Compare commits

...

42 Commits

Author SHA1 Message Date
Tim Kondratiev
f269f98b7b Clone Firmware recursively 2021-05-08 16:07:18 +03:00
Tim Kondratiev
bd481d09b9 Generate new sitl_gazebo. 2021-05-08 13:47:48 +03:00
Тимофей Кондратьев
b1b291d2aa Use Clover 22-armhf branch 2021-04-15 15:23:21 +03:00
Тимофей Кондратьев
6e36f2e912 Merge branch master into noetic_vm 2021-04-15 15:11:44 +03:00
Oleg Kalachev
129936bb4c v0.4.1 2021-02-22 20:42:39 +03:00
Oleg Kalachev
8393fd4c27 Fix building sitl_gazebo (#2) 2021-01-26 15:49:44 +03:00
Oleg Kalachev
141a6f37b5 Add jMAVSim + Clover shortcut 2021-01-13 18:29:54 +03:00
Oleg Kalachev
7b046547a4 Simplify VS Code shortcut title 2021-01-13 18:29:44 +03:00
Alexey Rogachevskiy
d0670f1235 ros_ide_vm: Don't try to disable scrensaver
Apparently there's more to it than just this one file. Need to investigate further.
2020-10-27 00:06:59 +03:00
Alexey Rogachevskiy
5b599431a1 scripts: Re-add rqt_multiplot installation 2020-10-26 21:58:33 +03:00
Alexey Rogachevskiy
de95bbb2bb scripts: Build against the 22 branch 2020-10-26 21:41:07 +03:00
Alexey Rogachevskiy
74a83d7159 ros_ide_vm: Remove vscode configuration
It's all Python3 now
2020-10-26 21:39:54 +03:00
Alexey Rogachevskiy
244c678e46 scripts, ros_ide_vm: Disable screen autolock 2020-10-26 21:36:54 +03:00
Alexey Rogachevskiy
56e0f805db scripts: Temporarily disable rqt_multiplot installation
It is not yet released for Noetic. May have to build it from sources for x86_64.
2020-10-26 19:25:31 +03:00
Alexey Rogachevskiy
07c328484d scripts: Use proper branch for clover 2020-10-26 11:06:03 +03:00
Alexey Rogachevskiy
dafebce445 scripts: Re-enable patching sitl_gazebo 2020-10-26 09:40:44 +03:00
Alexey Rogachevskiy
ed2e767748 scripts: Use absolute path for mav_comm clone 2020-10-26 08:32:51 +03:00
Alexey Rogachevskiy
407a1a30cf scripts: Use Python3, noetic wherever possible 2020-10-25 23:58:34 +03:00
Alexey Rogachevskiy
b3dd27356e assets: Update sitl_gazebo patch 2020-10-25 23:03:37 +03:00
Alexey Rogachevskiy
841f8f45b1 Update to Ubuntu Focal 2020-10-25 22:59:50 +03:00
Oleg Kalachev
29f4118dc6 Use git describe for image name 2020-10-23 16:59:37 +03:00
Alexey Rogachevskiy
18e3d2408f scripts: Use master branch for clover 2020-08-14 16:36:39 +03:00
Alexey Rogachevskiy
b452360661 build: Fix syntax 2020-08-11 23:24:09 +03:00
Alexey Rogachevskiy
db0d54ba27 build: Show deploy link in logs 2020-08-11 00:59:21 +03:00
Alexey Rogachevskiy
b8efc64718 assets, scripts: More clever->clover transitions 2020-08-10 19:01:37 +03:00
Alexey Rogachevskiy
16e81cabf9 scripts: ugh, npm 2020-08-10 02:14:38 +03:00
Alexey Rogachevskiy
a87234921d scripts: Expose examples 2020-08-10 00:33:33 +03:00
Alexey Rogachevskiy
62391fa4d4 scripts: Install Node.js and build Clover docs 2020-08-10 00:30:45 +03:00
Alexey Rogachevskiy
d3dded96a8 scripts: Use v1.10.1-clover branch for PX4 2020-08-07 17:07:49 +03:00
Alexey Rogachevskiy
de5ea26b6c travis: Use xvfb to run packer
This may help with SSH timeouts - apparently something is wrong when
Virtualbox starts without an X session, so the internal X session fails.
2020-08-04 13:23:01 +03:00
Alexey Rogachevskiy
9c7e1926aa base_vm, ros_ide_vm: Rename clever to clover 2020-08-04 00:10:00 +03:00
Alexey Rogachevskiy
345d639e53 scripts: Remove hardcoded paths to $HOME, prepare for renaming 2020-08-03 19:06:15 +03:00
Alexey Rogachevskiy
03a52f7129 scripts: Respect requirements.txt from clover 2020-07-22 00:35:03 +03:00
Alexey Rogachevskiy
f5ded4c4e2 build: Bring back check for prebuilt image 2020-07-20 23:31:50 +03:00
Alexey Rogachevskiy
d2bce5c4ad travis: Try downgrading virtualbox
Not sure if it's going to help, but why not?
2020-07-20 23:16:30 +03:00
Alexey Rogachevskiy
e31ff0d850 build.sh: Always run Packer twice
First invocation will most likely fail, but I can't see other major differences
between working (travis-integration branch) and not working (main branch)
Virtualboxes.
2020-07-20 22:45:34 +03:00
Alexey Rogachevskiy
5ede163f02 travis, build: Produce less dots 2020-07-20 22:29:26 +03:00
Alexey Rogachevskiy
f209bf024c build.sh: Add version to resulting image 2020-07-20 22:03:30 +03:00
Alexey Rogachevskiy
66f544add5 travis: Upload directly to root 2020-07-20 22:03:14 +03:00
Alexey Rogachevskiy
4417ac6651 build.sh: Don't try to build base image if it already exists 2020-07-20 21:55:01 +03:00
Alexey Rogachevskiy
34fc51389f travis: Enable image builds for main branch
Squashed commit of the following:

commit c70fc8dd0b
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Thu Jul 9 21:26:47 2020 +0300

    travis: Use proper bucket name

commit d9fc21773b
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Thu Jul 9 21:14:38 2020 +0300

    travis: Use S3 key stored in travis environment

commit 8ef93c928a
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Thu Jul 9 20:02:28 2020 +0300

    travis: Set actual S3 endpoint

commit 848e4b33f7
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Thu Jul 9 18:50:41 2020 +0300

    travis: Try enabling deployments

commit 11196f0c7d
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Thu Jul 9 17:03:44 2020 +0300

    scripts: Allow apt to finish doing initial updates

commit 46064eafe2
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 22:16:18 2020 +0300

    ros_ide_vm: Be even more CI-friendly

commit 72f35a0b04
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 22:05:57 2020 +0300

    ros_ide_vm: Allocate less resources for build

commit 246ba6e5fb
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 22:04:16 2020 +0300

    travis: Download base VM instead of building it

commit 9d2830bfeb
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 20:29:26 2020 +0300

    base_vm: Try building in headless mode

commit 31db396477
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 18:22:54 2020 +0300

    base_vm: Use simplier hardware config

commit 8709ec5873
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 18:05:59 2020 +0300

    build: Download Packer in CI environment (hack)

commit 691cdde431
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 17:58:23 2020 +0300

    travis: Bump Virtualbox version

commit e2c6d709db
Author: Alexey Rogachevskiy <sfalexrog@gmail.com>
Date:   Sun Jul 5 17:54:11 2020 +0300

    travis: Try running Packer in CI
2020-07-20 21:52:52 +03:00
Alexey Rogachevskiy
6c42bbff35 scripts: Simplify sudo invocations 2020-07-05 19:20:11 +03:00
13 changed files with 231 additions and 76 deletions

24
.travis.yml Normal file
View File

@@ -0,0 +1,24 @@
language: generic
dist: bionic
before_install:
- wget https://www.virtualbox.org/download/oracle_vbox_2016.asc -O- | sudo apt-key
add - && sudo sh -c "echo deb https://download.virtualbox.org/virtualbox/debian
bionic contrib >> /etc/apt/sources.list" && sudo apt-get update && sudo apt-get
install build-essential gcc make linux-headers-$(uname -r) virtualbox-6.0 && sudo
usermod -aG vboxusers $(whoami)
- mkdir output-virtualbox-iso && pushd output-virtualbox-iso && wget --progress=dot:giga https://clovervm.ams3.digitaloceanspaces.com/base-focal.ova -O clover-devel.ova
&& popd
- sudo apt install -y xvfb
script:
- "xvfb-run ./build.sh"
deploy:
provider: s3
access_key_id: XOJXX4IOM66XN7VZAFYX
secret_access_key: $S3_SECRET_KEY
bucket: clovervm
local-dir: output-virtualbox-ovf
acl: public_read
on:
all_branches: true
skip_cleanup: true
endpoint: https://ams3.digitaloceanspaces.com

View File

@@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<channel name="xfce4-power-manager" version="1.0">
<property name="xfce4-power-manager" type="empty">
<property name="power-button-action" type="empty"/>
<property name="lock-screen-suspend-hibernate" type="empty"/>
<property name="logind-handle-lid-switch" type="empty"/>
<property name="blank-on-ac" type="empty"/>
<property name="blank-on-battery" type="empty"/>
<property name="dpms-enabled" type="bool" value="false"/>
<property name="dpms-on-ac-sleep" type="empty"/>
<property name="dpms-on-ac-off" type="empty"/>
<property name="dpms-on-battery-sleep" type="empty"/>
<property name="dpms-on-battery-off" type="empty"/>
<property name="show-panel-label" type="empty"/>
<property name="inactivity-sleep-mode-on-ac" type="empty"/>
<property name="inactivity-sleep-mode-on-battery" type="empty"/>
<property name="show-tray-icon" type="bool" value="false"/>
</property>
</channel>

View File

@@ -3,7 +3,7 @@ Version=1.0
Type=Application Type=Application
Name=Gazebo PX4 Name=Gazebo PX4
Comment=Fully-featured Gazebo simulation with default PX4 settings Comment=Fully-featured Gazebo simulation with default PX4 settings
Exec=/bin/bash -c 'source /home/clever/catkin_ws/devel/setup.bash; roslaunch clover_simulation simulator.launch' Exec=/bin/bash -c 'source /home/clover/catkin_ws/devel/setup.bash; roslaunch clover_simulation simulator.launch'
Icon=gazebo Icon=gazebo
Path= Path=
Terminal=true Terminal=true

View File

@@ -1,8 +1,8 @@
[Desktop Entry] [Desktop Entry]
Name=VS Code + ROS Name=VS Code
Comment=Code Editing. Redefined. Comment=Code Editing. Redefined.
GenericName=Text Editor GenericName=Text Editor
Exec=/bin/bash -c "source /home/clever/catkin_ws/devel/setup.bash; /usr/share/code/code --no-sandbox --unity-launch %F" Exec=/bin/bash -c "source /home/clover/catkin_ws/devel/setup.bash; /usr/share/code/code --no-sandbox --unity-launch %F"
Icon=/usr/share/pixmaps/com.visualstudio.code.png Icon=/usr/share/pixmaps/com.visualstudio.code.png
Type=Application Type=Application
StartupNotify=false StartupNotify=false

View File

@@ -0,0 +1,10 @@
[Desktop Entry]
Version=1.0
Type=Application
Name=jMAVSim + Clover
Comment=A lightweight PX4 simulator + Clover services
Exec=/bin/bash -c 'source /home/clover/catkin_ws/devel/setup.bash; roslaunch clover_simulation simulator.launch type:=jmavsim'
Icon=openjdk-8
Path=
Terminal=true
StartupNotify=false

View File

@@ -3,7 +3,7 @@ Type=Application
Name=QGroundControl Name=QGroundControl
GenericName=Ground Control Station GenericName=Ground Control Station
Comment=UAS ground control station Comment=UAS ground control station
Icon=/home/clever/Pictures/qgroundcontrol.png Icon=/home/clover/Pictures/qgroundcontrol.png
Exec=/home/clever/QGroundControl.AppImage Exec=/home/clover/QGroundControl.AppImage
Terminal=false Terminal=false
Categories=Utility; Categories=Utility;

View File

@@ -11,8 +11,23 @@ index 4fbeab2..18a192b 100644
using namespace cv; using namespace cv;
using namespace std; using namespace std;
diff --git a/package.xml b/package.xml
index ae0fb34..12f17b8 100644
--- a/package.xml
+++ b/package.xml
@@ -50,8 +50,8 @@
<build_depend>roscpp</build_depend>
<build_depend>sensor_msgs</build_depend>
<build_depend>std_msgs</build_depend>
- <build_depend>python-rospkg</build_depend>
- <build_depend>python-jinja2</build_depend>
+ <build_depend>python3-rospkg</build_depend>
+ <build_depend>python3-jinja2</build_depend>
<run_depend>eigen</run_depend>
<run_depend>gazebo_ros</run_depend>
<run_depend>geometry_msgs</run_depend>
diff --git a/src/gazebo_geotagged_images_plugin.cpp b/src/gazebo_geotagged_images_plugin.cpp diff --git a/src/gazebo_geotagged_images_plugin.cpp b/src/gazebo_geotagged_images_plugin.cpp
index 050558f..7029199 100644 index 050558f..3edda33 100644
--- a/src/gazebo_geotagged_images_plugin.cpp --- a/src/gazebo_geotagged_images_plugin.cpp
+++ b/src/gazebo_geotagged_images_plugin.cpp +++ b/src/gazebo_geotagged_images_plugin.cpp
@@ -581,7 +581,8 @@ void GeotaggedImagesPlugin::_send_capture_status(struct sockaddr* srcaddr) @@ -581,7 +581,8 @@ void GeotaggedImagesPlugin::_send_capture_status(struct sockaddr* srcaddr)
@@ -25,6 +40,25 @@ index 050558f..7029199 100644
_send_mavlink_message(&msg, srcaddr); _send_mavlink_message(&msg, srcaddr);
} }
@@ -591,6 +592,7 @@ void GeotaggedImagesPlugin::_handle_storage_info(const mavlink_message_t *pMsg,
float total_mib = 0.0f;
float available_mib = 0.0f;
boost::filesystem::space_info si = boost::filesystem::space(".");
+ const std::string storage_name = "SITL Camera Storage";
available_mib = (float)((double)si.available / (1024.0 * 1024.0));
total_mib = (float)((double)si.capacity / (1024.0 * 1024.0));
_send_cmd_ack(pMsg->sysid, pMsg->compid, MAV_CMD_REQUEST_STORAGE_INFORMATION, MAV_RESULT_ACCEPTED, srcaddr);
@@ -608,7 +610,9 @@ void GeotaggedImagesPlugin::_handle_storage_info(const mavlink_message_t *pMsg,
total_mib - available_mib, // used_capacity,
available_mib,
NAN, // read_speed,
- NAN // write_speed
+ NAN, // write_speed
+ STORAGE_TYPE_OTHER, // storage type
+ storage_name.c_str() // storage name
);
_send_mavlink_message(&msg, srcaddr);
}
diff --git a/src/gazebo_mavlink_interface.cpp b/src/gazebo_mavlink_interface.cpp diff --git a/src/gazebo_mavlink_interface.cpp b/src/gazebo_mavlink_interface.cpp
index 5d29017..d4dd6a7 100644 index 5d29017..d4dd6a7 100644
--- a/src/gazebo_mavlink_interface.cpp --- a/src/gazebo_mavlink_interface.cpp

