Skip to content

Commit

Permalink
Enable TSAN builds on CI for Functional Tests.
Browse files Browse the repository at this point in the history
This enables TSAN checking when running the functional tests in CI.

This is currently only enabled on Linux since the various races there
were fixed when #7478 landed.

When Darwin races are fixed, tsan can be enabled for those too.
  • Loading branch information
mrjerryjohns committed Jun 22, 2021
1 parent 82e6290 commit 23258ee
Showing 1 changed file with 18 additions and 3 deletions.
21 changes: 18 additions & 3 deletions .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,10 @@ jobs:
name: Test Suites - Linux
timeout-minutes: 60

strategy:
matrix:
type: [no_tsan, with_tsan]

if: github.actor != 'restyled-io[bot]'
runs-on: ubuntu-latest

Expand Down Expand Up @@ -61,11 +65,23 @@ jobs:
- name: Build all clusters app
timeout-minutes: 5
run: |
scripts/examples/gn_build_example.sh examples/all-clusters-app/linux out/debug/standalone/ chip_config_network_layer_ble=false
case ${{ matrix.type }} in
"no_tsan") GN_ARGS='is_tsan=false';;
"with_tsan") GN_ARGS='is_tsan=true';;
*) ;;
esac
scripts/examples/gn_build_example.sh examples/all-clusters-app/linux out/debug/standalone/ chip_config_network_layer_ble=false "$GN_ARGS"
- name: Build chip-tool
timeout-minutes: 5
run: |
scripts/examples/gn_build_example.sh examples/chip-tool out/debug/standalone/
case ${{ matrix.type }} in
"no_tsan") GN_ARGS='is_tsan=false';;
"with_tsan") GN_ARGS='is_tsan=true';;
*) ;;
esac
scripts/examples/gn_build_example.sh examples/chip-tool out/debug/standalone/ "$GN_ARGS"
- name: Copy objdir
run: |
# The idea is to not upload our objdir unless builds have
Expand Down Expand Up @@ -95,7 +111,6 @@ jobs:
test_suites_darwin:
name: Test Suites - Darwin
timeout-minutes: 60

if: github.actor != 'restyled-io[bot]'
runs-on: macos-latest

Expand Down

0 comments on commit 23258ee

Please sign in to comment.