| # |
| # Copyright (c) 2023, The OpenThread Authors. |
| # All rights reserved. |
| # |
| # Redistribution and use in source and binary forms, with or without |
| # modification, are permitted provided that the following conditions are met: |
| # 1. Redistributions of source code must retain the above copyright |
| # notice, this list of conditions and the following disclaimer. |
| # 2. Redistributions in binary form must reproduce the above copyright |
| # notice, this list of conditions and the following disclaimer in the |
| # documentation and/or other materials provided with the distribution. |
| # 3. Neither the name of the copyright holder nor the |
| # names of its contributors may be used to endorse or promote products |
| # derived from this software without specific prior written permission. |
| # |
| # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
| # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| # POSSIBILITY OF SUCH DAMAGE. |
| # |
| |
| name: Unit |
| |
| on: |
| push: |
| branches-ignore: |
| - 'dependabot/**' |
| pull_request: |
| branches: |
| - 'main' |
| |
| concurrency: |
| group: ${{ github.workflow }}-${{ github.event.pull_request.number || (github.repository == 'openthread/openthread' && github.run_id) || github.ref }} |
| cancel-in-progress: true |
| |
| permissions: # added using https://github.com/step-security/secure-workflows |
| contents: read |
| |
| jobs: |
| |
| tcplp-buffering: |
| runs-on: ubuntu-20.04 |
| steps: |
| - name: Harden Runner |
| uses: step-security/harden-runner@63c24ba6bd7ba022e95695ff85de572c04a18142 # v2.7.0 |
| with: |
| egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs |
| |
| - uses: actions/checkout@9bb56186c3b09b4f86b1c65136769dd318469633 # v4.1.2 |
| with: |
| submodules: true |
| - name: Build |
| run: make -C third_party/tcplp/lib/test/ |
| - name: Run |
| run: third_party/tcplp/lib/test/test_all |
| |
| unit-tests: |
| runs-on: ubuntu-20.04 |
| env: |
| COVERAGE: 1 |
| steps: |
| - name: Harden Runner |
| uses: step-security/harden-runner@63c24ba6bd7ba022e95695ff85de572c04a18142 # v2.7.0 |
| with: |
| egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs |
| |
| - uses: actions/checkout@9bb56186c3b09b4f86b1c65136769dd318469633 # v4.1.2 |
| with: |
| submodules: true |
| - name: Bootstrap |
| run: | |
| sudo rm /etc/apt/sources.list.d/* && sudo apt-get update |
| sudo apt-get --no-install-recommends install -y ninja-build lcov |
| - name: Build Simulation |
| run: ./script/cmake-build simulation |
| - name: Test Simulation |
| run: cd build/simulation && ninja test |
| - name: Build Multipan Simulation |
| run: ./script/cmake-build simulation -DOT_MULTIPAN_TEST=ON |
| - name: Test Multipan Simulation |
| run: cd build/simulation && ninja test |
| - name: Build POSIX |
| run: ./script/cmake-build posix |
| - name: Test POSIX |
| run: cd build/posix && ninja test |
| - name: Generate Coverage |
| run: | |
| ./script/test generate_coverage gcc |
| - uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1 |
| with: |
| name: cov-unit-tests |
| path: tmp/coverage.info |
| retention-days: 1 |
| |
| upload-coverage: |
| needs: unit-tests |
| runs-on: ubuntu-20.04 |
| steps: |
| - name: Harden Runner |
| uses: step-security/harden-runner@63c24ba6bd7ba022e95695ff85de572c04a18142 # v2.7.0 |
| with: |
| egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs |
| |
| - uses: actions/checkout@9bb56186c3b09b4f86b1c65136769dd318469633 # v4.1.2 |
| with: |
| submodules: true |
| - name: Bootstrap |
| run: | |
| sudo apt-get --no-install-recommends install -y lcov |
| - uses: actions/download-artifact@c850b930e6ba138125429b7e5c93fc707a7f8427 # v4.1.4 |
| with: |
| path: coverage/ |
| pattern: cov-* |
| merge-multiple: true |
| - name: Combine Coverage |
| run: | |
| script/test combine_coverage |
| - name: Upload Coverage |
| uses: codecov/codecov-action@0cfda1dd0a4ad9efc75517f399d859cd1ea4ced1 # v4.0.2 |
| env: |
| CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} |
| with: |
| files: final.info |
| fail_ci_if_error: true |