summaryrefslogtreecommitdiffstats
path: root/.github/workflows/crossbuild.yml
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-08-26 10:41:53 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-08-26 10:41:53 +0000
commit1526b335a5a81d945e64291e2fbcf92f72d15a4e (patch)
tree64d3bc5d36df06664cc49d7c4d8710100e23b888 /.github/workflows/crossbuild.yml
parentReleasing progress-linux version 3.2.3+dfsg-2~progress7.99u1. (diff)
downloadfreeradius-1526b335a5a81d945e64291e2fbcf92f72d15a4e.tar.xz
freeradius-1526b335a5a81d945e64291e2fbcf92f72d15a4e.zip
Merging upstream version 3.2.5+dfsg.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '.github/workflows/crossbuild.yml')
-rw-r--r--.github/workflows/crossbuild.yml91
1 files changed, 91 insertions, 0 deletions
diff --git a/.github/workflows/crossbuild.yml b/.github/workflows/crossbuild.yml
new file mode 100644
index 0000000..d3d9186
--- /dev/null
+++ b/.github/workflows/crossbuild.yml
@@ -0,0 +1,91 @@
+name: Check Crossbuild
+
+on:
+ push:
+ branches-ignore:
+ - coverity_scan
+ workflow_dispatch:
+
+env:
+ CI: 1
+ GH_ACTIONS: 1
+ DEBIAN_FRONTEND: noninteractive
+ APT_OPTS: "-y --no-install-recommends"
+
+jobs:
+ #
+ # Generate matrix based on crossbuild docker directories.
+ #
+ gen-matrix:
+
+ runs-on: ubuntu-latest
+
+ outputs:
+ matrix: ${{ steps.gen-matrix.outputs.matrix }}
+
+ steps:
+
+ - uses: actions/checkout@v4
+ with:
+ lfs: false
+
+ - id: gen-matrix
+ name: Generate matrix based on crossbuild targets
+ run: |
+ cd scripts/crossbuild/docker
+ M=$(ls | perl -n -e '{chomp; push @L,"\"$_\""} END{print "{\"env\":[{\"OS\":",join("},{\"OS\":",@L),"}]}"}')
+ echo "Matrix: $M"
+ echo matrix=$M >> $GITHUB_OUTPUT
+
+ #
+ # Run crossbuild target for each given OS. This will build the
+ # Docker image and run `make test` inside.
+ #
+ crossbuild:
+ needs:
+ - gen-matrix
+
+ runs-on: ubuntu-20.04
+
+ strategy:
+ fail-fast: false
+ matrix: ${{ fromJson(needs.gen-matrix.outputs.matrix) }}
+
+ env: ${{ matrix.env }}
+
+ name: "v3.2.x-${{ matrix.env.OS }}"
+
+ steps:
+
+ - uses: actions/checkout@v4
+ with:
+ fetch-depth: 0${{ ( matrix.env.OS != 'centos7' ) && '1' }}
+
+ - name: Run crossbuild tests
+ run: |
+ make crossbuild.$OS
+
+ - name: Show build log
+ if: ${{ success() || failure() }}
+ run: |
+ cat scripts/crossbuild/build/build.$OS
+
+ - name: Show configure log
+ if: ${{ success() || failure() }}
+ run: |
+ cat scripts/crossbuild/build/configure.$OS
+
+ - name: Show test log
+ if: ${{ success() || failure() }}
+ run: |
+ cat scripts/crossbuild/build/log.$OS
+
+ #
+ # If the CI has failed and the branch is ci-debug then start a tmate
+ # session. SSH rendezvous point is emited continuously in the job output.
+ #
+ - name: "Debug: Start tmate"
+ uses: mxschmitt/action-tmate@v3
+ with:
+ limit-access-to-actor: true
+ if: ${{ github.ref == 'refs/heads/ci-debug' && failure() }}