summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.gitlab-ci.yml46
-rw-r--r--scripts/ci/Dockerfile.checkout9
-rwxr-xr-xscripts/ci/checkout-oe.sh38
3 files changed, 93 insertions, 0 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
new file mode 100644
index 0000000..642a156
--- /dev/null
+++ b/.gitlab-ci.yml
@@ -0,0 +1,46 @@
1stages:
2 - docker
3 - checkout
4 - test
5
6# notes:
7# - could be useful https://docs.gitlab.com/ee/ci/yaml/#include
8
9variables:
10 BITBAKE_MASTER_IMAGE: ${CI_REGISTRY_IMAGE}:ci-master-bitbake
11 BITBAKE_PR_IMAGE: ${CI_REGISTRY_IMAGE}:ci-${CI_COMMIT_REF_SLUG}-bitbake
12
13 CHECKOUT_MASTER_IMAGE: ${CI_REGISTRY_IMAGE}:ci-master-xml
14 CHECKOUT_PR_IMAGE: ${CI_REGISTRY_IMAGE}:ci-${CI_COMMIT_REF_SLUG}-xml
15
16 UPDATER_REPO: https://main.gitlab.in.here.com/olp/edge/ota/connect/client/updater-repo
17
18
19Docker Setup:
20 stage: docker
21 before_script:
22 - docker login -u gitlab-ci-token -p "$CI_JOB_TOKEN" "$CI_REGISTRY"
23 script:
24 - docker pull "$BITBAKE_PR_IMAGE" || docker pull "$BITBAKE_MASTER_IMAGE" || true
25 - docker build --pull --cache-from "$BITBAKE_MASTER_IMAGE" --cache-from "$BITBAKE_PR_IMAGE" -f ./scripts/ci/Dockerfile.bitbake -t "$BITBAKE_PR_IMAGE" ./scripts/ci
26 - docker push "$BITBAKE_PR_IMAGE"
27
28 - docker pull "$CHECKOUT_PR_IMAGE" || docker pull "$CHECKOUT_MASTER_IMAGE" || true
29 - docker build --pull --cache-from "$CHECKOUT_MASTER_IMAGE" --cache-from "$CHECKOUT_PR_IMAGE" -f ./scripts/ci/Dockerfile.checkout -t "$CHECKOUT_PR_IMAGE" ./scripts/ci
30 - docker push "$CHECKOUT_PR_IMAGE"
31
32Checkout:
33 image: "$CHECKOUT_PR_IMAGE"
34 stage: checkout
35 artifacts:
36 paths:
37 - updater-repo
38 script:
39 - ./scripts/ci/checkout-oe.sh
40
41Build core-image-minimal:
42 image: "$BITBAKE_PR_IMAGE"
43 stage: test
44 script:
45 - ./scripts/ci/configure.sh
46 - ./scripts/ci/build.sh core-image-minimal
diff --git a/scripts/ci/Dockerfile.checkout b/scripts/ci/Dockerfile.checkout
new file mode 100644
index 0000000..55dcff9
--- /dev/null
+++ b/scripts/ci/Dockerfile.checkout
@@ -0,0 +1,9 @@
1FROM debian:stable-slim
2LABEL Description="Image for checking out updater-repo"
3
4RUN sed -i 's#deb http://deb.debian.org/debian stable main#deb http://deb.debian.org/debian stable main contrib#g' /etc/apt/sources.list
5RUN sed -i 's#deb http://deb.debian.org/debian stable-updates main#deb http://deb.debian.org/debian stable-updates main contrib#g' /etc/apt/sources.list
6RUN apt-get update -q && apt-get install -qy \
7 git \
8 repo \
9 xmlstarlet
diff --git a/scripts/ci/checkout-oe.sh b/scripts/ci/checkout-oe.sh
new file mode 100755
index 0000000..b073d3e
--- /dev/null
+++ b/scripts/ci/checkout-oe.sh
@@ -0,0 +1,38 @@
1#!/usr/bin/env bash
2
3set -euo pipefail
4
5set -x
6
7REMOTE_SOURCE=${REMOTE_SOURCE:-https://github.com/advancedtelematic}
8MANIFEST=${MANIFEST:-master}
9CURRENT_PROJECT=${CURRENT_PROJECT:-meta-updater}
10
11#CURRENT_REV=$(git rev-parse HEAD)
12LOCAL_REPO=$PWD
13
14mkdir -p updater-repo
15
16cd updater-repo
17
18repo init -m "${MANIFEST}.xml" -u "$REMOTE_SOURCE/updater-repo"
19
20git -C .repo/manifests reset --hard
21
22# patch manifest
23MANIFEST_FILE=".repo/manifests/${MANIFEST}.xml"
24xmlstarlet ed --omit-decl -L \
25 -s "/manifest" -t elem -n "remote" -v "" \
26 -i "/manifest/remote[last()]" -t attr -n "name" -v "ats" \
27 -i "/manifest/remote[last()]" -t attr -n "fetch" -v "$REMOTE_SOURCE" \
28 -u "/manifest/project[contains(@name, 'advancedtelematic')]/@remote" -v "ats" \
29 -d "/manifest/project[@path=\"$CURRENT_PROJECT\"]" \
30 "$MANIFEST_FILE"
31
32# hack: sed on `advancedtelematic/` names
33sed -i 's#name="advancedtelematic/#name="#g' "$MANIFEST_FILE"
34
35repo sync --force-sync
36
37rm -f "$CURRENT_PROJECT"
38ln -s "$LOCAL_REPO" "$CURRENT_PROJECT"