diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 05a48fc6..aafd67c2 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -11,3 +11,17 @@ updates: directory: "/" schedule: interval: "weekly" + - package-ecosystem: "github-actions" + # Workflow files stored in the + # default location of `.github/workflows` + directory: "/" + schedule: + interval: "weekly" + target-branch: "humble" + - package-ecosystem: "github-actions" + # Workflow files stored in the + # default location of `.github/workflows` + directory: "/" + schedule: + interval: "weekly" + target-branch: "iron" diff --git a/.github/workflows/ci-format.yaml b/.github/workflows/ci-format.yaml index 0712e70b..4db51ac9 100644 --- a/.github/workflows/ci-format.yaml +++ b/.github/workflows/ci-format.yaml @@ -13,7 +13,7 @@ jobs: runs-on: ubuntu-22.04 steps: - uses: actions/checkout@v4 - - uses: actions/setup-python@v4 + - uses: actions/setup-python@v5 with: python-version: 3.10.6 - name: Install system hooks diff --git a/.github/workflows/ci-iron.yaml b/.github/workflows/ci-iron.yaml new file mode 100644 index 00000000..d8408142 --- /dev/null +++ b/.github/workflows/ci-iron.yaml @@ -0,0 +1,84 @@ +name: gz_ros2_control CI - Iron + +on: + pull_request: + branches: [ iron ] + push: + branches: [ iron ] + +jobs: + build: + runs-on: ubuntu-latest + strategy: + matrix: + include: + - docker-image: "ubuntu:22.04" + gz-version: "fortress" + ros-distro: "iron" + - docker-image: "ubuntu:22.04" + gz-version: "garden" + ros-distro: "iron" + env: + DOCKER_IMAGE: ${{ matrix.docker-image }} + GZ_VERSION: ${{ matrix.gz-version }} + ROS_DISTRO: ${{ matrix.ros-distro }} + container: + image: ${{ matrix.docker-image }} + steps: + - uses: actions/checkout@v4 + - name: Setup colcon workspace + id: configure + shell: bash + run: | + export DEBIAN_FRONTEND=noninteractive + apt update -qq + apt install -qq -y lsb-release wget curl gnupg2 git + cd .. + mkdir -p /home/ros2_ws/src + if [ "$ROS_DISTRO" == "rolling" ]; then + git clone https://github.com/gazebosim/ros_gz/ + fi + cp -r gz_ros2_control /home/ros2_ws/src/ + curl -sSL https://raw.githubusercontent.com/ros/rosdistro/master/ros.key -o /usr/share/keyrings/ros-archive-keyring.gpg + echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/ros-archive-keyring.gpg] http://packages.ros.org/ros2/ubuntu $(. /etc/os-release && echo $UBUNTU_CODENAME) main" | tee /etc/apt/sources.list.d/ros2.list > /dev/null + wget https://packages.osrfoundation.org/gazebo.gpg -O /usr/share/keyrings/pkgs-osrf-archive-keyring.gpg + echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/pkgs-osrf-archive-keyring.gpg] http://packages.osrfoundation.org/gazebo/ubuntu-stable $(lsb_release -cs) main" | tee /etc/apt/sources.list.d/gazebo-stable.list > /dev/null + if [ "$GZ_VERSION" == "garden" ]; then + export GZ_DEPS="libgz-sim7-dev libgz-plugin2-dev gz-sim7-cli" + fi + + apt-get update && apt-get upgrade -q -y + apt-get update && apt-get install -qq -y \ + dirmngr \ + python3-colcon-ros \ + python3-colcon-common-extensions \ + python3-rosdep \ + build-essential \ + ${GZ_DEPS} + + if [ "$GZ_VERSION" == "garden" ]; then + export ROSDEP_ARGS="--skip-keys ros_gz_sim --skip-keys gz-plugin2 --skip-keys gz-sim7 --skip-keys gz-transport12 --skip-keys gz-math7 --skip-keys gz-msgs9" + fi + cd /home/ros2_ws/src/ + if [ "$ROS_DISTRO" == "rolling" ]; then + git clone https://github.com/gazebosim/ros_gz/ + fi + if [ "$ROS_DISTRO" == "iron" ]; then + git clone https://github.com/gazebosim/ros_gz/ -b iron + fi + rosdep init + rosdep update + rosdep install --from-paths ./ -i -y --rosdistro ${ROS_DISTRO} --ignore-src ${ROSDEP_ARGS} + - name: Build project + id: build + run: | + cd /home/ros2_ws/ + . /opt/ros/${ROS_DISTRO}/local_setup.sh + colcon build --packages-up-to gz_ros2_control_demos gz_ros2_control_tests + - name: Run tests + id: test + run: | + cd /home/ros2_ws/ + . /opt/ros/${ROS_DISTRO}/local_setup.sh + colcon test --event-handlers console_direct+ --packages-select gz_ros2_control gz_ros2_control_demos gz_ros2_control_tests + colcon test-result diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci-rolling.yaml similarity index 93% rename from .github/workflows/ci.yaml rename to .github/workflows/ci-rolling.yaml index 88414e67..47d4b053 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci-rolling.yaml @@ -1,7 +1,8 @@ -name: Gazebo-Sim ros2 control CI +name: gz_ros2_control CI - Rolling on: pull_request: + branches: [ master ] push: branches: [ master ] @@ -11,15 +12,9 @@ jobs: strategy: matrix: include: - - docker-image: "ubuntu:22.04" - gz-version: "fortress" - ros-distro: "iron" - docker-image: "ubuntu:22.04" gz-version: "fortress" ros-distro: "rolling" - - docker-image: "ubuntu:22.04" - gz-version: "garden" - ros-distro: "iron" - docker-image: "ubuntu:22.04" gz-version: "garden" ros-distro: "rolling" diff --git a/README.md b/README.md index c9a35a5b..ab5d48c6 100644 --- a/README.md +++ b/README.md @@ -15,18 +15,23 @@ Foxy | Citadel | [foxy](https://github.com/ros-controls/gz_ros2_control/tree/fox Foxy | Edifice | [foxy](https://github.com/ros-controls/gz_ros2_control/tree/foxy) | only from source Galactic | Edifice | [galactic](https://github.com/ros-controls/gz_ros2_control/tree/galactic) | https://packages.ros.org Galactic | Fortress | [galactic](https://github.com/ros-controls/gz_ros2_control/tree/galactic) | only from source -Humble | Fortress | [ros2](https://github.com/ros-controls/gz_ros2_control/tree/master) | https://packages.ros.org -Rolling | Edifice | [ros2](https://github.com/ros-controls/gz_ros2_control/tree/master) | only from source -Rolling | Fortress | [ros2](https://github.com/ros-controls/gz_ros2_control/tree/master) | https://packages.ros.org -Rolling | Garden (not released) | [ros2](https://github.com/ros-controls/gz_ros2_control/tree/master) | only from source +Humble | Fortress | [humble](https://github.com/ros-controls/gz_ros2_control/tree/humble) | https://packages.ros.org +Iron | Edifice | [iron](https://github.com/ros-controls/gz_ros2_control/tree/iron) | only from source +Iron | Fortress | [iron](https://github.com/ros-controls/gz_ros2_control/tree/iron) | https://packages.ros.org +Iron | Garden (not released) | [iron](https://github.com/ros-controls/gz_ros2_control/tree/iron) | only from source +Iron | Harmonic (not released) | [iron](https://github.com/ros-controls/gz_ros2_control/tree/iron) | only from source +Rolling | Edifice | [master](https://github.com/ros-controls/gz_ros2_control/tree/master) | only from source +Rolling | Fortress | [master](https://github.com/ros-controls/gz_ros2_control/tree/master) | https://packages.ros.org +Rolling | Garden (not released) | [master](https://github.com/ros-controls/gz_ros2_control/tree/master) | only from source +Rolling | Harmonic (not released) | [master](https://github.com/ros-controls/gz_ros2_control/tree/master) | only from source ## Build status ROS 2 Distro | Branch | Build status | Documentation :----------: | :----: | :----------: | :-----------: -**Rolling** | [`master`](https://github.com/ros-controls/gz_ros2_control/tree/master) | [![Gazebo ros2 control CI](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci.yaml/badge.svg?branch=master)](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci.yaml) | [Documentation](https://control.ros.org/master/index.html)
[API Reference](https://control.ros.org/master/doc/api/index.html) -**Iron** | [`master`](https://github.com/ros-controls/gz_ros2_control/tree/master) | [![Gazebo ros2 control CI](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci.yaml/badge.svg?branch=master)](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci.yaml) | [Documentation](https://control.ros.org/master/index.html)
[API Reference](https://control.ros.org/master/doc/api/index.html) -**Humble** | [`humble`](https://github.com/ros-controls/gz_ros2_control/tree/humble) | [![Gazebo ros2 control CI](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci.yaml/badge.svg?branch=humble)](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci.yaml) | [Documentation](https://control.ros.org/humble/index.html)
[API Reference](https://control.ros.org/humble/doc/api/index.html) +**Rolling** | [`master`](https://github.com/ros-controls/gz_ros2_control/tree/master) | [![gazebo_ros2_control CI - Rolling](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci-rolling.yaml/badge.svg?branch=master)](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci-rolling.yaml) | [Documentation](https://control.ros.org/master/index.html)
[API Reference](https://control.ros.org/master/doc/api/index.html) +**Iron** | [`iron`](https://github.com/ros-controls/gz_ros2_control/tree/iron) | [![gazebo_ros2_control CI - Iron](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci-iron.yaml/badge.svg?branch=iron)](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci-iron.yaml) | [Documentation](https://control.ros.org/iron/index.html)
[API Reference](https://control.ros.org/iron/doc/api/index.html) +**Humble** | [`humble`](https://github.com/ros-controls/gz_ros2_control/tree/humble) | [![ign_ros2_control CI - Humble](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci-humble.yaml/badge.svg?branch=humble)](https://github.com/ros-controls/gz_ros2_control/actions/workflows/ci-humble.yaml) | [Documentation](https://control.ros.org/humble/index.html)
[API Reference](https://control.ros.org/humble/doc/api/index.html) ## Documentation See the [documentation file](doc/index.rst) or [control.ros.org](https://control.ros.org/master/doc/simulators/gz_ros2_control/doc/index.html) @@ -37,6 +42,7 @@ If you want compile this from source, you should choose the Gazebo version. The ```bash export GZ_VERSION=fortress export GZ_VERSION=garden +export GZ_VERSION=harmonic ``` Then create a workspace, clone the repo and compile it: diff --git a/gz_ros2_control/CMakeLists.txt b/gz_ros2_control/CMakeLists.txt index 8ec5f5a5..c28ae795 100644 --- a/gz_ros2_control/CMakeLists.txt +++ b/gz_ros2_control/CMakeLists.txt @@ -36,6 +36,15 @@ if("$ENV{GZ_VERSION}" STREQUAL "garden") set(GZ_PLUGIN gz-plugin${GZ_PLUGIN_VER}::register) set(GZ_SIM gz-sim${GZ_SIM_VER}::core) add_definitions(-DGZ_HEADERS) +elseif("$ENV{GZ_VERSION}" STREQUAL "harmonic") + find_package(gz-sim8 REQUIRED) + set(GZ_SIM_VER ${gz-sim8_VERSION_MAJOR}) + message(STATUS "Compiling against Gazebo Harmonic") + find_package(gz-plugin2 REQUIRED) + set(GZ_PLUGIN_VER ${gz-plugin2_VERSION_MAJOR}) + set(GZ_PLUGIN gz-plugin${GZ_PLUGIN_VER}::register) + set(GZ_SIM gz-sim${GZ_SIM_VER}::core) + add_definitions(-DGZ_HEADERS) else() find_package(ignition-gazebo6 REQUIRED) set(GZ_SIM_VER ${ignition-gazebo6_VERSION_MAJOR}) diff --git a/gz_ros2_control/package.xml b/gz_ros2_control/package.xml index 6a97719a..6344c7bb 100644 --- a/gz_ros2_control/package.xml +++ b/gz_ros2_control/package.xml @@ -15,10 +15,12 @@ ignition-gazebo6 ignition-gazebo6 gz-sim7 + gz-sim8 ignition-plugin ignition-plugin gz-plugin2 + gz-plugin2 pluginlib rclcpp yaml_cpp_vendor diff --git a/gz_ros2_control_demos/package.xml b/gz_ros2_control_demos/package.xml index 45565b05..51ef09fb 100644 --- a/gz_ros2_control_demos/package.xml +++ b/gz_ros2_control_demos/package.xml @@ -37,6 +37,7 @@ rclcpp robot_state_publisher ros_gz_sim + ros_gz_sim ros_gz_sim ros_ign_gazebo ros2controlcli diff --git a/gz_ros2_control_tests/package.xml b/gz_ros2_control_tests/package.xml index 67add5ff..870ceef6 100644 --- a/gz_ros2_control_tests/package.xml +++ b/gz_ros2_control_tests/package.xml @@ -29,6 +29,7 @@ rclcpp robot_state_publisher ros_gz_sim + ros_gz_sim ros_gz_sim ros_ign_gazebo ros2controlcli