Simplify workflow: single job loop over changed specs

Remove the overcomplicated two-job dynamic matrix setup.
Now a single job determines changed specs with git diff and loops
over them sequentially. Much simpler and less error-prone.
This commit is contained in:
Anders da Silva Rytter Hansen 2026-05-27 15:03:53 -03:00
commit 80b2b48515

View file

@ -7,112 +7,75 @@ on:
workflow_dispatch: workflow_dispatch:
jobs: jobs:
changed: build:
runs-on: almalinux-10 runs-on: almalinux-10
outputs:
matrix: ${{ steps.set.outputs.matrix }}
steps: steps:
- name: Checkout - uses: actions/checkout@v4
uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0
- name: Determine changed specs - name: Determine changed specs
id: set id: changed
run: | run: |
if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then
python3 -c "import json; print(json.dumps({'spec': ['sonic-interface-libraries.spec','sonic-win.spec','sonic-workspace.spec']}))" SPECS="sonic-interface-libraries.spec sonic-win.spec sonic-workspace.spec"
else else
CHANGED=$(git diff --name-only ${{ github.event.before }} ${{ github.sha }} | grep '\.spec$' || true) SPECS=$(git diff --name-only ${{ github.event.before }} ${{ github.sha }} | grep '\.spec$' || true)
python3 -c "import json, sys; print(json.dumps({'spec': sys.argv[1].split()}))" "$CHANGED" fi
fi >> "$GITHUB_OUTPUT" echo "specs=$SPECS" >> "$GITHUB_OUTPUT"
build:
needs: changed
runs-on: almalinux-10
strategy:
fail-fast: false
matrix: ${{ fromJSON(needs.changed.outputs.matrix) }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install build tools - name: Install build tools
run: | run: |
dnf install -y \ dnf install -y rpm-build rpmdevtools mock curl
rpm-build \ usermod -aG mock $(whoami) || true
rpmdevtools \
mock \
curl
- name: Add runner user to mock group
run: usermod -aG mock $(whoami) || true
- name: Setup RPM build tree - name: Setup RPM build tree
run: rpmdev-setuptree run: rpmdev-setuptree
- name: Download sources for ${{ matrix.spec }} - name: Build changed specs
run: |
spectool -g -C ~/rpmbuild/SOURCES/ ${{ matrix.spec }}
- name: Build SRPM from ${{ matrix.spec }}
run: |
rpmbuild -bs \
--define "_topdir ${HOME}/rpmbuild" \
--define "_disable_source_fetch 0" \
${{ matrix.spec }}
PKGNAME=$(rpmspec -q --srpm --queryformat "%{NAME}-%{VERSION}-%{RELEASE}.src.rpm" ${{ matrix.spec }})
echo "SRPM_PATH=${HOME}/rpmbuild/SRPMS/${PKGNAME}" >> "$GITHUB_ENV"
- name: Build RPM with mock
run: |
cat > /tmp/mock-custom.cfg <<'MOCKEOF'
include('/etc/mock/alma+epel-10-x86_64.cfg')
config_opts['root'] = 'custom'
config_opts['yum.conf'] += """
[sonicde-rpm]
name=SonicDE RPM
baseurl=https://pc-rytteren.dk/forge/api/packages/anders/rpm
enabled=1
gpgcheck=0
[xlibre-xserver]
name=Copr xlibre-xserver
baseurl=https://download.copr.fedorainfracloud.org/results/@xlibre/xlibre-xserver/rhel+epel-10-$basearch/
type=rpm-md
skip_if_unavailable=True
gpgcheck=1
gpgkey=https://download.copr.fedorainfracloud.org/results/@xlibre/xlibre-xserver/pubkey.gpg
repo_gpgcheck=0
enabled=1
"""
MOCKEOF
cp /tmp/mock-custom.cfg /etc/mock/custom.cfg
mock --root custom --scrub=chroot || true
mock \
--root custom \
--resultdir "${HOME}/mock-results" \
--clean \
--rebuild "${{ env.SRPM_PATH }}"
- name: Upload RPMs to Forgejo Package Registry
run: | run: |
FORGEJO_URL="${{ github.server_url }}" FORGEJO_URL="${{ github.server_url }}"
OWNER="${{ github.repository_owner }}" OWNER="${{ github.repository_owner }}"
TOKEN="${{ secrets.PACKAGE_TOKEN }}" TOKEN="${{ secrets.PACKAGE_TOKEN }}"
find "${HOME}/mock-results" -name "*.rpm" ! -name "*.src.rpm" | while read rpm; do for spec in ${{ steps.changed.outputs.specs }}; do
FILENAME=$(basename "$rpm") echo "=== Building $spec ==="
echo "Uploading $FILENAME ..." spectool -g -C ~/rpmbuild/SOURCES/ "$spec"
curl --fail-with-body \ rpmbuild -bs --define "_topdir ${HOME}/rpmbuild" --define "_disable_source_fetch 0" "$spec"
--user "${OWNER}:${TOKEN}" \ PKGNAME=$(rpmspec -q --srpm --queryformat "%{NAME}-%{VERSION}-%{RELEASE}.src.rpm" "$spec")
--upload-file "$rpm" \ SRPM="${HOME}/rpmbuild/SRPMS/${PKGNAME}"
"${FORGEJO_URL}/api/packages/${OWNER}/rpm/upload"
done
- name: Clean up build artifacts cat > /tmp/mock-custom.cfg <<'MOCKEOF'
if: always() include('/etc/mock/alma+epel-10-x86_64.cfg')
run: | config_opts['root'] = 'custom'
rm -rf "${HOME}/mock-results" config_opts['yum.conf'] += """
rm -rf "${HOME}/rpmbuild/SRPMS" [sonicde-rpm]
name=SonicDE RPM
baseurl=https://pc-rytteren.dk/forge/api/packages/anders/rpm
enabled=1
gpgcheck=0
[xlibre-xserver]
name=Copr xlibre-xserver
baseurl=https://download.copr.fedorainfracloud.org/results/@xlibre/xlibre-xserver/rhel+epel-10-$basearch/
type=rpm-md
skip_if_unavailable=True
gpgcheck=1
gpgkey=https://download.copr.fedorainfracloud.org/results/@xlibre/xlibre-xserver/pubkey.gpg
repo_gpgcheck=0
enabled=1
"""
MOCKEOF
cp /tmp/mock-custom.cfg /etc/mock/custom.cfg
mock --root custom --scrub=chroot || true
mock --root custom --resultdir "${HOME}/mock-results" --clean --rebuild "$SRPM"
find "${HOME}/mock-results" -name "*.rpm" ! -name "*.src.rpm" | while read rpm; do
FILENAME=$(basename "$rpm")
echo "Uploading $FILENAME ..."
curl --fail-with-body --user "${OWNER}:${TOKEN}" --upload-file "$rpm" "${FORGEJO_URL}/api/packages/${OWNER}/rpm/upload"
done
rm -rf "${HOME}/mock-results"
rm -rf "${HOME}/rpmbuild/SRPMS"
done