-
Notifications
You must be signed in to change notification settings - Fork 13.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Updates some actions to run build steps in container instead of the whole workflow.
- Loading branch information
Showing
10 changed files
with
135 additions
and
307 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -11,13 +11,17 @@ on: | |
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
container: px4io/px4-dev-clang:2021-09-08 | ||
steps: | ||
- uses: actions/checkout@v1 | ||
- uses: actions/checkout@v4 | ||
with: | ||
token: ${{secrets.ACCESS_TOKEN}} | ||
fetch-depth: 0 | ||
|
||
- uses: corrupt952/[email protected] | ||
- name: Testing (clang-tidy-quiet) | ||
uses: addnab/docker-run-action@v3 | ||
with: | ||
command: make clang-tidy-quiet | ||
max_attempts: 3 | ||
image: px4io/px4-dev-clang:2021-09-08 | ||
options: -v ${{ github.workspace }}:/workspace | ||
run: | | ||
cd /workspace | ||
git config --global --add safe.directory /workspace | ||
make clang-tidy-quiet |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,21 +1,28 @@ | ||
name: EKF Change Indicator | ||
|
||
on: pull_request | ||
on: | ||
pull_request: | ||
branches: | ||
- '*' | ||
|
||
jobs: | ||
unit_tests: | ||
runs-on: ubuntu-latest | ||
container: px4io/px4-dev-base-focal:2021-09-08 | ||
steps: | ||
- uses: actions/checkout@v2.3.1 | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
- name: checkout newest version of branch | ||
run: | | ||
git fetch origin pull/${{github.event.pull_request.number}}/head:${{github.head_ref}} | ||
git checkout ${GITHUB_HEAD_REF} | ||
|
||
- name: main test | ||
run: make tests TESTFILTER=EKF | ||
uses: addnab/docker-run-action@v3 | ||
with: | ||
image: px4io/px4-dev-base-focal:2021-09-08 | ||
options: -v ${{ github.workspace }}:/workspace | ||
run: | | ||
cd /workspace | ||
git config --global --add safe.directory /workspace | ||
make tests TESTFILTER=EKF | ||
- name: Check if there is a functional change | ||
run: git diff --exit-code | ||
working-directory: src/modules/ekf2/test/change_indication |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,25 +5,40 @@ on: push | |
jobs: | ||
unit_tests: | ||
runs-on: ubuntu-latest | ||
container: px4io/px4-dev-base-focal:2021-09-08 | ||
env: | ||
GIT_COMMITTER_EMAIL: [email protected] | ||
GIT_COMMITTER_NAME: PX4BuildBot | ||
steps: | ||
- uses: actions/checkout@v2.3.1 | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
- name: main test updates change indication files | ||
run: make tests TESTFILTER=EKF | ||
|
||
- name: main test | ||
uses: addnab/docker-run-action@v3 | ||
with: | ||
image: px4io/px4-dev-base-focal:2021-09-08 | ||
options: -v ${{ github.workspace }}:/workspace | ||
run: | | ||
cd /workspace | ||
git config --global --add safe.directory /workspace | ||
make tests TESTFILTER=EKF | ||
- name: Check if there exists diff and save result in variable | ||
run: echo "CHANGE_INDICATED=$(git diff --exit-code --output=/dev/null || echo $?)" >> $GITHUB_ENV | ||
id: diff-check | ||
run: echo "CHANGE_INDICATED=$(git diff --exit-code --output=/dev/null || echo $?)" >> $GITHUB_OUTPUT | ||
working-directory: src/modules/ekf2/test/change_indication | ||
|
||
- name: auto-commit any changes to change indication | ||
uses: stefanzweifel/git-auto-commit-action@v4 | ||
with: | ||
commit_message: '[AUTO COMMIT] update change indication' | ||
file_pattern: 'src/modules/ekf2/test/change_indication/*.csv' | ||
commit_user_name: ${GIT_COMMITTER_NAME} | ||
commit_user_email: ${GIT_COMMITTER_EMAIL} | ||
- if: ${{env.CHANGE_INDICATED}} | ||
name: if there is a functional change, fail check | ||
commit_message: | | ||
'[AUTO COMMIT] update change indication' | ||
See .github/workflopws/ekf_update_change_indicator.yml for more details | ||
- name: if there is a functional change, fail check | ||
if: ${{ steps.diff-check.outputs.CHANGE_INDICATED }} | ||
run: exit 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -11,131 +11,26 @@ on: | |
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
env: | ||
ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION: true | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
config: | ||
- {vehicle: "iris", mission: "MC_mission_box", build_type: "RelWithDebInfo"} | ||
- {vehicle: "rover", mission: "rover_mission_1", build_type: "RelWithDebInfo"} | ||
#- {vehicle: "plane", mission: "FW_mission_1", build_type: "RelWithDebInfo"} | ||
#- {vehicle: "plane_catapult",mission: "FW_mission_1", build_type: "RelWithDebInfo"} | ||
#- {vehicle: "standard_vtol", mission: "VTOL_mission_1", build_type: "Coverage"} | ||
#- {vehicle: "standard_vtol", mission: "VTOL_mission_1", build_type: "AddressSanitizer"} | ||
#- {vehicle: "tailsitter", mission: "VTOL_mission_1", build_type: "RelWithDebInfo"} | ||
#- {vehicle: "tiltrotor", mission: "VTOL_mission_1", build_type: "RelWithDebInfo"} | ||
- {vehicle: "iris", mission: "MC_mission_box"} | ||
- {vehicle: "rover", mission: "rover_mission_1"} | ||
|
||
container: | ||
image: px4io/px4-dev-ros-melodic:2021-09-08 | ||
options: --privileged --ulimit core=-1 --security-opt seccomp=unconfined | ||
steps: | ||
- uses: actions/checkout@v1 | ||
- uses: actions/checkout@v4 | ||
with: | ||
token: ${{ secrets.ACCESS_TOKEN }} | ||
fetch-depth: 0 | ||
|
||
- name: Prepare ccache timestamp | ||
id: ccache_cache_timestamp | ||
shell: cmake -P {0} | ||
run: | | ||
string(TIMESTAMP current_date "%Y-%m-%d-%H;%M;%S" UTC) | ||
message("::set-output name=timestamp::${current_date}") | ||
- name: ccache cache files | ||
uses: actions/cache@v2 | ||
- name: Build SITL and Run Tests | ||
uses: addnab/docker-run-action@v3 | ||
with: | ||
path: ~/.ccache | ||
key: sitl_tests-${{matrix.config.build_type}}-ccache-${{steps.ccache_cache_timestamp.outputs.timestamp}} | ||
restore-keys: sitl_tests-${{matrix.config.build_type}}-ccache- | ||
- name: setup ccache | ||
run: | | ||
mkdir -p ~/.ccache | ||
echo "base_dir = ${GITHUB_WORKSPACE}" > ~/.ccache/ccache.conf | ||
echo "compression = true" >> ~/.ccache/ccache.conf | ||
echo "compression_level = 6" >> ~/.ccache/ccache.conf | ||
echo "max_size = 100M" >> ~/.ccache/ccache.conf | ||
echo "hash_dir = false" >> ~/.ccache/ccache.conf | ||
ccache -s | ||
ccache -z | ||
- name: check environment | ||
run: | | ||
export | ||
ulimit -a | ||
- name: Build PX4 and sitl_gazebo-classic | ||
env: | ||
PX4_CMAKE_BUILD_TYPE: ${{matrix.config.build_type}} | ||
run: | | ||
ccache -z | ||
make px4_sitl_default | ||
make px4_sitl_default sitl_gazebo-classic | ||
ccache -s | ||
- name: Core dump settings | ||
run: | | ||
ulimit -c unlimited | ||
echo "`pwd`/%e.core" > /proc/sys/kernel/core_pattern | ||
- name: Run SITL tests | ||
env: | ||
PX4_CMAKE_BUILD_TYPE: ${{matrix.config.build_type}} | ||
run: | | ||
export | ||
./test/rostest_px4_run.sh mavros_posix_test_mission.test mission:=${{matrix.config.mission}} vehicle:=${{matrix.config.vehicle}} | ||
timeout-minutes: 45 | ||
|
||
- name: Look at core files | ||
if: failure() | ||
run: gdb build/px4_sitl_default/bin/px4 px4.core -ex "thread apply all bt" -ex "quit" | ||
- name: Upload px4 coredump | ||
if: failure() | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: coredump | ||
path: px4.core | ||
|
||
- name: ecl EKF analysis | ||
if: always() | ||
run: ./Tools/ecl_ekf/process_logdata_ekf.py ~/.ros/log/*/*.ulg || true | ||
|
||
- name: Upload logs to flight review | ||
if: always() | ||
run: ./Tools/upload_log.py -q --description "${GITHUB_WORKFLOW} ${GITHUB_RUN_ID}" --feedback "${GITHUB_WORKFLOW} ${GITHUB_RUN_ID} ${GITHUB_REPOSITORY} ${GITHUB_REF}" --source CI ~/.ros/log/*/*.ulg | ||
|
||
- name: Upload px4 binary | ||
if: failure() | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: binary | ||
path: build/px4_sitl_default/bin/px4 | ||
|
||
- name: Store PX4 log | ||
if: failure() | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: px4_log | ||
path: ~/.ros/log/*/*.ulg | ||
|
||
- name: Store ROS log | ||
if: failure() | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: ros_log | ||
path: ~/.ros/**/rostest-*.log | ||
|
||
# Report test coverage | ||
- name: Upload coverage | ||
if: contains(matrix.config.build_type, 'Coverage') | ||
run: | | ||
git config --global credential.helper "" # disable the keychain credential helper | ||
git config --global --add credential.helper store # enable the local store credential helper | ||
echo "https://x-access-token:${{ secrets.ACCESS_TOKEN }}@github.com" >> ~/.git-credentials # add credential | ||
git config --global url."https://github.com/".insteadof [email protected]: # credentials add credential | ||
mkdir -p coverage | ||
lcov --directory build/px4_sitl_default --base-directory build/px4_sitl_default --gcov-tool gcov --capture -o coverage/lcov.info | ||
- name: Upload coverage information to Codecov | ||
if: contains(matrix.config.build_type, 'Coverage') | ||
uses: codecov/codecov-action@v1 | ||
with: | ||
token: ${{ secrets.CODECOV_TOKEN }} | ||
flags: mavros_mission | ||
file: coverage/lcov.info | ||
image: px4io/px4-dev-ros-melodic:2021-09-08 | ||
options: -v ${{ github.workspace }}:/workspace | ||
run: | | ||
cd /workspace | ||
git config --global --add safe.directory /workspace | ||
make px4_sitl_default | ||
make px4_sitl_default sitl_gazebo-classic | ||
./test/rostest_px4_run.sh mavros_posix_test_mission.test mission:=${{matrix.config.mission}} vehicle:=${{matrix.config.vehicle}} |
Oops, something went wrong.