From d19cc749b6a296aad6243691f2ff93b88fa242be Mon Sep 17 00:00:00 2001 From: Stefan Schmidt <stefan.schmidt@huawei.com> Date: Fri, 7 Oct 2022 21:42:38 +0200 Subject: [PATCH] ci: remove upstream CI to avoid conflicts with Oniro downstream CI Upstream started to use its own gitlab CI pipeline which do conflict with ours on the Oniro side. To avoid this the only real option is to remove the upstream CI configuration and carry this patch in our fork. Signed-off-by: Stefan Schmidt <stefan.schmidt@huawei.com> --- .gitlab-ci.yml | 90 -------------------------------------- ci/96b-avenger96.yml | 6 --- ci/96b-nitrogen.yml | 20 --------- ci/arduino-nano-33-ble.yml | 21 --------- ci/base.yml | 38 ---------------- ci/check-machine-coverage | 26 ----------- ci/check-warnings | 19 -------- ci/intel-x86-64.yml | 6 --- ci/jobs-to-kas | 19 -------- ci/logging.yml | 13 ------ ci/meta-openembedded.yml | 11 ----- ci/nrf52840dk-nrf52840.yml | 20 --------- ci/qemu-cortex-m3.yml | 12 ----- ci/qemu-nios2.yml | 10 ----- ci/qemu-x86.yml | 10 ----- ci/stm32mp157c-dk2.yml | 13 ------ ci/testimage.yml | 9 ---- ci/update-repos | 40 ----------------- 18 files changed, 383 deletions(-) delete mode 100644 .gitlab-ci.yml delete mode 100644 ci/96b-avenger96.yml delete mode 100644 ci/96b-nitrogen.yml delete mode 100644 ci/arduino-nano-33-ble.yml delete mode 100644 ci/base.yml delete mode 100755 ci/check-machine-coverage delete mode 100755 ci/check-warnings delete mode 100644 ci/intel-x86-64.yml delete mode 100755 ci/jobs-to-kas delete mode 100644 ci/logging.yml delete mode 100644 ci/meta-openembedded.yml delete mode 100644 ci/nrf52840dk-nrf52840.yml delete mode 100644 ci/qemu-cortex-m3.yml delete mode 100644 ci/qemu-nios2.yml delete mode 100644 ci/qemu-x86.yml delete mode 100644 ci/stm32mp157c-dk2.yml delete mode 100644 ci/testimage.yml delete mode 100755 ci/update-repos diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml deleted file mode 100644 index 8d22654..0000000 --- a/.gitlab-ci.yml +++ /dev/null @@ -1,90 +0,0 @@ -image: ghcr.io/siemens/kas/kas:latest-release - -stages: - - prep - - build - -# Common job fragment to get a worker ready -.setup: - stage: build - interruptible: true - variables: - KAS_WORK_DIR: $CI_PROJECT_DIR/work - KAS_REPO_REF_DIR: $CI_BUILDS_DIR/persist/repos - SSTATE_DIR: $CI_BUILDS_DIR/persist/sstate - DL_DIR: $CI_BUILDS_DIR/persist/downloads - BB_LOGCONFIG: $CI_PROJECT_DIR/ci/logging.yml - before_script: - - echo KAS_WORK_DIR = $KAS_WORK_DIR - - echo SSTATE_DIR = $SSTATE_DIR - - echo DL_DIR = $DL_DIR - - rm -rf $KAS_WORK_DIR - - mkdir --verbose --parents $KAS_WORK_DIR $KAS_REPO_REF_DIR $SSTATE_DIR $DL_DIR - -# Generalised fragment to do a Kas build -.build: - extends: .setup - script: - - KASFILES=$(./ci/jobs-to-kas "$CI_JOB_NAME") - - kas shell --update --force-checkout $KASFILES -c 'cat conf/*.conf' - - kas build $KASFILES - - ./ci/check-warnings $KAS_WORK_DIR/build/warnings.log - artifacts: - name: "logs" - when: on_failure - paths: - - $CI_PROJECT_DIR/work/build/tmp/work*/**/temp/log.do_*.* - -# -# Prep stage, update repositories once -# -update-repos: - extends: .setup - stage: prep - script: - - flock --verbose --timeout 60 $KAS_REPO_REF_DIR ./ci/update-repos - - -# -# Bootstrap stage, machine coverage -# - -# What percentage of machines in the layer do we build -machine-coverage: - stage: prep - interruptible: true - script: - - ./ci/check-machine-coverage - coverage: '/Coverage: \d+/' - - -# -# Build stage, the actual build jobs -# - -96b-avenger96: - extends: .build - -96b-nitrogen: - extends: .build - -arduino-nano-33-ble: - extends: .build - -intel-x86-64: - extends: .build - -nrf52840dk-nrf52840: - extends: .build - -qemu-cortex-m3/testimage: - extends: .build - -qemu-nios2: - extends: .build - -qemu-x86/testimage: - extends: .build - -stm32mp157c-dk2: - extends: .build diff --git a/ci/96b-avenger96.yml b/ci/96b-avenger96.yml deleted file mode 100644 index bcdccf3..0000000 --- a/ci/96b-avenger96.yml +++ /dev/null @@ -1,6 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -machine: 96b-avenger96 diff --git a/ci/96b-nitrogen.yml b/ci/96b-nitrogen.yml deleted file mode 100644 index 9b685fe..0000000 --- a/ci/96b-nitrogen.yml +++ /dev/null @@ -1,20 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -machine: 96b-nitrogen - -target: - - zephyr-blinky - - zephyr-coap-client - - zephyr-coap-server - - zephyr-echo-client - - zephyr-hci-uart - - zephyr-helloworld - - zephyr-http-client - - zephyr-kernel-test-all - - zephyr-mqtt-publisher - - zephyr-peripheral-esp - - zephyr-peripheral-hr - - zephyr-philosophers diff --git a/ci/arduino-nano-33-ble.yml b/ci/arduino-nano-33-ble.yml deleted file mode 100644 index 1035118..0000000 --- a/ci/arduino-nano-33-ble.yml +++ /dev/null @@ -1,21 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -machine: arduino-nano-33-ble - -target: - - zephyr-blinky - - zephyr-coap-client - - zephyr-coap-server - - zephyr-echo-client - - zephyr-helloworld - - zephyr-http-client - - zephyr-kernel-test-all - - zephyr-mqtt-publisher - - zephyr-openthread-echo-client - - zephyr-openthread-rcp - - zephyr-peripheral-esp - - zephyr-peripheral-hr - - zephyr-philosophers diff --git a/ci/base.yml b/ci/base.yml deleted file mode 100644 index bab03d3..0000000 --- a/ci/base.yml +++ /dev/null @@ -1,38 +0,0 @@ -header: - version: 11 - includes: - - ci/meta-openembedded.yml - -distro: zephyr - -defaults: - repos: - refspec: kirkstone - -repos: - meta-zephyr: - layers: - meta-zephyr-core: - meta-zephyr-bsp: - - poky: - url: https://git.yoctoproject.org/git/poky - layers: - meta: - meta-poky: - -env: - BB_LOGCONFIG: "" - -local_conf_header: - base: | - BB_SERVER_TIMEOUT = "60" - CONF_VERSION = "2" - INHERIT += "rm_work" - -machine: unset - -target: - - zephyr-helloworld - - zephyr-kernel-test-all - - zephyr-philosophers diff --git a/ci/check-machine-coverage b/ci/check-machine-coverage deleted file mode 100755 index 19f9571..0000000 --- a/ci/check-machine-coverage +++ /dev/null @@ -1,26 +0,0 @@ -#! /usr/bin/env python3 - -from pathlib import Path -import sys - -metazephyr = Path.cwd() - -if metazephyr.name != "meta-zephyr": - print("Not running inside meta-zephyr") - sys.exit(1) - -# All machine configurations -machines = metazephyr.glob("meta-zephyr-bsp/conf/machine/*.conf") -machines = set(p.stem for p in machines) - -# All kas files -kas = metazephyr.glob("ci/*.yml") -kas = set(p.stem for p in kas) - -missing = machines - kas -print(f"The following machines are missing: {', '.join(sorted(missing))}.") - -covered = len(machines) - len(missing) -total = len(machines) -percent = int(covered / total * 100) -print(f"Coverage: {percent}%") diff --git a/ci/check-warnings b/ci/check-warnings deleted file mode 100755 index 9d08010..0000000 --- a/ci/check-warnings +++ /dev/null @@ -1,19 +0,0 @@ -#! /bin/bash - -# Expects the path to a log file as $1, and if this file has any content -# then display the contents and exit with an error code. - -set -e -u - -LOGFILE=$1 - -LINES=$(grep --invert-match "relocations in \.text" $LOGFILE | wc -l) -if test "$LINES" -ne 0; then - echo ============================== - echo The build had warnings/errors: - echo ============================== - cat $LOGFILE - exit 1 -fi - -exit 0 diff --git a/ci/intel-x86-64.yml b/ci/intel-x86-64.yml deleted file mode 100644 index 23e711c..0000000 --- a/ci/intel-x86-64.yml +++ /dev/null @@ -1,6 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -machine: intel-x86-64 diff --git a/ci/jobs-to-kas b/ci/jobs-to-kas deleted file mode 100755 index 7057970..0000000 --- a/ci/jobs-to-kas +++ /dev/null @@ -1,19 +0,0 @@ -#! /bin/bash - -# Read a GitLab CI job name on $1 and transform it to a -# list of Kas yaml files - -set -e -u - -# Read Job namne from $1 and split on / -IFS=/ read -r -a PARTS<<<$1 - -# Prefix each part with ci/ -PARTS=("${PARTS[@]/#/ci/}") - -# Suffix each part with .yml -PARTS=("${PARTS[@]/%/.yml}") - -# Print colon-separated -IFS=":" -echo "${PARTS[*]}" diff --git a/ci/logging.yml b/ci/logging.yml deleted file mode 100644 index 3af1029..0000000 --- a/ci/logging.yml +++ /dev/null @@ -1,13 +0,0 @@ -# Python logging configuration to write all warnings to a separate file -version: 1 - -handlers: - warnings: - class: logging.FileHandler - level: WARNING - filename: warnings.log - formatter: BitBake.logfileFormatter - -loggers: - BitBake: - handlers: [warnings] diff --git a/ci/meta-openembedded.yml b/ci/meta-openembedded.yml deleted file mode 100644 index bed338d..0000000 --- a/ci/meta-openembedded.yml +++ /dev/null @@ -1,11 +0,0 @@ -header: - version: 11 - -repos: - meta-openembedded: - url: https://git.openembedded.org/meta-openembedded - layers: - meta-filesystems: - meta-networking: - meta-oe: - meta-python: diff --git a/ci/nrf52840dk-nrf52840.yml b/ci/nrf52840dk-nrf52840.yml deleted file mode 100644 index a0c1587..0000000 --- a/ci/nrf52840dk-nrf52840.yml +++ /dev/null @@ -1,20 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -machine: nrf52840dk-nrf52840 - -target: - - zephyr-blinky - - zephyr-coap-client - - zephyr-coap-server - - zephyr-echo-client - - zephyr-helloworld - - zephyr-http-client - - zephyr-kernel-test-all - - zephyr-lvgl - - zephyr-mqtt-publisher - - zephyr-peripheral-esp - - zephyr-peripheral-hr - - zephyr-philosophers diff --git a/ci/qemu-cortex-m3.yml b/ci/qemu-cortex-m3.yml deleted file mode 100644 index b01480c..0000000 --- a/ci/qemu-cortex-m3.yml +++ /dev/null @@ -1,12 +0,0 @@ -header: - version: 11 - includes: - - ci/base.yml - -local_conf_header: - nonbuilding_tests: | - ZEPHYRTESTS:remove = "common context pending poll sleep" - qemu_opts: | - QB_OPT_APPEND = "-icount shift=3,align=off,sleep=on -rtc clock=vm" - -machine: qemu-cortex-m3 diff --git a/ci/qemu-nios2.yml b/ci/qemu-nios2.yml deleted file mode 100644 index b818371..0000000 --- a/ci/qemu-nios2.yml +++ /dev/null @@ -1,10 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -local_conf_header: - nonbuilding_tests: | - ZEPHYRTESTS:remove = "interrupt" - -machine: qemu-nios2 diff --git a/ci/qemu-x86.yml b/ci/qemu-x86.yml deleted file mode 100644 index df744a1..0000000 --- a/ci/qemu-x86.yml +++ /dev/null @@ -1,10 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -local_conf_header: - failing_tests: | - ZEPHYRTESTS:remove = "pending" - -machine: qemu-x86 diff --git a/ci/stm32mp157c-dk2.yml b/ci/stm32mp157c-dk2.yml deleted file mode 100644 index 3dc04a5..0000000 --- a/ci/stm32mp157c-dk2.yml +++ /dev/null @@ -1,13 +0,0 @@ -header: - version: 9 - includes: - - ci/base.yml - -machine: stm32mp157c-dk2 - -target: - - zephyr-blinky - - zephyr-helloworld - - zephyr-kernel-test-all - - zephyr-philosophers - - zephyr-openamp-rsc-table diff --git a/ci/testimage.yml b/ci/testimage.yml deleted file mode 100644 index 83e17a7..0000000 --- a/ci/testimage.yml +++ /dev/null @@ -1,9 +0,0 @@ -header: - version: 11 - -local_conf_header: - testimage: | - IMAGE_CLASSES += "testimage" - TEST_TARGET = "QemuTargetZephyr" - TEST_SUITES = "zephyr" - TESTIMAGE_AUTO = "1" diff --git a/ci/update-repos b/ci/update-repos deleted file mode 100755 index fa638aa..0000000 --- a/ci/update-repos +++ /dev/null @@ -1,40 +0,0 @@ -#! /usr/bin/env python3 - -# Update clones of the repositories we need in KAS_REPO_REF_DIR to speed up fetches - -import sys -import os -import subprocess -import pathlib - -def repo_shortname(url): - # Taken from Kas (Repo.__getattr__) to ensure the logic is right - from urllib.parse import urlparse - url = urlparse(url) - return ('{url.netloc}{url.path}' - .format(url=url) - .replace('@', '.') - .replace(':', '.') - .replace('/', '.') - .replace('*', '.')) - -repositories = ( - "https://git.yoctoproject.org/git/poky", - "https://git.openembedded.org/meta-openembedded", -) - -if __name__ == "__main__": - if "KAS_REPO_REF_DIR" not in os.environ: - print("KAS_REPO_REF_DIR needs to be set") - sys.exit(1) - - base_repodir = pathlib.Path(os.environ["KAS_REPO_REF_DIR"]) - - for repo in repositories: - repodir = base_repodir / repo_shortname(repo) - if repodir.exists(): - print("Updating %s..." % repo) - subprocess.run(["git", "-C", repodir, "fetch"], check=True) - else: - print("Cloning %s..." % repo) - subprocess.run(["git", "clone", "--bare", repo, repodir], check=True) -- GitLab