Compare commits

..

45 Commits

Author SHA1 Message Date
Oleg Kalachev
fc2661ad88 Don’t show s3 progress 2021-06-29 03:57:04 +03:00
Oleg Kalachev
2deb4bd54c Upload to S3 with a raw command 2021-06-29 02:39:31 +03:00
Oleg Kalachev
dfb82608ad Use okalachev/upload-s3-action to upload to S3 2021-06-29 01:10:45 +03:00
Oleg Kalachev
94d339639e Upload image from Actions 2021-06-28 20:51:06 +03:00
Oleg Kalachev
3bc7fb406e Disable deploy in Travis 2021-06-28 19:59:20 +03:00
Oleg Kalachev
62e41bed40 Use git describe --always for image name 2021-06-23 23:30:49 +03:00
Oleg Kalachev
31d0d6e2fc Show built image size 2021-06-23 22:38:52 +03:00
Oleg Kalachev
f1fd8f73e8 Downgrade Node.js to v10.15.0 2021-06-23 21:44:01 +03:00
Oleg Kalachev
13e74f2d5b Update Node.js to v14.17.1 2021-06-23 17:46:11 +03:00
Oleg Kalachev
763b158fb5 Use install_gitbook for gitbook installation 2021-06-23 17:45:46 +03:00
Oleg Kalachev
6efa9c89d7 Yet another attempt to enforce using PX4’s mavlink in sitl_gazebo 2021-06-23 09:04:48 +03:00
Oleg Kalachev
93af5e2700 Try another way to enforce using PX4’s mavlink 2021-06-23 03:36:57 +03:00
Oleg Kalachev
2eb18b7ab3 Clone Firmware recursively 2021-06-23 02:55:30 +03:00
Oleg Kalachev
ef008af9d2 Simplify setup setp 2021-06-23 02:54:37 +03:00
Oleg Kalachev
5e38d72e63 Add comment 2021-06-23 02:52:10 +03:00
Oleg Kalachev
ae92554d52 Enforce using PX4’s mavlink in sitl_gazebo
Instead of ROS mavlink
2021-06-23 02:25:34 +03:00
Oleg Kalachev
6b464d83b9 Make examples directory a symlink 2021-06-23 00:06:05 +03:00
Oleg Kalachev
6a41aa1c21 Clone master branch of clover 2021-06-23 00:04:14 +03:00
Oleg Kalachev
3e22ed3824 Use base focal image 2021-06-23 00:03:17 +03:00
Oleg Kalachev
acf9d304d2 Use apt-get not apt
apt issues warnings as it doesn’t have a stable interface
2021-06-22 23:52:42 +03:00
Oleg Kalachev
3621327929 Merge commit 'd0670f123588a5144f41c5626f49c952f061780a' into actions-noetic 2021-06-22 23:47:02 +03:00
Oleg Kalachev
0759a10973 Echo commands in install software script 2021-06-22 21:56:46 +03:00
Oleg Kalachev
e491ca6e18 Echo commands in build script 2021-06-22 21:55:39 +03:00
Oleg Kalachev
15b685ca06 Make build script work on mac and linux 2021-06-22 21:54:47 +03:00
Oleg Kalachev
09551d89e3 Use packer for darwin 2021-06-22 20:17:17 +03:00
Oleg Kalachev
ae652f0d1c Try macos-10.15 2021-06-22 20:14:55 +03:00
Oleg Kalachev
2b5548fe7f Try Ubuntu Bionic 2021-06-22 19:10:44 +03:00
Oleg Kalachev
969ed1dbdc Use apt-get not apt 2021-06-22 19:06:10 +03:00
Oleg Kalachev
fc4b87bb64 Ubuntu 20.04 2021-06-22 19:02:51 +03:00
Oleg Kalachev
5fbcca0fa3 Simplify script 2021-06-22 19:00:03 +03:00
Oleg Kalachev
aaadd0f72e Fix 2021-06-22 18:59:25 +03:00
Oleg Kalachev
b3faab68e1 Echo commands 2021-06-22 18:52:07 +03:00
Oleg Kalachev
93d75e8a02 Add GitHub actions workflow 2021-06-22 18:20:59 +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
9 changed files with 30 additions and 116 deletions

View File

