mirror of
https://github.com/espressif/esp-protocols.git
synced 2025-07-16 12:02:11 +02:00
fix(mdns): Use idf-build-apps package for building mdns
This commit is contained in:
121
.github/workflows/mdns__build-target-test.yml
vendored
121
.github/workflows/mdns__build-target-test.yml
vendored
@ -13,122 +13,33 @@ jobs:
|
|||||||
name: Build
|
name: Build
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
idf_ver: ["latest"]
|
idf_ver: ["latest", "release-v5.0"]
|
||||||
idf_target: ["esp32", "esp32s2", "esp32c3"]
|
test: [ { app: example, path: "examples" }, { app: unit_test, path: "tests/unit_test" }, { app: test_app, path: "tests/test_apps" } ]
|
||||||
test: [ { app: example, path: "components/mdns/examples" }, { app: unit_test, path: "components/mdns/tests/unit_test" } ]
|
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
container: espressif/idf:${{ matrix.idf_ver }}
|
container: espressif/idf:${{ matrix.idf_ver }}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout esp-protocols
|
- name: Checkout esp-protocols
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
- name: Build ${{ matrix.test.app }} with IDF-${{ matrix.idf_ver }}
|
||||||
submodules: recursive
|
|
||||||
- name: Build ${{ matrix.test.app }} with IDF-${{ matrix.idf_ver }} for ${{ matrix.idf_target }}
|
|
||||||
shell: bash
|
shell: bash
|
||||||
working-directory: ${{ matrix.test.path }}
|
|
||||||
run: |
|
run: |
|
||||||
${IDF_PATH}/install.sh --enable-pytest
|
|
||||||
. ${IDF_PATH}/export.sh
|
. ${IDF_PATH}/export.sh
|
||||||
python $IDF_PATH/tools/ci/ci_build_apps.py . --target ${{ matrix.idf_target }} -vv --preserve-all --pytest-app
|
python -m pip install idf-build-apps
|
||||||
for dir in `ls -d build_*`; do
|
# Build default configs for all targets
|
||||||
|
python ./ci/build_apps.py components/mdns/${{ matrix.test.path }} -r default -m components/mdns/.build-test-rules.yml -d
|
||||||
|
# Build specific configs for test targets
|
||||||
|
python ./ci/build_apps.py components/mdns/${{ matrix.test.path }}
|
||||||
|
cd components/mdns/${{ matrix.test.path }}
|
||||||
|
for dir in `ls -d build_esp32_*`; do
|
||||||
$GITHUB_WORKSPACE/ci/clean_build_artifacts.sh `pwd`/$dir
|
$GITHUB_WORKSPACE/ci/clean_build_artifacts.sh `pwd`/$dir
|
||||||
zip -qur artifacts.zip $dir
|
zip -qur artifacts.zip $dir
|
||||||
done
|
done
|
||||||
- uses: actions/upload-artifact@v3
|
- uses: actions/upload-artifact@v3
|
||||||
if: ${{ matrix.idf_target }} == "esp32"
|
|
||||||
with:
|
with:
|
||||||
name: mdns_bin_${{ matrix.idf_target }}_${{ matrix.idf_ver }}_${{ matrix.test.app }}
|
name: mdns_bin_esp32_${{ matrix.idf_ver }}_${{ matrix.test.app }}
|
||||||
path: ${{ matrix.test.path }}/artifacts.zip
|
path: components/mdns/${{ matrix.test.path }}/artifacts.zip
|
||||||
if-no-files-found: error
|
if-no-files-found: error
|
||||||
|
|
||||||
build_mdns_app:
|
|
||||||
if: contains(github.event.pull_request.labels.*.name, 'mdns') || github.event_name == 'push'
|
|
||||||
name: Build Test Apps
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
idf_ver: ["latest"]
|
|
||||||
idf_target: ["esp32", "esp32s2", "esp32c3"]
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
container: espressif/idf:${{ matrix.idf_ver }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout esp-protocols
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- name: Setup Build Environment
|
|
||||||
working-directory: components/mdns/tests/test_apps
|
|
||||||
run: |
|
|
||||||
. ${IDF_PATH}/export.sh
|
|
||||||
pip install -r $GITHUB_WORKSPACE/ci/requirements.txt
|
|
||||||
- name: Build ${{ matrix.example }} with IDF-${{ matrix.idf_ver }} for ${{ matrix.idf_target }}
|
|
||||||
env:
|
|
||||||
IDF_TARGET: ${{ matrix.idf_target }}
|
|
||||||
shell: bash
|
|
||||||
working-directory: components/mdns/tests/test_apps
|
|
||||||
run: |
|
|
||||||
. ${IDF_PATH}/export.sh
|
|
||||||
python $IDF_PATH/tools/ci/ci_build_apps.py . --target ${{ matrix.idf_target }} -vv --pytest-apps
|
|
||||||
- name: Merge binaries with IDF-${{ matrix.idf_ver }}
|
|
||||||
working-directory: components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default
|
|
||||||
env:
|
|
||||||
IDF_TARGET: ${{ matrix.idf_target }}
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
. ${IDF_PATH}/export.sh
|
|
||||||
esptool.py --chip ${{ matrix.idf_target }} merge_bin --fill-flash-size 4MB -o flash_image.bin @flash_args
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: examples_app_bin_${{ matrix.idf_target }}_${{ matrix.idf_ver }}
|
|
||||||
path: |
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/bootloader/bootloader.bin
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/partition_table/partition-table.bin
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/*.bin
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/*.elf
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/flasher_args.json
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/config/sdkconfig.h
|
|
||||||
components/mdns/tests/test_apps/build_${{ matrix.idf_target }}_default/config/sdkconfig.json
|
|
||||||
if-no-files-found: error
|
|
||||||
|
|
||||||
target_test_apps_mdns:
|
|
||||||
# Skip running on forks since it won't have access to secrets
|
|
||||||
if: |
|
|
||||||
github.repository == 'espressif/esp-protocols' &&
|
|
||||||
( contains(github.event.pull_request.labels.*.name, 'mdns') || github.event_name == 'push' )
|
|
||||||
name: Target Test Apps
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
idf_ver: ["latest"]
|
|
||||||
idf_target: ["esp32"]
|
|
||||||
needs: build_mdns_app
|
|
||||||
runs-on:
|
|
||||||
- self-hosted
|
|
||||||
- ESP32-ETHERNET-KIT
|
|
||||||
steps:
|
|
||||||
- name: Clear repository
|
|
||||||
run: sudo rm -fr $GITHUB_WORKSPACE && mkdir $GITHUB_WORKSPACE
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- uses: actions/download-artifact@v2
|
|
||||||
with:
|
|
||||||
name: examples_app_bin_${{ matrix.idf_target }}_${{ matrix.idf_ver }}
|
|
||||||
path: components/mdns/tests/test_apps/build
|
|
||||||
- name: Install Python packages
|
|
||||||
env:
|
|
||||||
PIP_EXTRA_INDEX_URL: "https://www.piwheels.org/simple"
|
|
||||||
run: |
|
|
||||||
sudo apt-get install -y dnsutils
|
|
||||||
- name: Download Test apps to target
|
|
||||||
run: |
|
|
||||||
python -m esptool --chip ${{ matrix.idf_target }} write_flash 0x0 components/mdns/tests/test_apps/build/flash_image.bin
|
|
||||||
- name: Run Example Test on target
|
|
||||||
working-directory: components/mdns/tests/test_apps
|
|
||||||
run: |
|
|
||||||
python -m pytest --log-cli-level DEBUG --junit-xml=./examples_results_${{ matrix.idf_target }}_${{ matrix.idf_ver }}.xml --target=${{matrix.idf_target}}
|
|
||||||
- uses: actions/upload-artifact@v2
|
|
||||||
if: always()
|
|
||||||
with:
|
|
||||||
name: test_apps_results_${{ matrix.idf_target }}_${{ matrix.idf_ver }}
|
|
||||||
path: components/mdns/tests/test_apps/*.xml
|
|
||||||
|
|
||||||
target_tests_mdns:
|
target_tests_mdns:
|
||||||
# Skip running on forks since it won't have access to secrets
|
# Skip running on forks since it won't have access to secrets
|
||||||
if: |
|
if: |
|
||||||
@ -139,7 +50,7 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
idf_ver: ["latest"]
|
idf_ver: ["latest"]
|
||||||
idf_target: ["esp32"]
|
idf_target: ["esp32"]
|
||||||
test: [ { app: example, path: "components/mdns/examples" }, { app: unit_test, path: "components/mdns/tests/unit_test" } ]
|
test: [ { app: example, path: "examples" }, { app: unit_test, path: "tests/unit_test" }, { app: test_app, path: "tests/test_apps" } ]
|
||||||
needs: build_mdns
|
needs: build_mdns
|
||||||
runs-on:
|
runs-on:
|
||||||
- self-hosted
|
- self-hosted
|
||||||
@ -151,14 +62,14 @@ jobs:
|
|||||||
- uses: actions/download-artifact@v3
|
- uses: actions/download-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: mdns_bin_${{ matrix.idf_target }}_${{ matrix.idf_ver }}_${{ matrix.test.app }}
|
name: mdns_bin_${{ matrix.idf_target }}_${{ matrix.idf_ver }}_${{ matrix.test.app }}
|
||||||
path: ${{ matrix.test.path }}/ci/
|
path: components/mdns/${{ matrix.test.path }}/ci/
|
||||||
- name: Install Python packages
|
- name: Install Python packages
|
||||||
env:
|
env:
|
||||||
PIP_EXTRA_INDEX_URL: "https://www.piwheels.org/simple"
|
PIP_EXTRA_INDEX_URL: "https://www.piwheels.org/simple"
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get install -y dnsutils
|
sudo apt-get install -y dnsutils
|
||||||
- name: Run ${{ matrix.test.app }} application on ${{ matrix.idf_target }}
|
- name: Run ${{ matrix.test.app }} application on ${{ matrix.idf_target }}
|
||||||
working-directory: ${{ matrix.test.path }}
|
working-directory: components/mdns/${{ matrix.test.path }}
|
||||||
run: |
|
run: |
|
||||||
unzip ci/artifacts.zip -d ci
|
unzip ci/artifacts.zip -d ci
|
||||||
for dir in `ls -d ci/build_*`; do
|
for dir in `ls -d ci/build_*`; do
|
||||||
@ -170,4 +81,4 @@ jobs:
|
|||||||
if: always()
|
if: always()
|
||||||
with:
|
with:
|
||||||
name: results_${{ matrix.test.app }}_${{ matrix.idf_target }}_${{ matrix.idf_ver }}.xml
|
name: results_${{ matrix.test.app }}_${{ matrix.idf_target }}_${{ matrix.idf_ver }}.xml
|
||||||
path: ${{ matrix.test.path }}/*.xml
|
path: components/mdns/${{ matrix.test.path }}/*.xml
|
||||||
|
@ -48,7 +48,7 @@ jobs:
|
|||||||
. ${IDF_PATH}/export.sh
|
. ${IDF_PATH}/export.sh
|
||||||
python -m pip install idf-build-apps
|
python -m pip install idf-build-apps
|
||||||
cd $GITHUB_WORKSPACE/protocols
|
cd $GITHUB_WORKSPACE/protocols
|
||||||
python ./ci/build_apps.py components/esp_modem/examples/${{ matrix.example }}
|
python ./ci/build_apps.py components/esp_modem/examples/${{ matrix.example }} -m components/esp_modem/examples/.build-test-rules.yml
|
||||||
|
|
||||||
host_test_esp_modem:
|
host_test_esp_modem:
|
||||||
if: contains(github.event.pull_request.labels.*.name, 'modem') || github.event_name == 'push'
|
if: contains(github.event.pull_request.labels.*.name, 'modem') || github.event_name == 'push'
|
||||||
|
@ -7,7 +7,6 @@ This file is used in CI for esp-protocols build tests
|
|||||||
import argparse
|
import argparse
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
from pathlib import Path
|
|
||||||
|
|
||||||
from idf_build_apps import build_apps, find_apps, setup_logging
|
from idf_build_apps import build_apps, find_apps, setup_logging
|
||||||
from idf_build_apps.constants import SUPPORTED_TARGETS
|
from idf_build_apps.constants import SUPPORTED_TARGETS
|
||||||
@ -24,6 +23,9 @@ if __name__ == '__main__':
|
|||||||
default='all',
|
default='all',
|
||||||
help='Build apps for given target',
|
help='Build apps for given target',
|
||||||
)
|
)
|
||||||
|
parser.add_argument('-r', '--rules', nargs='*', default=['sdkconfig.ci=default', 'sdkconfig.ci.*=', '=default'], help='Rules how to treat configs')
|
||||||
|
parser.add_argument('-m', '--manifests', nargs='*', default=[], help='list of manifest files')
|
||||||
|
parser.add_argument('-d', '--delete', action='store_true', help='Delete build artifacts')
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
IDF_PATH = os.environ['IDF_PATH']
|
IDF_PATH = os.environ['IDF_PATH']
|
||||||
@ -32,19 +34,15 @@ if __name__ == '__main__':
|
|||||||
setup_logging(2)
|
setup_logging(2)
|
||||||
apps = find_apps(
|
apps = find_apps(
|
||||||
args.paths,
|
args.paths,
|
||||||
recursive=True,
|
recursive=False,
|
||||||
target=args.target,
|
target=args.target,
|
||||||
build_dir='build_@t_@w',
|
build_dir='build_@t_@w',
|
||||||
config_rules_str=[
|
config_rules_str=args.rules,
|
||||||
'sdkconfig.ci=default', 'sdkconfig.ci.*=', '=default'
|
|
||||||
],
|
|
||||||
build_log_path='build_log.txt',
|
build_log_path='build_log.txt',
|
||||||
size_json_path='size.json',
|
size_json_path='size.json',
|
||||||
check_warnings=True,
|
check_warnings=True,
|
||||||
preserve=True,
|
preserve=not args.delete,
|
||||||
manifest_files=[
|
manifest_files=args.manifests,
|
||||||
str(p) for p in Path('.').glob('**/.build-test-rules.yml')
|
|
||||||
],
|
|
||||||
default_build_targets=SUPPORTED_TARGETS,
|
default_build_targets=SUPPORTED_TARGETS,
|
||||||
manifest_rootpath='.',
|
manifest_rootpath='.',
|
||||||
)
|
)
|
||||||
|
11
components/mdns/.build-test-rules.yml
Normal file
11
components/mdns/.build-test-rules.yml
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
components/mdns/examples:
|
||||||
|
disable:
|
||||||
|
- if: IDF_TARGET in ["esp32h2"]
|
||||||
|
|
||||||
|
components/mdns/tests/unit_test:
|
||||||
|
disable:
|
||||||
|
- if: IDF_TARGET in ["esp32h2"]
|
||||||
|
|
||||||
|
components/mdns/tests/test_apps:
|
||||||
|
disable:
|
||||||
|
- if: IDF_TARGET in ["esp32h2"]
|
3
components/mdns/tests/unit_test/sdkconfig.ci
Normal file
3
components/mdns/tests/unit_test/sdkconfig.ci
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
CONFIG_IDF_TARGET="esp32"
|
||||||
|
CONFIG_UNITY_ENABLE_FIXTURE=y
|
||||||
|
CONFIG_UNITY_ENABLE_IDF_TEST_RUNNER=n
|
Reference in New Issue
Block a user