summaryrefslogtreecommitdiffstats
path: root/.gitlab-ci.yml
blob: 628b0e643d2e65b1229d663213a33fd472a1ba63 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
.before-my-script: &before-my-script
    - echo "$ERR_REPORT_USERNAME" > ~/.oe-send-error
    - echo "$ERR_REPORT_EMAIL" >> ~/.oe-send-error
    - echo "$CI_PROJECT_DIR" >> ~/.ci_project_dir
    - export PATH=~/.local/bin:$PATH
    - python3 -m venv ~/kas_env/
    - source ~/kas_env/bin/activate
    - python3 -m pip install kas
    - mkdir -p $CI_PROJECT_DIR/build/tmp/log/error-report/
    - mkdir -p $CI_PROJECT_DIR/log/

.after-my-script: &after-my-script
    - cd $CI_PROJECT_DIR/poky
    - . ./oe-init-build-env $CI_PROJECT_DIR/build
    - for x in `ls $CI_PROJECT_DIR/build/tmp/log/error-report/ | grep error_report_`; do
    - send-error-report -y tmp/log/error-report/$x
    - done
    - rm -fr $CI_PROJECT_DIR/build

stages:
  - base 
  - parsec
  - musl
  - test

.base:
  before_script:
    - *before-my-script
  stage: base 
  after_script:
    - *after-my-script
  artifacts:
    paths:
      - $CI_PROJECT_DIR/log/*
    when: always

.parsec:
  before_script:
    - *before-my-script
  stage: parsec 
  after_script:
    - *after-my-script

.musl:
  before_script:
    - *before-my-script
  stage: musl
  after_script:
    - *after-my-script

.test:
  before_script:
    - *before-my-script
  stage: test 
  after_script:
    - *after-my-script

qemux86:
  extends: .base
  script:
  - kas shell kas/$CI_JOB_NAME.yml  -c "bitbake -k security-build-image integrity-image-minimal" 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_security_image.txt
  - kas build --target harden-image-minimal kas/$CI_JOB_NAME-harden.yml 2>&1 | tee CI_PROJECT_DIR/log/qemux86_harden_image.txt

qemux86-musl:
  extends: .musl
  needs: ['qemux86']
  script:
  - kas build --target security-build-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_musl_security_image.txt

qemux86-parsec:
  extends: .parsec
  needs: ['qemux86']
  script:
  - kas build --target security-parsec-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_parsec_security_image.txt

qemux86-test:
  extends: .test
  needs: ['qemux86']
  allow_failure: true
  script:
  - kas build --target security-test-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_test_security_image.txt
  - kas build -c testimage --target security-test-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_testimage_security_image.txt

qemux86-64:
  extends: .base
  script:
  - kas shell kas/$CI_JOB_NAME.yml  -c "bitbake -k core-image-minimal security-build-image security-tpm-image security-tpm2-image integrity-image-minimal" 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_64_security_image.txt
  - kas build --target dm-verity-image-initramfs kas/$CI_JOB_NAME-dm-verify.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_64_dm_verify.txt
  - kas build --target security-build-image kas/$CI_JOB_NAME-alt.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_64_security_build_image.txt

qemux86-64-parsec:
  extends: .parsec
  needs: ['qemux86-64']
  script:
  - kas build --target security-parsec-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemux86_64_parsec_security_image.txt

qemuarm:
  extends: .base
  script:
  - kas build --target security-build-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemuarm_security_image.txt

qemuarm-parsec:
  extends: .parsec
  needs: ['qemuarm']
  script:
  - kas build --target security-parsec-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemuarm_parsec_security_image.txt

qemuarm64:
  extends: .base
  script:
  - kas shell kas/$CI_JOB_NAME.yml  -c "bitbake -k security-build-image security-tpm2-image integrity-image-minimal" 2>&1 | tee $CI_PROJECT_DIR/log/qemuarm64_parsec_security_image.txt
  - kas build --target security-build-image kas/$CI_JOB_NAME-alt.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemuarm64_build_security_image.txt

qemuarm64-musl:
  extends: .musl
  needs: ['qemuarm64']
  script:
  - kas build --target security-build-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemuarm64_musl_security_image.txt

qemuarm64-parsec:
  extends: .parsec
  needs: ['qemuarm64']
  script:
  - kas build --target security-parsec-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemuarm64_parsec_security_image.txt

qemuriscv64:
  extends: .base
  script:
  - kas build --target security-build-image kas/$CI_JOB_NAME.yml 2>&1 | tee $CI_PROJECT_DIR/log/qemuriscv64_security_image.txt