mirror of
https://github.com/CopterExpress/clover_vm.git
synced 2026-06-01 17:49:32 +00:00
Compare commits
45 Commits
v1.0-rc.6
...
actions-no
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
fc2661ad88 | ||
|
|
2deb4bd54c | ||
|
|
dfb82608ad | ||
|
|
94d339639e | ||
|
|
3bc7fb406e | ||
|
|
62e41bed40 | ||
|
|
31d0d6e2fc | ||
|
|
f1fd8f73e8 | ||
|
|
13e74f2d5b | ||
|
|
763b158fb5 | ||
|
|
6efa9c89d7 | ||
|
|
93af5e2700 | ||
|
|
2eb18b7ab3 | ||
|
|
ef008af9d2 | ||
|
|
5e38d72e63 | ||
|
|
ae92554d52 | ||
|
|
6b464d83b9 | ||
|
|
6a41aa1c21 | ||
|
|
3e22ed3824 | ||
|
|
acf9d304d2 | ||
|
|
3621327929 | ||
|
|
0759a10973 | ||
|
|
e491ca6e18 | ||
|
|
15b685ca06 | ||
|
|
09551d89e3 | ||
|
|
ae652f0d1c | ||
|
|
2b5548fe7f | ||
|
|
969ed1dbdc | ||
|
|
fc4b87bb64 | ||
|
|
5fbcca0fa3 | ||
|
|
aaadd0f72e | ||
|
|
b3faab68e1 | ||
|
|
93d75e8a02 | ||
|
|
d0670f1235 | ||
|
|
5b599431a1 | ||
|
|
de95bbb2bb | ||
|
|
74a83d7159 | ||
|
|
244c678e46 | ||
|
|
56e0f805db | ||
|
|
07c328484d | ||
|
|
dafebce445 | ||
|
|
ed2e767748 | ||
|
|
407a1a30cf | ||
|
|
b3dd27356e | ||
|
|
841f8f45b1 |
8
.github/workflows/main.yml
vendored
8
.github/workflows/main.yml
vendored
@@ -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
21
LICENSE
@@ -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.
|
||||
19
README.md
19
README.md
@@ -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).
|
||||
10
assets/desktop/jMAVSim Clover.desktop
Normal file
10
assets/desktop/jMAVSim Clover.desktop
Normal 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
|
||||
@@ -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
|
||||
|
||||
@@ -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}/
|
||||
)
|
||||
|
||||
|
||||
18
build.sh
18
build.sh
@@ -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
|
||||
|
||||
@@ -65,7 +65,7 @@
|
||||
},
|
||||
{
|
||||
"type": "shell",
|
||||
"script": "scripts/install_software.sh",
|
||||
"script": "scripts/installSoftware.sh",
|
||||
"execute_command": "PASSWORD='{{user `password`}}' bash '{{.Path}}'"
|
||||
}]
|
||||
}
|
||||
|
||||
@@ -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
|
||||
Reference in New Issue
Block a user