Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix CI on the honister branch #696

Merged
merged 2 commits into from
Dec 10, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
134 changes: 134 additions & 0 deletions .github/workflows/build-template.yml
Original file line number Diff line number Diff line change
@@ -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 }}
6 changes: 5 additions & 1 deletion .github/workflows/premerge.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,15 @@ on:

jobs:
build:
uses: ndechesne/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 cryptodev-module
machines: dragonboard-410c qcom-armv8a sdx55-mtp
variants: >-
dragonboard-410c-glibc-linaro-qcomlt dragonboard-410c-musl-linaro-qcomlt
qcom-armv8a-glibc-linaro-qcomlt qcom-armv8a-musl-linaro-qcomlt
sdx55-mtp-glibc-linaro-qcomlt sdx55-mtp-musl-linaro-qcomlt
ref: refs/pull/${{github.event.pull_request.number}}/merge
branch: ${{github.base_ref}}
url: ${{github.server_url}}/${{github.repository}}
Expand Down
6 changes: 5 additions & 1 deletion .github/workflows/push.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,15 @@ on:

jobs:
build:
uses: ndechesne/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 cryptodev-module
machines: dragonboard-410c qcom-armv8a sdx55-mtp
variants: >-
dragonboard-410c-glibc-linaro-qcomlt dragonboard-410c-musl-linaro-qcomlt
qcom-armv8a-glibc-linaro-qcomlt qcom-armv8a-musl-linaro-qcomlt
sdx55-mtp-glibc-linaro-qcomlt sdx55-mtp-musl-linaro-qcomlt
ref: ${{github.sha}}
ref_type: sha
branch: ${{github.ref_name}}
Expand Down