mirror of
https://github.com/espressif/openthread.git
synced 2026-06-06 05:24:51 +00:00
e336e7a86c
This commit simplifies the Simulation 1.4 workflow by removing the compiler and architecture matrix. Run-time issues due to compiler differences or architecture have not been an issue, so testing a single configuration is sufficient to reduce CI resource usage. The workflow now uses the default environment instead of explicitly testing both gcc/clang and m32/m64 architectures.
247 lines
8.6 KiB
YAML
247 lines
8.6 KiB
YAML
#
|
|
# Copyright (c) 2020, 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: Simulation 1.4
|
|
|
|
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:
|
|
|
|
thread-1-4:
|
|
name: thread-1-4
|
|
runs-on: ubuntu-22.04
|
|
env:
|
|
COVERAGE: 1
|
|
THREAD_VERSION: 1.4
|
|
VIRTUAL_TIME: 1
|
|
TEST_TIMEOUT: 300
|
|
OT_VT_USE_UNIX_SOCKET: 1
|
|
INTER_OP: 1
|
|
INTER_OP_BBR: 1
|
|
strategy:
|
|
fail-fast: false
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
|
with:
|
|
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
|
|
|
|
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
|
|
with:
|
|
submodules: recursive
|
|
- uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
|
|
with:
|
|
python-version: '3.12'
|
|
cache: pip
|
|
- name: Bootstrap
|
|
run: |
|
|
sudo dpkg --add-architecture i386
|
|
sudo apt-get update
|
|
sudo apt-get --no-install-recommends install -y ninja-build llvm lcov
|
|
sudo apt-get --no-install-recommends install -y g++-multilib libreadline-dev:i386 libncurses-dev:i386
|
|
python3 -m pip install -r tests/scripts/thread-cert/requirements.txt
|
|
- name: Build
|
|
run: |
|
|
./script/test build
|
|
- name: Run
|
|
run: |
|
|
ulimit -c unlimited
|
|
./script/test prepare_coredump_upload
|
|
./script/test unit
|
|
./script/test cert_suite tests/scripts/thread-cert/v1_2_*
|
|
- name: Check Crash
|
|
if: ${{ failure() }}
|
|
run: |
|
|
CRASHED=$(./script/test check_crash | tail -1)
|
|
[[ $CRASHED -eq "1" ]] && echo "Crashed!" || echo "Not crashed."
|
|
echo "CRASHED=$CRASHED" >> $GITHUB_ENV
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
if: ${{ failure() }}
|
|
with:
|
|
name: thread-1-4-pcaps
|
|
path: "*.pcap"
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
if: ${{ failure() && env.CRASHED == '1' }}
|
|
with:
|
|
name: core-packet-verification-thread-1-4
|
|
path: |
|
|
./ot-core-dump/*
|
|
- name: Generate Coverage
|
|
run: |
|
|
./script/test generate_coverage gcc
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: cov-thread-1-4
|
|
path: tmp/coverage.info
|
|
retention-days: 1
|
|
|
|
channel-manager-csl:
|
|
runs-on: ubuntu-24.04
|
|
env:
|
|
CFLAGS: -m32
|
|
CXXFLAGS: -m32
|
|
LDFLAGS: -m32
|
|
COVERAGE: 1
|
|
THREAD_VERSION: 1.4
|
|
VIRTUAL_TIME: 1
|
|
OT_VT_USE_UNIX_SOCKET: 1
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
|
with:
|
|
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
|
|
|
|
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
|
|
with:
|
|
submodules: recursive
|
|
- uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
|
|
with:
|
|
python-version: '3.12'
|
|
cache: pip
|
|
- name: Bootstrap
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get --no-install-recommends install -y g++-multilib lcov ninja-build
|
|
python3 -m pip install -r tests/scripts/thread-cert/requirements.txt
|
|
- name: Build
|
|
run: |
|
|
OT_OPTIONS="-DOT_CHANNEL_MANAGER_CSL=ON" ./script/test build
|
|
- name: Run
|
|
run: |
|
|
ulimit -c unlimited
|
|
./script/test cert_suite ./tests/scripts/thread-cert/addon_test_channel_manager_autocsl*.py
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
if: ${{ failure() }}
|
|
with:
|
|
name: channel-manager-csl
|
|
path: ot_testing
|
|
- name: Generate Coverage
|
|
run: |
|
|
./script/test generate_coverage gcc
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: cov-channel-manager-csl
|
|
path: tmp/coverage.info
|
|
retention-days: 1
|
|
|
|
expects:
|
|
runs-on: ubuntu-24.04
|
|
env:
|
|
COVERAGE: 1
|
|
THREAD_VERSION: 1.4
|
|
VIRTUAL_TIME: 0
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
|
with:
|
|
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
|
|
|
|
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
|
|
with:
|
|
submodules: recursive
|
|
- uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
|
|
with:
|
|
python-version: '3.12'
|
|
cache: pip
|
|
- name: Bootstrap
|
|
run: |
|
|
sudo apt-get --no-install-recommends install -y expect ninja-build lcov
|
|
sudo bash script/install_socat
|
|
pip install bleak 'cryptography==43.0.0'
|
|
- name: Run RCP Mode
|
|
run: |
|
|
ulimit -c unlimited
|
|
./script/test prepare_coredump_upload
|
|
OT_OPTIONS=-DOT_READLINE=OFF OT_NODE_TYPE=rcp ./script/test build expect
|
|
- name: Check Crash
|
|
if: ${{ failure() }}
|
|
run: |
|
|
CRASHED=$(./script/test check_crash | tail -1)
|
|
[[ $CRASHED -eq "1" ]] && echo "Crashed!" || echo "Not crashed."
|
|
echo "CRASHED=$CRASHED" >> $GITHUB_ENV
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
if: ${{ failure() && env.CRASHED == '1' }}
|
|
with:
|
|
name: core-expect-1-4
|
|
path: |
|
|
./ot-core-dump/*
|
|
- name: Generate Coverage
|
|
run: |
|
|
./script/test generate_coverage gcc
|
|
- uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: cov-expects
|
|
path: tmp/coverage.info
|
|
retention-days: 1
|
|
|
|
upload-coverage:
|
|
needs:
|
|
- thread-1-4
|
|
- expects
|
|
runs-on: ubuntu-22.04
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@5ef0c079ce82195b2a36a210272d6b661572d83e # v2.14.2
|
|
with:
|
|
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
|
|
|
|
- uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
|
|
with:
|
|
submodules: recursive
|
|
- name: Bootstrap
|
|
run: |
|
|
sudo apt-get --no-install-recommends install -y lcov
|
|
- uses: actions/download-artifact@634f93cb2916e3fdff6788551b99b062d0335ce0 # v5.0.0
|
|
with:
|
|
path: coverage/
|
|
pattern: cov-*
|
|
merge-multiple: true
|
|
- name: Combine Coverage
|
|
run: |
|
|
script/test combine_coverage
|
|
- name: Upload Coverage
|
|
uses: codecov/codecov-action@671740ac38dd9b0130fbe1cec585b89eea48d3de # v5.5.2
|
|
env:
|
|
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
|
|
with:
|
|
files: final.info
|
|
fail_ci_if_error: true
|