View File

@@ -1,3 +0,0 @@
{
"python.pythonPath": "/usr/bin/python2.7"
}

View File

@@ -1,8 +1,8 @@
{ {
"variables" : { "variables" : {
"user": "clever", "user": "clover",
"password": "clever", "password": "clover",
"vm-name": "clever-devel" "vm-name": "clover-devel"
}, },
"builders": [{ "builders": [{
"type": "virtualbox-iso", "type": "virtualbox-iso",
@@ -13,12 +13,14 @@
"disk_size": "30000", "disk_size": "30000",
"hard_drive_interface": "sata", "hard_drive_interface": "sata",
"vboxmanage": [ "vboxmanage": [
["modifyvm", "{{.Name}}", "--memory", "4096", "--vram", "128", "--mouse", "usbtablet", "--accelerate3d", "on", "--apic", "on", "--rtcuseutc", "on", "--graphicscontroller", "vmsvga", "--nictype1", "virtio"], ["modifyvm", "{{.Name}}", "--memory", "2048", "--mouse", "usbtablet", "--apic", "on", "--rtcuseutc", "on", "--nictype1", "virtio"],
["storageattach", "{{.Name}}", "--storagectl", "SATA Controller", "--port", "0", "--nonrotational", "on", "--discard", "on"] ["storageattach", "{{.Name}}", "--storagectl", "SATA Controller", "--port", "0", "--nonrotational", "on", "--discard", "on"]
], ],
"iso_url": "http://archive.ubuntu.com/ubuntu/dists/bionic/main/installer-amd64/current/images/netboot/mini.iso", "headless": "false",
"iso_checksum": "bed8a55ae2a657f8349fe3271097cff3a5b8c3d1048cf258568f1601976fa30d",
"iso_url": "http://archive.ubuntu.com/ubuntu/dists/focal/main/installer-amd64/current/legacy-images/netboot/mini.iso",
"iso_checksum": "0e79e00bf844929d40825b1f0e8634415cda195ba23bae0b041911fde4dfe018",
"iso_checksum_type": "sha256", "iso_checksum_type": "sha256",
"ssh_password": "{{user `password`}}", "ssh_password": "{{user `password`}}",

View File

@@ -1,23 +1,39 @@
#!/bin/bash #!/bin/bash
PACKER=$(which packer) set -e
if [ "x${PACKER}" == "x" ]; then # FIXME: Use system Packer if possible
#PACKER=$(which packer)
#if [ "x${PACKER}" == "x" ]; then
PACKER="./packer"
if [ ! -f ${PACKER} ]; then
echo "Packer not found; downloading v1.5.4 from Hashicorp" echo "Packer not found; downloading v1.5.4 from Hashicorp"
wget https://releases.hashicorp.com/packer/1.5.4/packer_1.5.4_linux_amd64.zip wget --progress=dot:giga https://releases.hashicorp.com/packer/1.5.4/packer_1.5.4_linux_amd64.zip
unzip packer_1.5.4_linux_amd64.zip unzip packer_1.5.4_linux_amd64.zip
rm packer_1.5.4_linux_amd64.zip rm packer_1.5.4_linux_amd64.zip
PACKER="./packer"
fi fi
echo "--- Using Packer version $(${PACKER} --version)" echo "--- Using Packer version $(${PACKER} --version)"
echo "--- Building base image" if [ ! -f output-virtualbox-iso/clover-devel.ova ]; then
echo "--- Building base image"
${PACKER} build base_vm.json ${PACKER} build -only=virtualbox-iso base_vm.json || true
fi
echo "--- Building extended image" echo "--- Building extended image"
${PACKER} build ros_ide_vm.json ${PACKER} build ros_ide_vm.json
echo "--- Marking the VM"
GIT_REV=$(git rev-parse --short HEAD)
GIT_DESCRIBE=$(git describe --tags)
VM_NAME="clover-devel_${GIT_DESCRIBE}.ova"
mv ./output-virtualbox-ovf/clover-devel.ova ./output-virtualbox-ovf/${VM_NAME}
echo "--- All done!" echo "--- All done!"
if [ "${CI}" == "true" ]; then
echo "Deploying to https://clovervm.ams3.digitaloceanspaces.com/${VM_NAME}"
fi

View File

@@ -7,7 +7,7 @@ d-i debconf debconf/frontend select Noninteractive
d-i debian-installer/locale string en_US.utf8 d-i debian-installer/locale string en_US.utf8
### Hardware enablement kernel ### Hardware enablement kernel
d-i base-installer/kernel/override-image string linux-generic-hwe-18.04 d-i base-installer/kernel/override-image string linux-generic-hwe-20.04
### Keyboard selection ### Keyboard selection
d-i console-setup/ask_detect boolean false d-i console-setup/ask_detect boolean false
@@ -25,7 +25,7 @@ ubiquity console-keymaps-at/variant select us
d-i kbd-chooser/method select British English d-i kbd-chooser/method select British English
### Network ### Network
d-i netcfg/get_hostname string clever-devel d-i netcfg/get_hostname string clover-devel
d-i netcfg/get_domain string unassigned-domain d-i netcfg/get_domain string unassigned-domain
### Clock and time zone setup ### Clock and time zone setup
@@ -41,10 +41,10 @@ d-i partman/choose_partition select finish
d-i partman/confirm boolean true d-i partman/confirm boolean true
### Account setup ### Account setup
d-i passwd/user-fullname string clever d-i passwd/user-fullname string clover
d-i passwd/username string clever d-i passwd/username string clover
d-i passwd/user-password password clever d-i passwd/user-password password clover
d-i passwd/user-password-again password clever d-i passwd/user-password-again password clover
d-i passwd/auto-login boolean true d-i passwd/auto-login boolean true
d-i user-setup/encrypt-home boolean false d-i user-setup/encrypt-home boolean false
d-i user-setup/allow-password-weak boolean true d-i user-setup/allow-password-weak boolean true

View File

@@ -1,8 +1,8 @@
{ {
"variables": { "variables": {
"user": "clever", "user": "clover",
"password": "clever", "password": "clover",
"vm-name": "clever-devel", "vm-name": "clover-devel",
"scriptsDir": "scripts", "scriptsDir": "scripts",
"assetsDir": "assets" "assetsDir": "assets"
}, },
@@ -13,8 +13,10 @@
"format": "ova", "format": "ova",
"guest_additions_mode": "disable", "guest_additions_mode": "disable",
"headless": "false",
"vboxmanage": [ "vboxmanage": [
["modifyvm", "{{.Name}}", "--memory", "8192", "--vram", "128", "--mouse", "usbtablet", "--rtcuseutc", "on", "--usb", "on", "--usbxhci", "on", "--nictype1", "virtio"], ["modifyvm", "{{.Name}}", "--memory", "6144", "--vram", "128", "--mouse", "usbtablet", "--rtcuseutc", "on", "--nictype1", "virtio"],
["storageattach", "{{.Name}}", "--storagectl", "SATA Controller", "--port", "0", "--nonrotational", "on", "--discard", "on"] ["storageattach", "{{.Name}}", "--storagectl", "SATA Controller", "--port", "0", "--nonrotational", "on", "--discard", "on"]
], ],
"import_opts": "importtovdi", "import_opts": "importtovdi",
@@ -39,17 +41,17 @@
"provisioners": [{ "provisioners": [{
"type": "file", "type": "file",
"source": "{{user `assetsDir`}}/background/", "source": "{{user `assetsDir`}}/background/",
"destination": "/home/clever/Pictures" "destination": "/home/{{user `user`}}/Pictures"
}, },
{ {
"type": "file", "type": "file",
"source": "{{user `assetsDir`}}/pictures/", "source": "{{user `assetsDir`}}/pictures/",
"destination": "/home/clever/Pictures" "destination": "/home/{{user `user`}}/Pictures"
}, },
{ {
"type": "file", "type": "file",
"source": "{{user `assetsDir`}}/desktop/", "source": "{{user `assetsDir`}}/desktop/",
"destination": "/home/clever/Desktop" "destination": "/home/{{user `user`}}/Desktop"
}, },
{ {
"type": "file", "type": "file",
@@ -65,10 +67,5 @@
"type": "shell", "type": "shell",
"script": "scripts/installSoftware.sh", "script": "scripts/installSoftware.sh",
"execute_command": "PASSWORD='{{user `password`}}' bash '{{.Path}}'" "execute_command": "PASSWORD='{{user `password`}}' bash '{{.Path}}'"
},
{
"type": "file",
"source": "{{user `assetsDir`}}/vscode/",
"destination": "/home/clever/.config/Code/User/"
}] }]
} }

View File

@@ -6,44 +6,53 @@ echo "--- Current environment:"
/usr/bin/env /usr/bin/env
echo "Enabling passwordless sudo" echo "Enabling passwordless sudo"
echo "${PASSWORD}" | sudo -E -S sh -c 'echo "clever ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers' echo "${PASSWORD}" | sudo -E -S sh -c "echo '${USER} ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers"
echo "--- Increasing apt retries"
sudo -E sh -c 'echo "APT::Acquire::Retries \"3\";" > /etc/apt/apt.conf.d/80-retries'
cat /etc/apt/apt.conf.d/80-retries
echo "--- Allowing apt to perform its updates"
sudo -E sh -c 'apt update; while fuser /var/lib/dpkg/lock ; do sleep 0.5 ; done'
echo "--- Installing open-vm-tools" echo "--- Installing open-vm-tools"
echo "${PASSWORD}" | sudo -E -S sh -c 'apt update; apt install -y open-vm-tools open-vm-tools-desktop' sudo -E sh -c 'apt update; apt install -y open-vm-tools open-vm-tools-desktop'
echo "--- Installing ROS desktop packages" echo "--- Installing ROS desktop packages"
echo "${PASSWORD}" | sudo -E -S sh -c 'echo "deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main" > /etc/apt/sources.list.d/ros-latest.list' sudo -E sh -c 'echo "deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main" > /etc/apt/sources.list.d/ros-latest.list'
echo "${PASSWORD}" | sudo -E -S sh -c 'apt-key adv --keyserver "hkp://keyserver.ubuntu.com:80" --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654' sudo -E sh -c 'apt-key adv --keyserver "hkp://keyserver.ubuntu.com:80" --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654'
echo "${PASSWORD}" | sudo -E -S sh -c 'apt update; apt install -y python-rosdep python-rosinstall-generator python-wstool build-essential ros-melodic-desktop' sudo -E sh -c 'apt update; apt install -y python3-rosdep python3-rosinstall-generator python3-wstool build-essential ros-noetic-desktop'
echo "${PASSWORD}" | sudo -E -S sh -c 'rosdep init' sudo -E sh -c 'rosdep init'
rosdep update rosdep update
# FIXME: PX4 needs pip to be installed
# FIXME: python2 dependencies?
echo "--- Downloading PX4 and installing its dependencies" echo "--- Downloading PX4 and installing its dependencies"
git clone -b v1.10.1-clever https://github.com/CopterExpress/Firmware ${HOME}/Firmware git clone --recursive -b v1.11.1-clover https://github.com/CopterExpress/Firmware ${HOME}/Firmware
echo "${PASSWORD}" | sudo -E -S sh -c '${HOME}/Firmware/Tools/setup/ubuntu.sh' # PX4 v1.11.1 script will happily run sudo by itself
echo "${PASSWORD}" | sudo -E -S sh -c 'echo "2" | update-alternatives --config java' ${HOME}/Firmware/Tools/setup/ubuntu.sh
echo "${PASSWROD}" | sudo -E -S sed -i -e '/^assistive_technologies=/s/^/#/' /etc/java-*-openjdk/accessibility.properties # Ubuntu 20.04 no longer sets assistive_technologies, thankfully
echo "--- Prebuilding PX4 SITL configuration" echo "--- Prebuilding PX4 SITL configuration"
make -C ${HOME}/Firmware px4_sitl make -C ${HOME}/Firmware px4_sitl
echo "--- Patching gazebo plugins for SITL" echo "--- Patching gazebo plugins for SITL"
cd ${HOME}/Firmware/Tools/sitl_gazebo cd ${HOME}/Firmware/Tools/sitl_gazebo
patch -p1 < /tmp/patches/sitl_gazebo.patch patch -p1 < /tmp/patches/sitl_gazebo.patch
echo 'export SVGA_VGPU10=0' >> /home/clever/Firmware/Tools/setup_gazebo.bash echo 'export SVGA_VGPU10=0' >> ${HOME}/Firmware/Tools/setup_gazebo.bash
echo "source /opt/ros/melodic/setup.bash" >> ~/.bashrc echo "source /opt/ros/noetic/setup.bash" >> ~/.bashrc
echo "--- Installing Visual Studio Code" echo "--- Installing Visual Studio Code"
echo "${PASSWORD}" | sudo -E -S sh -c 'apt update; apt install -y curl' sudo -E sh -c 'apt update; apt install -y curl'
curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > ${HOME}/packages.microsoft.gpg curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > ${HOME}/packages.microsoft.gpg
echo "${PASSWORD}" | sudo -E -S sh -c 'install -o root -g root -m 644 ${HOME}/packages.microsoft.gpg /usr/share/keyrings' sudo -E sh -c 'install -o root -g root -m 644 ${HOME}/packages.microsoft.gpg /usr/share/keyrings'
rm ${HOME}/packages.microsoft.gpg rm ${HOME}/packages.microsoft.gpg
echo "${PASSWORD}" | sudo -E -S sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list' sudo -E sh -c 'echo "deb [arch=amd64 signed-by=/usr/share/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/vscode stable main" > /etc/apt/sources.list.d/vscode.list'
echo "${PASSWORD}" | sudo -E -S sh -c 'apt install -y apt-transport-https; apt update; apt install -y code' sudo -E sh -c 'apt install -y apt-transport-https; apt update; apt install -y code'
code --install-extension ms-python.python code --install-extension ms-python.python
code --install-extension DavidAnson.vscode-markdownlint code --install-extension DavidAnson.vscode-markdownlint
code --install-extension ms-vscode.cmake-tools code --install-extension ms-vscode.cmake-tools
@@ -51,23 +60,70 @@ code --install-extension ms-vscode.cpptools
code --install-extension streetsidesoftware.code-spell-checker code --install-extension streetsidesoftware.code-spell-checker
code --install-extension eamodio.gitlens code --install-extension eamodio.gitlens
echo "--- Installing pylint" echo "--- Installing pylint"
/usr/bin/python2.7 -m pip install -U "pylint<2.0.0" --user /usr/bin/python3 -m pip install -U pylint --user
/usr/bin/python3.6 -m pip install -U pylint --user
echo "--- Cloning and installing Clever packages" echo "--- Cloning and installing Clover packages"
sudo sh -c 'curl http://deb.coex.tech/aptly_repo_signing.key 2> /dev/null | apt-key add -'
sudo sh -c 'echo "deb http://deb.coex.tech/ros xenial main" > /etc/apt/sources.list.d/coex.tech.list'
sudo sh -c 'echo "yaml file:///etc/ros/rosdep/coex.yaml" > /etc/ros/rosdep/sources.list.d/99-coex.list'
sudo sh -c 'cat <<EOF > /etc/ros/rosdep/coex.yaml
led_msgs:
ubuntu:
focal: [ros-noetic-led-msgs]
async_web_server_cpp:
ubuntu:
focal: [ros-noetic-async-web-server-cpp]
ros_pytest:
ubuntu:
focal: [ros-noetic-ros-pytest]
tf2_web_republisher:
ubuntu:
focal: [ros-noetic-tf2-web-republisher]
web_video_server:
ubuntu:
focal: [ros-noetic-web-video-server]
ws281x:
ubuntu:
focal: [ros-noetic-ws281x]
EOF'
sudo apt update
rosdep update
mkdir -p ${HOME}/catkin_ws/src mkdir -p ${HOME}/catkin_ws/src
git clone -b clover_description https://github.com/CopterExpress/clover ${HOME}/catkin_ws/src/clover git clone -b 22-armhf https://github.com/CopterExpress/clover ${HOME}/catkin_ws/src/clover
git clone https://github.com/CopterExpress/ros_led ${HOME}/catkin_ws/src/ros_led git clone https://github.com/CopterExpress/ros_led ${HOME}/catkin_ws/src/ros_led
# These packages are missing from Noetic release, but are required for sitl_gazebo
git clone https://github.com/ethz-asl/mav_comm ${HOME}/catkin_ws/src/mav_comm
# Make PX4 and Gazebo plugins visible in the workspace # Make PX4 and Gazebo plugins visible in the workspace
ln -s ${HOME}/Firmware ${HOME}/catkin_ws/src/Firmware ln -s ${HOME}/Firmware ${HOME}/catkin_ws/src/Firmware
ln -s ${HOME}/Firmware/Tools/sitl_gazebo ${HOME}/catkin_ws/src/sitl_gazebo ln -s ${HOME}/Firmware/Tools/sitl_gazebo ${HOME}/catkin_ws/src/sitl_gazebo
rosdep install --from-paths ${HOME}/catkin_ws/src --ignore-src --rosdistro melodic -y rosdep install --from-paths ${HOME}/catkin_ws/src --ignore-src --rosdistro noetic -y
curl https://raw.githubusercontent.com/mavlink/mavros/master/mavros/scripts/install_geographiclib_datasets.sh -o ${HOME}/install_geographiclib_datasets.sh sudo /opt/ros/noetic/lib/mavros/install_geographiclib_datasets.sh
chmod a+x ${HOME}/install_geographiclib_datasets.sh sudo /usr/bin/python3 -m pip install -r ${HOME}/catkin_ws/src/clover/clover/requirements.txt
echo "${PASSWORD}" | sudo -E -S sh -c '${HOME}/install_geographiclib_datasets.sh' source /opt/ros/noetic/setup.bash
source /opt/ros/melodic/setup.bash
cd ${HOME}/catkin_ws && catkin_make cd ${HOME}/catkin_ws && catkin_make
echo "source /home/clever/catkin_ws/devel/setup.bash" >> ~/.bashrc echo "source ${HOME}/catkin_ws/devel/setup.bash" >> ~/.bashrc
echo "--- Installing npm"
cd ${HOME}
wget --progress=dot:giga https://nodejs.org/dist/v10.15.0/node-v10.15.0-linux-x64.tar.gz
tar -xzf node-v10.15.0-linux-x64.tar.gz
sudo cp -R node-v10.15.0-linux-x64/* /usr/local/
rm -rf node-v10.15.0-linux-x64
rm node-v10.15.0-linux-x64.tar.gz
echo "--- Reconfiguring npm to use local prefix"
mkdir ${HOME}/.npm-global
npm config set prefix "${HOME}/.npm-global"
export PATH=${HOME}/.npm-global/bin:$PATH
echo 'export PATH='${HOME}'/.npm-global/bin:$PATH' >> ${HOME}/.bashrc
echo "--- Installing gitbook and building docs"
cd ${HOME}/catkin_ws/src/clover
NPM_CONFIG_UNSAFE_PERM=true npm install gitbook-cli -g
NPM_CONFIG_UNSAFE_PERM=true gitbook install
gitbook build
touch node_modules/CATKIN_IGNORE docs/CATKIN_IGNORE _book/CATKIN_IGNORE clover/www/CATKIN_IGNORE # ignore documentation files by catkin
echo "--- Exposing examples"
cp -R ${HOME}/catkin_ws/src/clover/builder/assets/examples ${HOME}/
echo "--- Enabling roscore service" echo "--- Enabling roscore service"
sed -i "s/pi/${USER}/g" ${HOME}/catkin_ws/src/clover/builder/assets/roscore.service sed -i "s/pi/${USER}/g" ${HOME}/catkin_ws/src/clover/builder/assets/roscore.service
@@ -75,13 +131,13 @@ sudo cp ${HOME}/catkin_ws/src/clover/builder/assets/roscore.service /etc/systemd
sudo systemctl enable roscore.service sudo systemctl enable roscore.service
echo "--- Installing QGroundControl" echo "--- Installing QGroundControl"
echo "${PASSWORD}" | sudo -E -S sh -c "usermod -a -G dialout $USER" sudo -E sh -c "usermod -a -G dialout $USER"
echo "${PASSWORD}" | sudo -E -S sh -c 'apt remove -y modemmanager; apt install -y gstreamer1.0-plugins-bad gstreamer1.0-libav' sudo -E sh -c 'apt remove -y modemmanager; apt install -y gstreamer1.0-plugins-bad gstreamer1.0-libav'
curl https://s3-us-west-2.amazonaws.com/qgroundcontrol/latest/QGroundControl.AppImage -o ${HOME}/QGroundControl.AppImage curl https://s3-us-west-2.amazonaws.com/qgroundcontrol/latest/QGroundControl.AppImage -o ${HOME}/QGroundControl.AppImage
chmod a+x ${HOME}/QGroundControl.AppImage chmod a+x ${HOME}/QGroundControl.AppImage
echo "--- Installing Firefox web browser" echo "--- Installing Firefox web browser"
echo "${PASSWORD}" | sudo -E -S sh -c 'apt update; apt install -y firefox' sudo -E sh -c 'apt update; apt install -y firefox'
echo "--- Installing Monkey web server" echo "--- Installing Monkey web server"
sudo apt install -y /tmp/packages/monkey_1.6.9-1_amd64.deb sudo apt install -y /tmp/packages/monkey_1.6.9-1_amd64.deb
@@ -90,14 +146,13 @@ sudo cp ${HOME}/catkin_ws/src/clover/builder/assets/monkey.service /etc/systemd/
sudo systemctl enable monkey sudo systemctl enable monkey
echo "--- Installing additional packages" echo "--- Installing additional packages"
sudo -E sh -c 'apt update; apt install -y sshfs gvfs-fuse gvfs-backends python3-opencv byobu ipython ipython3 byobu nmap lsof tmux vim ros-melodic-rqt-multiplot' sudo -E sh -c 'apt update; apt install -y sshfs gvfs-fuse gvfs-backends python3-opencv byobu ipython3 byobu nmap lsof tmux vim ros-noetic-rqt-multiplot'
echo "--- Personalizing VM" echo "--- Personalizing VM"
echo "${PASSWORD}" | sudo -E -S sh -c 'mv /etc/xdg/autostart/light-locker.desktop /etc/xdg/autostart/light-locker.desktop.old' sudo -E sh -c 'cp /usr/share/xfce4/backdrops/xubuntu-wallpaper.png /usr/share/xfce4/backdrops/xubuntu-wallpaper-old.png; cp ${HOME}/Pictures/Logo_COEX_2019_white_on_black.png /usr/share/xfce4/backdrops/xubuntu-wallpaper.png'
echo "${PASSWORD}" | sudo -E -S sh -c 'cp /usr/share/xfce4/backdrops/xubuntu-wallpaper.png /usr/share/xfce4/backdrops/xubuntu-wallpaper-old.png; cp /home/clever/Pictures/Logo_COEX_2019_white_on_black.png /usr/share/xfce4/backdrops/xubuntu-wallpaper.png' sudo -E sh -c 'hostnamectl set-hostname clover-dev; sed -i "s/ubuntu/clover-dev clover-dev.local/g" /etc/hosts'
echo "${PASSWORD}" | sudo -E -S sh -c 'hostnamectl set-hostname clever-dev; sed -i "s/ubuntu/clever-dev clever-dev.local/g" /etc/hosts'
echo "export ROS_HOSTNAME=\`hostname\`.local" >> ${HOME}/.bashrc echo "export ROS_HOSTNAME=\`hostname\`.local" >> ${HOME}/.bashrc
chmod a+x /home/clever/Desktop/* chmod a+x ${HOME}/Desktop/*
echo "--- Cleaning up" echo "--- Cleaning up"
echo "${PASSWORD}" | sudo -E -S sh -c 'apt-get -y autoremove; apt-get -y autoclean; apt-get -y clean; fstrim -v /' sudo -E sh -c 'apt-get -y autoremove; apt-get -y autoclean; apt-get -y clean; fstrim -v /'