diff options
| -rw-r--r-- | .gitlab-ci-sage-lab.yml | 186 | ||||
| -rw-r--r-- | .gitlab-ci.yml | 5 |
2 files changed, 191 insertions, 0 deletions
diff --git a/.gitlab-ci-sage-lab.yml b/.gitlab-ci-sage-lab.yml new file mode 100644 index 00000000000..d29af92565a --- /dev/null +++ b/.gitlab-ci-sage-lab.yml @@ -0,0 +1,186 @@ +# Definition for the lab connected to the "sage" host and managed with labgrid + +.sage_lab_template: &sage_lab_dfn + stage: sage-lab + rules: + - if: $SAGE_LAB == "1" + when: always + - if: $SAGE_LAB != "1" + when: manual + allow_failure: true + # USB can be unreliable. + retry: 2 + dependencies: [] + needs: [ "sandbox test.py" ] + tags: [ 'konsulko-sage-labgrid' ] + before_script: + # Clone uboot-test-hooks + - git config --global --add safe.directory "${CI_PROJECT_DIR}" + - git clone --depth=1 https://source.denx.de/u-boot/u-boot-test-hooks /tmp/uboot-test-hooks + - ln -s sage /tmp/uboot-test-hooks/bin/`hostname` + - ln -s sage /tmp/uboot-test-hooks/py/`hostname` + - export LG_ENV="/tmp/uboot-test-hooks/bin/sage/labgrid-sage-env.yaml"; + export LG_COORDINATOR=172.17.0.1:20408 + # Prepare python environment + - python3 -m venv /tmp/venv; + . /tmp/venv/bin/activate; + pip install -r test/py/requirements.txt -r tools/binman/requirements.txt + -r tools/buildman/requirements.txt -r tools/u_boot_pylib/requirements.txt + labgrid setuptools + # Add more tools + - sudo apt-get update && sudo apt-get -y install snmp rsync + # Acquire and turn on the exporter. + - labgrid-client reserve --wait board=${LABGRID_EXPORTER} && + labgrid-client -p ${LABGRID_EXPORTER} acquire && + labgrid-client -p ${LABGRID_EXPORTER} power on + # Prepare ssh + - mkdir --mode=0700 ~/.ssh; + printf 'Host sage-exporter-*\n\tUser labgrid\n' > ~/.ssh/config + script: + - export UBOOT_TRAVIS_BUILD_DIR=/tmp/${TEST_PY_BD} + # Don't stop on non-zero exit codes now, to provide as much chance as + # possible to ensure we don't leave lab resources acquired. + - set +e; + # Sage is 16 threads and has 3 devices attached, so 6 builder threads. + - tools/buildman/buildman -o ${UBOOT_TRAVIS_BUILD_DIR} -w -E -W -e + --board ${TEST_PY_BD} ${OVERRIDE} -T 6; + RC=`echo $?`; + # Wait for the exporter to have the device ready + - while test `labgrid-client resources | + grep -q ${LABGRID_EXPORTER}/${LG_PLACE}/; echo $?` -ne 0; do sleep 1; + done + # Fingerprint the exporter + - ssh-keyscan ${LABGRID_EXPORTER} > ~/.ssh/known_hosts 2>/dev/null + # If we built, run the tests and save the results. + - export PATH=/tmp/uboot-test-hooks/bin:${PATH}; + export PYTHONPATH=/tmp/uboot-test-hooks/py/sage; + test $RC -eq 0 && labgrid-client reserve --wait board=${LG_PLACE} && + labgrid-client -p ${LG_PLACE} acquire && + ./test/py/test.py -ra --bd ${TEST_PY_BD} ${TEST_PY_ID} + ${TEST_PY_EXTRA:-"--capture=tee-sys"} + ${TEST_PY_TEST_SPEC:+"-k ${TEST_PY_TEST_SPEC}"} + --build-dir "$UBOOT_TRAVIS_BUILD_DIR" + --junitxml=/tmp/${TEST_PY_BD}/results.xml; + RC=`echo $?`; + cp -v /tmp/${TEST_PY_BD}/*.{html,css,xml} .; + # Release and power off everything. + - labgrid-client -p ${LG_PLACE} power off + - labgrid-client -p ${LG_PLACE} release + - labgrid-client -p ${LABGRID_EXPORTER} ssh sudo poweroff && sleep 15 && + labgrid-client -p ${LABGRID_EXPORTER} power off + - labgrid-client -p ${LABGRID_EXPORTER} release + - exit $RC + artifacts: + when: always + paths: + - "*.html" + - "*.css" + - results.xml + reports: + junit: results.xml + expire_in: 1 week + +SolidRun Hummingboard 2: + <<: *sage_lab_dfn + variables: + LABGRID_EXPORTER: "sage-exporter-hb-1" + LG_PLACE: "hb-1" + TEST_PY_BD: "mx6cuboxi" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG" + +SolidRun Hummingboard 2 (lwIP): + <<: *sage_lab_dfn + needs: [ "SolidRun Hummingboard 2" ] + variables: + LABGRID_EXPORTER: "sage-exporter-hb-1" + LG_PLACE: "hb-1" + TEST_PY_BD: "mx6cuboxi" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a NET_LWIP" + +Raspberry Pi 4: + <<: *sage_lab_dfn + variables: + LABGRID_EXPORTER: "sage-exporter-rpi4-1" + LG_PLACE: "rpi4-1" + TEST_PY_BD: "rpi_4" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a ~CMD_BOOTEFI_SELFTEST -a CMD_TFTPPUT -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000" + +Raspberry Pi 4 (rpi_arm64): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 4" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi4-1" + LG_PLACE: "rpi4-1" + TEST_PY_BD: "rpi_arm64" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a ~CMD_BOOTEFI_SELFTEST -a CMD_TFTPPUT -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000" + +Raspberry Pi 4 (rpi_arm64, lwIP): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 4 (rpi_arm64)" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi4-1" + LG_PLACE: "rpi4-1" + TEST_PY_BD: "rpi_arm64" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a ~CMD_BOOTEFI_SELFTEST -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000 -a NET_LWIP" + +Raspberry Pi 4 (rpi_4_32b): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 4 (rpi_arm64, lwIP)" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi4-1" + LG_PLACE: "rpi4-1" + TEST_PY_BD: "rpi_4_32b" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a CMD_BOOTEFI_SELFTEST -a CMD_TFTPPUT -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000" + +Raspberry Pi 4 (rpi_4_32b, lwIP): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 4 (rpi_4_32b)" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi4-1" + LG_PLACE: "rpi4-1" + TEST_PY_BD: "rpi_4_32b" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a CMD_BOOTEFI_SELFTEST -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000 -a NET_LWIP" + +Raspberry Pi 3: + <<: *sage_lab_dfn + variables: + LABGRID_EXPORTER: "sage-exporter-rpi3-1" + LG_PLACE: "rpi3-1" + TEST_PY_BD: "rpi_3" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a CMD_BOOTEFI_SELFTEST -a CMD_TFTPPUT -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000" + +Raspberry Pi 3 (rpi_arm64): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 3" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi3-1" + LG_PLACE: "rpi3-1" + TEST_PY_BD: "rpi_arm64" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a ~CMD_BOOTEFI_SELFTEST -a CMD_TFTPPUT -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000" + +Raspberry Pi 3 (rpi_arm64, lwIP): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 3 (rpi_arm64)" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi3-1" + LG_PLACE: "rpi3-1" + TEST_PY_BD: "rpi_arm64" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a ~CMD_BOOTEFI_SELFTEST -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000 -a NET_LWIP" + +Raspberry Pi 3 (rpi_3_32b): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 3 (rpi_arm64, lwIP)" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi3-1" + LG_PLACE: "rpi3-1" + TEST_PY_BD: "rpi_3_32b" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a CMD_BOOTEFI_SELFTEST -a CMD_TFTPPUT -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000" + +Raspberry Pi 3 (rpi_3_32b, lwIP): + <<: *sage_lab_dfn + needs: [ "Raspberry Pi 3 (rpi_3_32b)" ] + variables: + LABGRID_EXPORTER: "sage-exporter-rpi3-1" + LG_PLACE: "rpi3-1" + TEST_PY_BD: "rpi_3_32b" + OVERRIDE: "-a UNIT_TEST -a ~CMD_EFIDEBUG -a CMD_BOOTMENU -a CMD_LOG -a CMD_BOOTEFI_SELFTEST -a FIT -a FIT_SIGNATURE -a FIT_BEST_MATCH -a SYS_BOOTM_LEN=0x4000000 -a BOOTSTAGE -a BOOTSTAGE_STASH -a CMD_BOOTSTAGE -a BOOTSTAGE_STASH_ADDR=0x02400000 -a NET_LWIP" diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 5e9995aed6a..8aab61dcb62 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -5,6 +5,7 @@ variables: DEFAULT_AMD64_TAG: "amd64" DEFAULT_FAST_TAG: "fast" MIRROR_DOCKER: docker.io + SAGE_LAB: "" SJG_LAB: "" PLATFORM: linux/amd64,linux/arm64 @@ -24,6 +25,7 @@ image: ${MIRROR_DOCKER}/trini/u-boot-gitlab-ci-runner:noble-20251001-11Nov2025 stages: - testsuites - test.py + - sage-lab - sjg-lab - world build @@ -593,6 +595,9 @@ coreboot test.py: TEST_PY_ID: "--id qemu" <<: *buildman_and_testpy_dfn +# Add sage-lab stage +include: .gitlab-ci-sage-lab.yml + .sjg_lab_template: &sjg_lab_dfn stage: sjg-lab rules: |
