From 1af038d3eaae43874d446fa4ff4df9d225e44728 Mon Sep 17 00:00:00 2001 From: Saikrishna Bairamoni <84093461+SaikrishnaBairamoni@users.noreply.github.com> Date: Fri, 1 Mar 2024 13:06:14 -0500 Subject: [PATCH] Add ros2 build step --- .github/workflows/Ci.yml | 34 +++++++++++++++++++++++++++++++--- docker/checkout.bash | 2 +- 2 files changed, 32 insertions(+), 4 deletions(-) diff --git a/.github/workflows/Ci.yml b/.github/workflows/Ci.yml index 1aba398eb19..bfa246748a8 100644 --- a/.github/workflows/Ci.yml +++ b/.github/workflows/Ci.yml @@ -5,6 +5,7 @@ on: types: [opened, synchronize, reopened] push: branches: [develop, master, feature/add_gha] + workflow_dispatch: jobs: build: @@ -32,7 +33,7 @@ jobs: - name: Checkout Dependencies run: | ./src/${{ github.event.repository.name }}/docker/checkout.bash -r /opt/carma - - name: Build + - name: Build ROS1 run: | source "$INIT_ENV" cd /opt/carma/src/${{ github.event.repository.name }} @@ -41,14 +42,41 @@ jobs: PACKAGES=$(find . -maxdepth 2 -type f -name package.xml | sed 's/\.\///' | cut -d/ -f1) sed -i '/colcon build/ s/$/ --packages-up-to $PACKAGES/' /home/carma/.ci-image/engineering_tools/code_coverage/make_with_coverage.bash make_with_coverage.bash -m -e /opt/carma/ -o ./coverage_reports/gcov - - name: Run C++ Tests + - name: Run ROS1 C++ Tests + continue-on-error: true run: | source "$INIT_ENV" cd /opt/carma/src/${{ github.event.repository.name }} export ROS_PARALLEL_JOBS='-j4 -l4' sed -i '/colcon test/ s/$/ --packages-above $PACKAGES/' /home/carma/.ci-image/engineering_tools/code_coverage/make_with_coverage.bash make_with_coverage.bash -t -e /opt/carma/ -o ./coverage_reports/gcov - + - name: Build ROS2 + continue-on-error: true + run: | + source "$INIT_ENV" + source "$ROS_2_ENV" + cd /opt/carma/src/${{ github.event.repository.name }} + export ROS_PARALLEL_JOBS='-j4 -l4' + export AUTOWARE_COMPILE_WITH_CUDA=1 + PACKAGES=$(find . -maxdepth 2 -type f -name package.xml | sed 's/\.\///' | cut -d/ -f1) + sed -i '/colcon build/ s/$/ --packages-up-to $PACKAGES/' /home/carma/.ci-image/engineering_tools/code_coverage/make_with_coverage.bash + make_with_coverage.bash -m -e /opt/carma/ -o ./coverage_reports/gcov + - name: Run ROS2 C++ Tests + continue-on-error: true + run: | + source "$INIT_ENV" + source "$ROS_2_ENV" + cd /opt/carma/src/${{ github.event.repository.name }} + export ROS_PARALLEL_JOBS='-j4 -l4' + sed -i '/colcon test/ s/$/ --packages-above $PACKAGES/' /home/carma/.ci-image/engineering_tools/code_coverage/make_with_coverage.bash + make_with_coverage.bash -t -e /opt/carma/ -o ./coverage_reports/gcov + + - name: Combine ROS1 and ROS2 compile_commands.json files + # Combine the ROS1 and ROS2 compile_commands.json files for sonarscan + run: | + mv /opt/carma/build/compile_commands.json /opt/carma/compile_commands.ros2.json + jq -s add /opt/carma/compile_commands.ros1.json /opt/carma/compile_commands.ros2.json > /opt/carma/build/compile_commands.json + - name: Upload Coverage Reports uses: actions/upload-artifact@v2 with: diff --git a/docker/checkout.bash b/docker/checkout.bash index 2a6e888f229..a77773eadf1 100755 --- a/docker/checkout.bash +++ b/docker/checkout.bash @@ -32,7 +32,7 @@ while [[ $# -gt 0 ]]; do esac done -cd ${dir}/src +cd ${dir}/src/autoware.ai if [[ "$BRANCH" = "develop" ]]; then git clone --depth=1 https://github.com/usdot-fhwa-stol/carma-msgs.git --branch $BRANCH