From b0793e7d71a0f1e4f9e6ae59b22f5c503a917634 Mon Sep 17 00:00:00 2001 From: Chase Qi <chase.qi@linaro.org> Date: Fri, 17 Jun 2022 10:32:38 +0800 Subject: [PATCH] ci: enable LAVA boot and smoke tests on qemu devices for new MRs Given test scope for new MRs is not defined yet and we only have one rpi4, b68 and c61 in the warsaw lab which are occupied mostly by daily scheduled pipeline, starting with boot and smoke tests on qemu devices should be a good starting point for per MR testing. Jobs that extend `.lava-test` will be added to MR's pipeline and schedueld pipeline. `.lava-test-scheduled` extends `.lava-test` with new scheduled pipeline only rule. Long run jobs like ltp should extends the job so that they wouldn't prevent MRs from merging. Solves #486. Signed-off-by: Chase Qi <chase.qi@linaro.org> --- .gitlab-ci.yml | 69 +++++++++++++------------------------ .oniro-ci/test-generic.yaml | 9 +++-- 2 files changed, 30 insertions(+), 48 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index e1c2682c..182e3136 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -198,20 +198,14 @@ publish-seco-intel-b68: # Run the build for scheduled pipelines. - if: '$CI_PIPELINE_SOURCE == "schedule"' -# Mimic the updated rules for lava-test from the bitbake-workspace. -.lava-test: - rules: - - if: '$CI_LAVA_TOKEN == null' - when: never - - if: '$CI_PIPELINE_SOURCE == "schedule"' - -# Mimic the updated rules for lava-report from the bitbake-workspace. -.lava-report: +.lava-test-scheduled: + extends: .lava-test + variables: + CI_SQUAD_PROJECT_NAME: "oniro" rules: - - if: '$CI_LAVA_TOKEN == null' + - if: '$CI_SQUAD_TOKEN == null' when: never - if: '$CI_PIPELINE_SOURCE == "schedule"' - when: manual ## ## Submit jobs to LAVA @@ -239,7 +233,7 @@ lava-qemu-x86_64: lava-raspberrypi4-64: needs: [linux-raspberrypi4-64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: raspberrypi4-64 CI_BUILD_JOB_NAME: linux-raspberrypi4-64-gcc @@ -249,7 +243,7 @@ lava-raspberrypi4-64: lava-seco-intel-b68: needs: [linux-seco-intel-b68-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-intel-b68 CI_BUILD_JOB_NAME: linux-seco-intel-b68-gcc @@ -259,7 +253,7 @@ lava-seco-intel-b68: lava-seco-c61: needs: [linux-seco-imx8mm-c61-4gb-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-imx8mm-c61-4gb CI_BUILD_JOB_NAME: linux-seco-imx8mm-c61-4gb-gcc @@ -269,7 +263,7 @@ lava-seco-c61: lava-qemu-x86-ltp: needs: [linux-qemu-x86-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: qemux86 CI_BUILD_JOB_NAME: linux-qemu-x86-gcc @@ -279,7 +273,7 @@ lava-qemu-x86-ltp: lava-qemu-x86_64-ltp: needs: [linux-qemu-x86_64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: qemux86-64 CI_BUILD_JOB_NAME: linux-qemu-x86_64-gcc @@ -289,7 +283,7 @@ lava-qemu-x86_64-ltp: lava-raspberrypi4-64-ltp: needs: [linux-raspberrypi4-64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: raspberrypi4-64 CI_BUILD_JOB_NAME: linux-raspberrypi4-64-gcc @@ -299,7 +293,7 @@ lava-raspberrypi4-64-ltp: lava-seco-intel-b68-ltp: needs: [linux-seco-intel-b68-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-intel-b68 CI_BUILD_JOB_NAME: linux-seco-intel-b68-gcc @@ -309,7 +303,7 @@ lava-seco-intel-b68-ltp: lava-seco-c61-ltp: needs: [linux-seco-imx8mm-c61-4gb-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-imx8mm-c61-4gb CI_BUILD_JOB_NAME: linux-seco-imx8mm-c61-4gb-gcc @@ -319,7 +313,7 @@ lava-seco-c61-ltp: lava-qemu-x86_64-kselftest: needs: [linux-qemu-x86_64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: qemux86-64 CI_BUILD_JOB_NAME: linux-qemu-x86_64-gcc @@ -329,7 +323,7 @@ lava-qemu-x86_64-kselftest: lava-raspberrypi4-64-kselftest: needs: [linux-raspberrypi4-64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: raspberrypi4-64 CI_BUILD_JOB_NAME: linux-raspberrypi4-64-gcc @@ -339,7 +333,7 @@ lava-raspberrypi4-64-kselftest: lava-seco-c61-kselftest: needs: [linux-seco-imx8mm-c61-4gb-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-imx8mm-c61-4gb CI_BUILD_JOB_NAME: linux-seco-imx8mm-c61-4gb-gcc @@ -349,7 +343,7 @@ lava-seco-c61-kselftest: lava-zephyr-96b-nitrogen-twister: needs: [zephyr-96b-nitrogen-twister-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: 96b-nitrogen CI_BUILD_JOB_NAME: zephyr-96b-nitrogen-twister-gcc @@ -359,7 +353,7 @@ lava-zephyr-96b-nitrogen-twister: lava-qemu-x86-perf: needs: [linux-qemu-x86-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: qemux86 CI_BUILD_JOB_NAME: linux-qemu-x86-gcc @@ -369,7 +363,7 @@ lava-qemu-x86-perf: lava-qemu-x86_64-perf: needs: [linux-qemu-x86_64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: qemux86-64 CI_BUILD_JOB_NAME: linux-qemu-x86_64-gcc @@ -379,7 +373,7 @@ lava-qemu-x86_64-perf: lava-raspberrypi4-64-perf: needs: [linux-raspberrypi4-64-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: raspberrypi4-64 CI_BUILD_JOB_NAME: linux-raspberrypi4-64-gcc @@ -389,7 +383,7 @@ lava-raspberrypi4-64-perf: lava-seco-intel-b68-perf: needs: [linux-seco-intel-b68-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-intel-b68 CI_BUILD_JOB_NAME: linux-seco-intel-b68-gcc @@ -399,7 +393,7 @@ lava-seco-intel-b68-perf: lava-seco-c61-perf: needs: [linux-seco-imx8mm-c61-4gb-gcc] stage: test - extends: .lava-test + extends: .lava-test-scheduled variables: MACHINE: seco-imx8mm-c61-4gb CI_BUILD_JOB_NAME: linux-seco-imx8mm-c61-4gb-gcc @@ -427,29 +421,12 @@ lava-zephyr-qemu-x86: CI_REPORT_JOB_NAME: lava-report lava-report: + extends: .lava-report needs: - lava-qemu-x86 - lava-qemu-x86_64 - - lava-raspberrypi4-64 - - lava-seco-intel-b68 - - lava-seco-c61 - - lava-qemu-x86-ltp - - lava-qemu-x86_64-ltp - - lava-raspberrypi4-64-ltp - - lava-seco-intel-b68-ltp - - lava-seco-c61-ltp - - lava-qemu-x86-perf - - lava-qemu-x86_64-perf - - lava-raspberrypi4-64-perf - - lava-seco-intel-b68-perf - - lava-seco-c61-perf - - lava-zephyr-96b-nitrogen-twister - lava-zephyr-qemu-cortex-m3 - lava-zephyr-qemu-x86 - - lava-qemu-x86_64-kselftest - - lava-raspberrypi4-64-kselftest - - lava-seco-c61-kselftest - extends: .lava-report lava-badge: needs: [lava-report] diff --git a/.oniro-ci/test-generic.yaml b/.oniro-ci/test-generic.yaml index af9b6a10..5e2dde3c 100644 --- a/.oniro-ci/test-generic.yaml +++ b/.oniro-ci/test-generic.yaml @@ -12,6 +12,7 @@ GIT_STRATEGY: none CI_LAVA_INSTANCE: "https://lava.ostc-eu.org/" CI_SQUAD_INSTANCE: "https://squadp.svc.ostc-eu.dev" + CI_SQUAD_PROJECT_NAME: "oniro-test-mr" # Run the same ltp test suites that using by LKFT project. # Reference: https://qa-reports.linaro.org/lkft/linux-stable-rc-linux-5.10.y/build/v5.10.98-75-g9f5cb871ceb9/testjobs/ LTP_TST_CMDFILES: "cap_bounds cpuhotplug crypto nptl pty securebits fs controllers hugetlb mm tracing containers io dio syscalls math commands ipc fcntl-locktests filecaps fs_bind fs_perms_simple fsx sched cve" @@ -71,8 +72,8 @@ # Submit the jobs to SQUAD. - | for job_def in $(find lava_jobs/ -name "*.yaml"); do - echo $CI_SQUAD_INSTANCE/api/submitjob/oniro-core/$CI_PROJECT_NAME/$CI_PIPELINE_ID/$MACHINE --header "Auth-Token: $CI_SQUAD_TOKEN" --form "backend=oniro_lava" --form "definition=@${job_def}" - curl $CI_SQUAD_INSTANCE/api/submitjob/oniro-core/$CI_PROJECT_NAME/$CI_PIPELINE_ID/$MACHINE --header "Auth-Token: $CI_SQUAD_TOKEN" --form "backend=oniro_lava" --form "definition=@${job_def}" + echo $CI_SQUAD_INSTANCE/api/submitjob/oniro-core/$CI_SQUAD_PROJECT_NAME/$CI_PIPELINE_ID/$MACHINE --header "Auth-Token: $CI_SQUAD_TOKEN" --form "backend=oniro_lava" --form "definition=@${job_def}" + curl $CI_SQUAD_INSTANCE/api/submitjob/oniro-core/$CI_SQUAD_PROJECT_NAME/$CI_PIPELINE_ID/$MACHINE --header "Auth-Token: $CI_SQUAD_TOKEN" --form "backend=oniro_lava" --form "definition=@${job_def}" done # Attach a callback to this build to trigger the lava-report job squad_build_id="$(curl --silent "$CI_SQUAD_INSTANCE/api/builds/?version=$CI_PIPELINE_ID" | jq -r '.results[0].id')" @@ -81,6 +82,8 @@ paths: - lava_jobs/*.yaml rules: + - if: '$CI_SQUAD_TOKEN == null' + when: never # Run the build when it is scheduled. - if: $CI_PIPELINE_SOURCE == "schedule" # Do not run pipelines for draft merge requests unless manually triggered. @@ -113,6 +116,8 @@ fi rules: + - if: '$CI_SQUAD_TOKEN == null' + when: never # Run the build when it is scheduled. - if: $CI_PIPELINE_SOURCE == "schedule" when: manual -- GitLab