@@ -5,8 +5,6 @@ on:
branches: [ '*' ]
pull_request:
branches: [ master ]
release:
types: [ created ]
jobs:
build:
@@ -20,9 +18,5 @@ jobs:
- name: Build
run: ./build.sh
- name: Upload
if: ${{ github.event_name == 'release' }}
# Not using ready S3 actions, because they either don't run on macOS machines or don't support changing the endpoint
run: |
AWS_ACCESS_KEY_ID=${{secrets.S3_KEY}} AWS_SECRET_ACCESS_KEY=${{secrets.S3_SECRET_KEY}} aws s3 sync . s3://clovervm/ --acl public-read --endpoint-url https://ams3.digitaloceanspaces.com --no-progress
echo Uploaded https://clovervm.ams3.digitaloceanspaces.com/$(ls)
run: AWS_ACCESS_KEY_ID=${{secrets.S3_KEY}} AWS_SECRET_ACCESS_KEY=${{secrets.S3_SECRET_KEY}} aws s3 sync . s3://clovervm/ --acl public-read --endpoint-url https://ams3.digitaloceanspaces.com --no-progress
working-directory: output-virtualbox-ovf

21
LICENSE
View File

@@ -1,21 +0,0 @@
MIT License
Copyright (c) 2020 Copter Express Technologies
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

View File

