1
0
mirror of https://github.com/esphome/esphome.git synced 2025-01-19 12:24:05 +00:00

Disable all other CI flows

This commit is contained in:
Jesse Hills 2024-06-26 13:20:56 +12:00
parent e0485894ca
commit 6d8afce3cd
No known key found for this signature in database
GPG Key ID: BEAAE804EFD8E83A

View File

@ -59,298 +59,298 @@ jobs:
pip install -r requirements.txt -r requirements_optional.txt -r requirements_test.txt pip install -r requirements.txt -r requirements_optional.txt -r requirements_test.txt
pip install -e . pip install -e .
black: # black:
name: Check black # name: Check black
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Run black # - name: Run black
run: | # run: |
. venv/bin/activate # . venv/bin/activate
black --verbose esphome tests # black --verbose esphome tests
- name: Suggested changes # - name: Suggested changes
run: script/ci-suggest-changes # run: script/ci-suggest-changes
if: always() # if: always()
flake8: # flake8:
name: Check flake8 # name: Check flake8
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Run flake8 # - name: Run flake8
run: | # run: |
. venv/bin/activate # . venv/bin/activate
flake8 esphome # flake8 esphome
- name: Suggested changes # - name: Suggested changes
run: script/ci-suggest-changes # run: script/ci-suggest-changes
if: always() # if: always()
pylint: # pylint:
name: Check pylint # name: Check pylint
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Run pylint # - name: Run pylint
run: | # run: |
. venv/bin/activate # . venv/bin/activate
pylint -f parseable --persistent=n esphome # pylint -f parseable --persistent=n esphome
- name: Suggested changes # - name: Suggested changes
run: script/ci-suggest-changes # run: script/ci-suggest-changes
if: always() # if: always()
pyupgrade: # pyupgrade:
name: Check pyupgrade # name: Check pyupgrade
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Run pyupgrade # - name: Run pyupgrade
run: | # run: |
. venv/bin/activate # . venv/bin/activate
pyupgrade ${{ env.PYUPGRADE_TARGET }} `find esphome -name "*.py" -type f` # pyupgrade ${{ env.PYUPGRADE_TARGET }} `find esphome -name "*.py" -type f`
- name: Suggested changes # - name: Suggested changes
run: script/ci-suggest-changes # run: script/ci-suggest-changes
if: always() # if: always()
ci-custom: # ci-custom:
name: Run script/ci-custom # name: Run script/ci-custom
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Register matcher # - name: Register matcher
run: echo "::add-matcher::.github/workflows/matchers/ci-custom.json" # run: echo "::add-matcher::.github/workflows/matchers/ci-custom.json"
- name: Run script/ci-custom # - name: Run script/ci-custom
run: | # run: |
. venv/bin/activate # . venv/bin/activate
script/ci-custom.py # script/ci-custom.py
script/build_codeowners.py --check # script/build_codeowners.py --check
pytest: # pytest:
name: Run pytest # name: Run pytest
strategy: # strategy:
fail-fast: false # fail-fast: false
matrix: # matrix:
python-version: # python-version:
- "3.9" # - "3.9"
- "3.10" # - "3.10"
- "3.11" # - "3.11"
- "3.12" # - "3.12"
os: # os:
- ubuntu-latest # - ubuntu-latest
- macOS-latest # - macOS-latest
- windows-latest # - windows-latest
exclude: # exclude:
# Minimize CI resource usage # # Minimize CI resource usage
# by only running the Python version # # by only running the Python version
# version used for docker images on Windows and macOS # # version used for docker images on Windows and macOS
- python-version: "3.12" # - python-version: "3.12"
os: windows-latest # os: windows-latest
- python-version: "3.10" # - python-version: "3.10"
os: windows-latest # os: windows-latest
- python-version: "3.9" # - python-version: "3.9"
os: windows-latest # os: windows-latest
- python-version: "3.12" # - python-version: "3.12"
os: macOS-latest # os: macOS-latest
- python-version: "3.10" # - python-version: "3.10"
os: macOS-latest # os: macOS-latest
- python-version: "3.9" # - python-version: "3.9"
os: macOS-latest # os: macOS-latest
runs-on: ${{ matrix.os }} # runs-on: ${{ matrix.os }}
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ matrix.python-version }} # python-version: ${{ matrix.python-version }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Register matcher # - name: Register matcher
run: echo "::add-matcher::.github/workflows/matchers/pytest.json" # run: echo "::add-matcher::.github/workflows/matchers/pytest.json"
- name: Run pytest # - name: Run pytest
if: matrix.os == 'windows-latest' # if: matrix.os == 'windows-latest'
run: | # run: |
./venv/Scripts/activate # ./venv/Scripts/activate
pytest -vv --cov-report=xml --tb=native tests # pytest -vv --cov-report=xml --tb=native tests
- name: Run pytest # - name: Run pytest
if: matrix.os == 'ubuntu-latest' || matrix.os == 'macOS-latest' # if: matrix.os == 'ubuntu-latest' || matrix.os == 'macOS-latest'
run: | # run: |
. venv/bin/activate # . venv/bin/activate
pytest -vv --cov-report=xml --tb=native tests # pytest -vv --cov-report=xml --tb=native tests
- name: Upload coverage to Codecov # - name: Upload coverage to Codecov
uses: codecov/codecov-action@v4 # uses: codecov/codecov-action@v4
with: # with:
token: ${{ secrets.CODECOV_TOKEN }} # token: ${{ secrets.CODECOV_TOKEN }}
clang-format: # clang-format:
name: Check clang-format # name: Check clang-format
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Install clang-format # - name: Install clang-format
run: | # run: |
. venv/bin/activate # . venv/bin/activate
pip install clang-format -c requirements_dev.txt # pip install clang-format -c requirements_dev.txt
- name: Run clang-format # - name: Run clang-format
run: | # run: |
. venv/bin/activate # . venv/bin/activate
script/clang-format -i # script/clang-format -i
git diff-index --quiet HEAD -- # git diff-index --quiet HEAD --
- name: Suggested changes # - name: Suggested changes
run: script/ci-suggest-changes # run: script/ci-suggest-changes
if: always() # if: always()
compile-tests-list: # compile-tests-list:
runs-on: ubuntu-latest # runs-on: ubuntu-latest
outputs: # outputs:
matrix: ${{ steps.set-matrix.outputs.matrix }} # matrix: ${{ steps.set-matrix.outputs.matrix }}
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Find all YAML test files # - name: Find all YAML test files
id: set-matrix # id: set-matrix
run: echo "matrix=$(ls tests/test*.yaml | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT # run: echo "matrix=$(ls tests/test*.yaml | jq -R -s -c 'split("\n")[:-1]')" >> $GITHUB_OUTPUT
validate-tests: # validate-tests:
name: Validate YAML test ${{ matrix.file }} # name: Validate YAML test ${{ matrix.file }}
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
- compile-tests-list # - compile-tests-list
strategy: # strategy:
fail-fast: false # fail-fast: false
matrix: # matrix:
file: ${{ fromJson(needs.compile-tests-list.outputs.matrix) }} # file: ${{ fromJson(needs.compile-tests-list.outputs.matrix) }}
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Run esphome config ${{ matrix.file }} # - name: Run esphome config ${{ matrix.file }}
run: | # run: |
. venv/bin/activate # . venv/bin/activate
esphome config ${{ matrix.file }} # esphome config ${{ matrix.file }}
compile-tests: # compile-tests:
name: Run YAML test ${{ matrix.file }} # name: Run YAML test ${{ matrix.file }}
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
- black # - black
- ci-custom # - ci-custom
- clang-format # - clang-format
- flake8 # - flake8
- pylint # - pylint
- pytest # - pytest
- pyupgrade # - pyupgrade
- compile-tests-list # - compile-tests-list
- validate-tests # - validate-tests
strategy: # strategy:
fail-fast: false # fail-fast: false
max-parallel: 2 # max-parallel: 2
matrix: # matrix:
file: ${{ fromJson(needs.compile-tests-list.outputs.matrix) }} # file: ${{ fromJson(needs.compile-tests-list.outputs.matrix) }}
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Run esphome compile ${{ matrix.file }} # - name: Run esphome compile ${{ matrix.file }}
run: | # run: |
. venv/bin/activate # . venv/bin/activate
esphome compile ${{ matrix.file }} # esphome compile ${{ matrix.file }}
clang-tidy: clang-tidy:
name: ${{ matrix.name }} name: ${{ matrix.name }}
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: needs:
- common - common
- black # - black
- ci-custom # - ci-custom
- clang-format # - clang-format
- flake8 # - flake8
- pylint # - pylint
- pytest # - pytest
- pyupgrade # - pyupgrade
strategy: strategy:
fail-fast: false fail-fast: false
max-parallel: 2 max-parallel: 2
matrix: matrix:
include: include:
- id: clang-tidy # - id: clang-tidy
name: Run script/clang-tidy for ESP8266 # name: Run script/clang-tidy for ESP8266
options: --environment esp8266-arduino-tidy --grep USE_ESP8266 # options: --environment esp8266-arduino-tidy --grep USE_ESP8266
pio_cache_key: tidyesp8266 # pio_cache_key: tidyesp8266
- id: clang-tidy # - id: clang-tidy
name: Run script/clang-tidy for ESP32 Arduino 1/4 # name: Run script/clang-tidy for ESP32 Arduino 1/4
options: --environment esp32-arduino-tidy --split-num 4 --split-at 1 # options: --environment esp32-arduino-tidy --split-num 4 --split-at 1
pio_cache_key: tidyesp32 # pio_cache_key: tidyesp32
- id: clang-tidy # - id: clang-tidy
name: Run script/clang-tidy for ESP32 Arduino 2/4 # name: Run script/clang-tidy for ESP32 Arduino 2/4
options: --environment esp32-arduino-tidy --split-num 4 --split-at 2 # options: --environment esp32-arduino-tidy --split-num 4 --split-at 2
pio_cache_key: tidyesp32 # pio_cache_key: tidyesp32
- id: clang-tidy # - id: clang-tidy
name: Run script/clang-tidy for ESP32 Arduino 3/4 # name: Run script/clang-tidy for ESP32 Arduino 3/4
options: --environment esp32-arduino-tidy --split-num 4 --split-at 3 # options: --environment esp32-arduino-tidy --split-num 4 --split-at 3
pio_cache_key: tidyesp32 # pio_cache_key: tidyesp32
- id: clang-tidy # - id: clang-tidy
name: Run script/clang-tidy for ESP32 Arduino 4/4 # name: Run script/clang-tidy for ESP32 Arduino 4/4
options: --environment esp32-arduino-tidy --split-num 4 --split-at 4 # options: --environment esp32-arduino-tidy --split-num 4 --split-at 4
pio_cache_key: tidyesp32 # pio_cache_key: tidyesp32
- id: clang-tidy - id: clang-tidy
name: Run script/clang-tidy for ESP32 IDF name: Run script/clang-tidy for ESP32 IDF
options: --environment esp32-idf-tidy --grep USE_ESP_IDF options: --environment esp32-idf-tidy --grep USE_ESP_IDF
@ -407,164 +407,164 @@ jobs:
# yamllint disable-line rule:line-length # yamllint disable-line rule:line-length
if: always() if: always()
list-components: # list-components:
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
if: github.event_name == 'pull_request' # if: github.event_name == 'pull_request'
outputs: # outputs:
components: ${{ steps.list-components.outputs.components }} # components: ${{ steps.list-components.outputs.components }}
count: ${{ steps.list-components.outputs.count }} # count: ${{ steps.list-components.outputs.count }}
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
with: # with:
# Fetch enough history so `git merge-base refs/remotes/origin/dev HEAD` works. # # Fetch enough history so `git merge-base refs/remotes/origin/dev HEAD` works.
fetch-depth: 500 # fetch-depth: 500
- name: Get target branch # - name: Get target branch
id: target-branch # id: target-branch
run: | # run: |
echo "branch=${{ github.event.pull_request.base.ref }}" >> $GITHUB_OUTPUT # echo "branch=${{ github.event.pull_request.base.ref }}" >> $GITHUB_OUTPUT
- name: Fetch ${{ steps.target-branch.outputs.branch }} branch # - name: Fetch ${{ steps.target-branch.outputs.branch }} branch
run: | # run: |
git -c protocol.version=2 fetch --no-tags --prune --no-recurse-submodules --depth=1 origin +refs/heads/${{ steps.target-branch.outputs.branch }}:refs/remotes/origin/${{ steps.target-branch.outputs.branch }} # git -c protocol.version=2 fetch --no-tags --prune --no-recurse-submodules --depth=1 origin +refs/heads/${{ steps.target-branch.outputs.branch }}:refs/remotes/origin/${{ steps.target-branch.outputs.branch }}
git merge-base refs/remotes/origin/${{ steps.target-branch.outputs.branch }} HEAD # git merge-base refs/remotes/origin/${{ steps.target-branch.outputs.branch }} HEAD
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Find changed components # - name: Find changed components
id: list-components # id: list-components
run: | # run: |
. venv/bin/activate # . venv/bin/activate
components=$(script/list-components.py --changed --branch ${{ steps.target-branch.outputs.branch }}) # components=$(script/list-components.py --changed --branch ${{ steps.target-branch.outputs.branch }})
output_components=$(echo "$components" | jq -R -s -c 'split("\n")[:-1] | map(select(length > 0))') # output_components=$(echo "$components" | jq -R -s -c 'split("\n")[:-1] | map(select(length > 0))')
count=$(echo "$output_components" | jq length) # count=$(echo "$output_components" | jq length)
echo "components=$output_components" >> $GITHUB_OUTPUT # echo "components=$output_components" >> $GITHUB_OUTPUT
echo "count=$count" >> $GITHUB_OUTPUT # echo "count=$count" >> $GITHUB_OUTPUT
echo "$count Components:" # echo "$count Components:"
echo "$output_components" | jq # echo "$output_components" | jq
test-build-components: # test-build-components:
name: Component test ${{ matrix.file }} # name: Component test ${{ matrix.file }}
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
- list-components # - list-components
if: github.event_name == 'pull_request' && fromJSON(needs.list-components.outputs.count) > 0 && fromJSON(needs.list-components.outputs.count) < 100 # if: github.event_name == 'pull_request' && fromJSON(needs.list-components.outputs.count) > 0 && fromJSON(needs.list-components.outputs.count) < 100
strategy: # strategy:
fail-fast: false # fail-fast: false
max-parallel: 2 # max-parallel: 2
matrix: # matrix:
file: ${{ fromJson(needs.list-components.outputs.components) }} # file: ${{ fromJson(needs.list-components.outputs.components) }}
steps: # steps:
- name: Install dependencies # - name: Install dependencies
run: sudo apt-get install libsodium-dev libsdl2-dev # run: sudo apt-get install libsodium-dev libsdl2-dev
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: test_build_components -e config -c ${{ matrix.file }} # - name: test_build_components -e config -c ${{ matrix.file }}
run: | # run: |
. venv/bin/activate # . venv/bin/activate
./script/test_build_components -e config -c ${{ matrix.file }} # ./script/test_build_components -e config -c ${{ matrix.file }}
- name: test_build_components -e compile -c ${{ matrix.file }} # - name: test_build_components -e compile -c ${{ matrix.file }}
run: | # run: |
. venv/bin/activate # . venv/bin/activate
./script/test_build_components -e compile -c ${{ matrix.file }} # ./script/test_build_components -e compile -c ${{ matrix.file }}
test-build-components-splitter: # test-build-components-splitter:
name: Split components for testing into 20 groups maximum # name: Split components for testing into 20 groups maximum
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
- list-components # - list-components
if: github.event_name == 'pull_request' && fromJSON(needs.list-components.outputs.count) >= 100 # if: github.event_name == 'pull_request' && fromJSON(needs.list-components.outputs.count) >= 100
outputs: # outputs:
matrix: ${{ steps.split.outputs.components }} # matrix: ${{ steps.split.outputs.components }}
steps: # steps:
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Split components into 20 groups # - name: Split components into 20 groups
id: split # id: split
run: | # run: |
components=$(echo '${{ needs.list-components.outputs.components }}' | jq -c '.[]' | shuf | jq -s -c '[_nwise(20) | join(" ")]') # components=$(echo '${{ needs.list-components.outputs.components }}' | jq -c '.[]' | shuf | jq -s -c '[_nwise(20) | join(" ")]')
echo "components=$components" >> $GITHUB_OUTPUT # echo "components=$components" >> $GITHUB_OUTPUT
test-build-components-split: # test-build-components-split:
name: Test split components # name: Test split components
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
- list-components # - list-components
- test-build-components-splitter # - test-build-components-splitter
if: github.event_name == 'pull_request' && fromJSON(needs.list-components.outputs.count) >= 100 # if: github.event_name == 'pull_request' && fromJSON(needs.list-components.outputs.count) >= 100
strategy: # strategy:
fail-fast: false # fail-fast: false
max-parallel: 4 # max-parallel: 4
matrix: # matrix:
components: ${{ fromJson(needs.test-build-components-splitter.outputs.matrix) }} # components: ${{ fromJson(needs.test-build-components-splitter.outputs.matrix) }}
steps: # steps:
- name: List components # - name: List components
run: echo ${{ matrix.components }} # run: echo ${{ matrix.components }}
- name: Install dependencies # - name: Install dependencies
run: sudo apt-get install libsodium-dev libsdl2-dev # run: sudo apt-get install libsodium-dev libsdl2-dev
- name: Check out code from GitHub # - name: Check out code from GitHub
uses: actions/checkout@v4.1.7 # uses: actions/checkout@v4.1.7
- name: Restore Python # - name: Restore Python
uses: ./.github/actions/restore-python # uses: ./.github/actions/restore-python
with: # with:
python-version: ${{ env.DEFAULT_PYTHON }} # python-version: ${{ env.DEFAULT_PYTHON }}
cache-key: ${{ needs.common.outputs.cache-key }} # cache-key: ${{ needs.common.outputs.cache-key }}
- name: Validate config # - name: Validate config
run: | # run: |
. venv/bin/activate # . venv/bin/activate
for component in ${{ matrix.components }}; do # for component in ${{ matrix.components }}; do
./script/test_build_components -e config -c $component # ./script/test_build_components -e config -c $component
done # done
- name: Compile config # - name: Compile config
run: | # run: |
. venv/bin/activate # . venv/bin/activate
for component in ${{ matrix.components }}; do # for component in ${{ matrix.components }}; do
./script/test_build_components -e compile -c $component # ./script/test_build_components -e compile -c $component
done # done
ci-status: # ci-status:
name: CI Status # name: CI Status
runs-on: ubuntu-latest # runs-on: ubuntu-latest
needs: # needs:
- common # - common
- black # - black
- ci-custom # - ci-custom
- clang-format # - clang-format
- flake8 # - flake8
- pylint # - pylint
- pytest # - pytest
- pyupgrade # - pyupgrade
- compile-tests # - compile-tests
- clang-tidy # - clang-tidy
- list-components # - list-components
- test-build-components # - test-build-components
- test-build-components-splitter # - test-build-components-splitter
- test-build-components-split # - test-build-components-split
if: always() # if: always()
steps: # steps:
- name: Success # - name: Success
if: ${{ !(contains(needs.*.result, 'failure')) }} # if: ${{ !(contains(needs.*.result, 'failure')) }}
run: exit 0 # run: exit 0
- name: Failure # - name: Failure
if: ${{ contains(needs.*.result, 'failure') }} # if: ${{ contains(needs.*.result, 'failure') }}
env: # env:
JSON_DOC: ${{ toJSON(needs) }} # JSON_DOC: ${{ toJSON(needs) }}
run: | # run: |
echo $JSON_DOC | jq # echo $JSON_DOC | jq
exit 1 # exit 1