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