@@ -1,19 +0,0 @@
# Clover drone VM image
The generator of Clover developer virtual machine image (`.ova` file) to simplify working with Clover and Clover simulation.
Download the latest image in [Releases](https://github.com/CopterExpress/clover_vm/releases/latest) section.
<img src=https://clover.coex.tech/assets/simulator.jpg width=600>
Image contains:
* Ubuntu 20.04 Focal.
* ROS Noetic.
* PX4 autopilot, QGroundControl.
* Preinstalled [Clover](https://github.com/CopterExpress/clover) and Clover simulation packages.
* Shortcuts for running Clover simulator.
* VSCode.
* Useful robotics-related software.
See detailed information in [Clover drone documentation](https://clover.coex.tech/en/simulation_vm.html).

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 @@ Version=1.0
Type=Application
Name=jMAVSim
Comment=A lightweight PX4 simulator
Exec=/bin/bash -c 'cd ~/PX4-Autopilot; make px4_sitl jmavsim'
Exec=/bin/bash -c 'cd ~/Firmware; make px4_sitl jmavsim'
Icon=openjdk-8
Path=
Terminal=true

View File

@@ -6,7 +6,7 @@ index 8de3079..3fdae02 100644
${CMAKE_SOURCE_DIR}/mavlink/
../../mavlink/
../mavlink/
+ $ENV{HOME}/PX4-Autopilot/mavlink/include
+ $ENV{HOME}/Firmware/mavlink/include
${CATKIN_DEVEL_PREFIX}/
)

View File

@@ -32,18 +32,14 @@ ${PACKER} build ros_ide_vm.json
echo "--- Marking the VM"
# if [[ $GITHUB_REF == refs/tags/*-rc* ]]; then
# remove rc label
# VERSION=${GITHUB_REF#refs/tags/}
# VERSION=${VERSION/-rc*/}
if [[ $GITHUB_REF == refs/tags/* ]]; then
VERSION=${GITHUB_REF#refs/tags/}
else
VERSION=$(git describe --always)
fi
VM_NAME="clover-devel_${VERSION}.ova"
GIT_REV=$(git rev-parse --short HEAD)
GIT_DESCRIBE=$(git describe --always)
VM_NAME="clover-devel_${GIT_DESCRIBE}.ova"
mv ./output-virtualbox-ovf/clover-devel.ova ./output-virtualbox-ovf/${VM_NAME}
ls -l output-virtualbox-ovf
echo "--- All done!"
if [ "${CI}" == "true" ]; then
echo "Deploying to https://clovervm.ams3.digitaloceanspaces.com/${VM_NAME}"
fi

View File

@@ -65,7 +65,7 @@
},
{
"type": "shell",
"script": "scripts/install_software.sh",
"script": "scripts/installSoftware.sh",
"execute_command": "PASSWORD='{{user `password`}}' bash '{{.Path}}'"
}]
}

View File

@@ -31,20 +31,17 @@ rosdep update
# FIXME: PX4 needs pip to be installed
# FIXME: python2 dependencies?
echo "--- Downloading PX4 and installing its dependencies"
git clone --recursive --depth 1 --branch v1.12.0 https://github.com/PX4/PX4-Autopilot.git ${HOME}/PX4-Autopilot
git clone --recursive -b v1.11.1-clover https://github.com/CopterExpress/Firmware ${HOME}/Firmware
# PX4 v1.11.1 script will happily run sudo by itself
${HOME}/PX4-Autopilot/Tools/setup/ubuntu.sh
${HOME}/Firmware/Tools/setup/ubuntu.sh
# Ubuntu 20.04 no longer sets assistive_technologies, thankfully
echo "--- Prebuilding PX4 SITL configuration"
make -C ${HOME}/PX4-Autopilot px4_sitl
make -C ${HOME}/Firmware px4_sitl
echo "--- Patching gazebo plugins for SITL"
# cd ${HOME}/PX4-Autopilot/Tools/sitl_gazebo
# patch -p1 < /tmp/patches/sitl_gazebo.patch
echo 'export SVGA_VGPU10=0' >> ${HOME}/PX4-Autopilot/Tools/setup_gazebo.bash
echo "source /usr/share/gazebo/setup.sh" >> ~/.bashrc
echo "export SVGA_VGPU10=0" >> ~/.bashrc
cd ${HOME}/Firmware/Tools/sitl_gazebo
patch -p1 < /tmp/patches/sitl_gazebo.patch
echo 'export SVGA_VGPU10=0' >> ${HOME}/Firmware/Tools/setup_gazebo.bash
echo "source /opt/ros/noetic/setup.bash" >> ~/.bashrc
@@ -97,8 +94,8 @@ 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
ln -s ${HOME}/PX4-Autopilot ${HOME}/catkin_ws/src/PX4-Autopilot
ln -s ${HOME}/PX4-Autopilot/Tools/sitl_gazebo ${HOME}/catkin_ws/src/sitl_gazebo
ln -s ${HOME}/Firmware ${HOME}/catkin_ws/src/Firmware
ln -s ${HOME}/Firmware/Tools/sitl_gazebo ${HOME}/catkin_ws/src/sitl_gazebo
rosdep install --from-paths ${HOME}/catkin_ws/src --ignore-src --rosdistro noetic -y
sudo /opt/ros/noetic/lib/mavros/install_geographiclib_datasets.sh
sudo /usr/bin/python3 -m pip install -r ${HOME}/catkin_ws/src/clover/clover/requirements.txt
@@ -106,11 +103,6 @@ source /opt/ros/noetic/setup.bash
cd ${HOME}/catkin_ws && catkin_make
echo "source ${HOME}/catkin_ws/devel/setup.bash" >> ~/.bashrc
source $HOME/catkin_ws/devel/setup.bash
echo "--- Adding Clover vehicle startup script to PX4"
ln -s "$(catkin_find clover_simulation airframes)"/* $HOME/PX4-Autopilot/ROMFS/px4fmu_common/init.d-posix/airframes/
echo "--- Installing npm"
cd ${HOME}
NODE_VERSION=v10.15.0 # GitBook won't install on newer version
@@ -131,8 +123,7 @@ 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"
ln -s ${HOME}/catkin_ws/src/clover/clover/examples ${HOME}/
[[ -d ${HOME}/examples ]] # test symlink is valid
ln -s ${HOME}/catkin_ws/src/clover/builder/assets/examples ${HOME}/
echo "--- Enabling roscore service"
sed -i "s/pi/${USER}/g" ${HOME}/catkin_ws/src/clover/builder/assets/roscore.service
@@ -165,40 +156,3 @@ chmod a+x ${HOME}/Desktop/*
echo "--- Cleaning up"
sudo -E sh -c 'apt-get -y autoremove; apt-get -y autoclean; apt-get -y clean; fstrim -v /'
echo "--- Validating"
# python --version # python-is-python3
python2 --version
python3 --version
# ipython --version
ipython3 --version
gazebo --version || true # FIXME: Gazebo exits with 255 on --version somehow
node -v
npm -v
byobu --version
git --version
vim --version
pip --version
pip3 --version
monkey --version
systemctl --version
# TODO: add Python tests
roscore -h
rosversion px4
rosversion clover
rosversion aruco_pose
rosversion mavros
rosversion mavros_extras
rosversion ws281x
rosversion led_msgs
rosversion dynamic_reconfigure
rosversion tf2_web_republisher
# rosversion compressed_image_transport
# rosversion rosbridge_suite
rosversion cv_camera
rosversion web_video_server
rosversion nodelet
echo "Trying running the Gazebo simulator, check the output"
timeout --preserve-status 30 roslaunch clover_simulation simulator.launch gui:=false --screen