From 4e4613d147706cb927fd61c367a701e6145e8993 Mon Sep 17 00:00:00 2001 From: Dmitry Baryshkov Date: Tue, 10 Dec 2024 03:53:03 +0200 Subject: [PATCH] CI: copy build-template from master branch In preparation of the master branch switching to 'kas' (as a part of the ownership transfer), switch the branch to use a local copy of build-template.yml Signed-off-by: Dmitry Baryshkov --- .github/workflows/build-template.yml | 134 +++++++++++++++++++++++++++ .github/workflows/premerge.yml | 2 +- .github/workflows/push.yml | 2 +- 3 files changed, 136 insertions(+), 2 deletions(-) create mode 100644 .github/workflows/build-template.yml diff --git a/.github/workflows/build-template.yml b/.github/workflows/build-template.yml new file mode 100644 index 000000000..be5f705b3 --- /dev/null +++ b/.github/workflows/build-template.yml @@ -0,0 +1,134 @@ +on: + workflow_call: + inputs: + host: + required: true + type: string + images: + required: true + type: string + machines: + required: true + type: string + variants: + required: true + type: string + url: + required: true + type: string + branch: + required: true + type: string + ref: + required: true + type: string + ref_type: + type: string + default: ref + secrets: + TUXSUITE_TOKEN: + required: true + +env: + POKY_URL: https://git.yoctoproject.org/poky + DISTRO: poky + TCLIBC: glibc musl + KERNELS: linaro-qcomlt yocto + +jobs: + build: + name: ${{github.event_name}} - ${{github.ref}} + runs-on: ubuntu-latest + steps: + - name: Set up Python + uses: actions/setup-python@v5 + with: + python-version: "3.x" + - name: Install dependencies + run: | + python -m pip install --upgrade tuxsuite + - name: Setup tux plan + run: | + cat << EOF > plan.yaml + name: CI for ${{github.repository}} + description: ${{github.workflow}} - ${{github.ref}} + version: 1 + + common: &commondata + container: ${{inputs.host}} + envsetup: poky/oe-init-build-env + sources: + git_trees: + - branch: ${{inputs.branch}} + url: $POKY_URL + - ${{inputs.ref_type}}: ${{inputs.ref}} + url: ${{inputs.url}} + distro: $DISTRO + bblayers_conf: + - BBLAYERS += '../$(echo ${{github.repository}} | cut -d'/' -f2)' + artifacts: ["licenses"] + EOF + + for tclibc in ${TCLIBC}; do + for kernel in ${KERNELS}; do + cat << EOF >> plan.yaml + ${tclibc}-${kernel}: &${tclibc}-${kernel} + local_conf: + - INHERIT += 'buildstats buildstats-summary' + - INHERIT:remove = 'rm_work' + - TCLIBC := '${tclibc}' + - PREFERRED_PROVIDER_virtual/kernel := 'linux-${kernel}' + - INITRAMFS_IMAGE ?= 'initramfs-rootfs-image' + + ${tclibc}-${kernel}-noinitramfs: &${tclibc}-${kernel}-noinitramfs + local_conf: + - INHERIT += 'buildstats buildstats-summary' + - INHERIT:remove = 'rm_work' + - TCLIBC := '${tclibc}' + - PREFERRED_PROVIDER_virtual/kernel := 'linux-${kernel}' + + EOF + done + done + + # armv7 machines do not support ESP / UKI + for machine in ${{inputs.machines}}; do + if [ ${machine##qcom-armv8a} == ${machine} ] ; then + images=`echo ${{inputs.images}} | sed -e 's/esp-qcom-image//g'` + else + images="${{inputs.images}}" + fi + cat << EOF >> plan.yaml + ${machine}: &${machine} + machine: ${machine} + target: ${images} + + EOF + done + + cat << EOF >> plan.yaml + jobs: + EOF + + for tclibc in ${TCLIBC}; do + cat << EOF >> plan.yaml + - name: ${tclibc} + bakes: + EOF + for machine in ${{inputs.machines}}; do + for variant in ${{inputs.variants}}; do + [ ${variant##${machine}-${tclibc}} == ${variant} ] && continue + cat << EOF >> plan.yaml + - { <<: [*commondata, *${variant#${machine}-}, *${machine}], name: ${variant} } + EOF + done + done + done + + echo "Ready to submit this Tux Plan:" + cat plan.yaml + - name: Run build + run: | + tuxsuite plan plan.yaml + env: + TUXSUITE_TOKEN: ${{ secrets.TUXSUITE_TOKEN }} diff --git a/.github/workflows/premerge.yml b/.github/workflows/premerge.yml index 995745acf..6dbc6e8e5 100644 --- a/.github/workflows/premerge.yml +++ b/.github/workflows/premerge.yml @@ -5,7 +5,7 @@ on: jobs: build: - uses: Linaro/meta-qcom/.github/workflows/build-template.yml@master + uses: ./.github/workflows/build-template.yml with: host: ubuntu-20.04 images: core-image-base core-image-weston core-image-x11 initramfs-test-image initramfs-test-full-image initramfs-firmware-image initramfs-rootfs-image cryptodev-module diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml index 6503e6034..172c79a63 100644 --- a/.github/workflows/push.yml +++ b/.github/workflows/push.yml @@ -7,7 +7,7 @@ on: jobs: build: - uses: Linaro/meta-qcom/.github/workflows/build-template.yml@master + uses: ./.github/workflows/build-template.yml with: host: ubuntu-20.04 images: core-image-base core-image-weston core-image-x11 initramfs-test-image initramfs-test-full-image initramfs-firmware-image initramfs-rootfs-image cryptodev-module