-
Notifications
You must be signed in to change notification settings - Fork 43
105 lines (96 loc) · 2.98 KB
/
release_build.yaml
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
name: Release Build
on:
push:
tags:
- 'v[0-9].[0-9]+.[0-9]+'
jobs:
build-matrix:
name: Build matrix
runs-on: ubuntu-22.04
steps:
- name: Checkout
uses: actions/checkout@v4
- id: set-matrix
name: Collect all tests
run: |
tests="$(find .github/tests -maxdepth 1 -type f -name '*.sh' -exec basename {} \; | sort | uniq)"
tests_json="$(echo "$tests" | jq -c --slurp --raw-input 'split("\n") | map(select(. != ""))')"
echo "tests=$tests_json" >> $GITHUB_OUTPUT
echo "Collected tests: $tests_json"
outputs:
tests: ${{ steps.set-matrix.outputs.tests }}
integration-tests:
runs-on: ubuntu-22.04
needs: [build-matrix]
permissions:
contents: read
strategy:
matrix:
tests: ${{ fromJson(needs.build-matrix.outputs.tests) }}
steps:
- uses: actions/checkout@v4
- name: Build containers
run: ./build.sh
shell: bash
working-directory: ./.github/tests/it
- name: Run tests
run: bash ${{ matrix.tests }}
shell: bash
working-directory: ./.github/tests
build:
name: build (linux)
runs-on: ubuntu-22.04
needs: integration-tests
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup go
uses: actions/setup-go@v5
with:
go-version-file: 'go.mod'
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build artifact
run: make build
- name: Build docker artifact
run: make docker-build
- name: Compress artifact
run: tar -czvf spiffe-helper-${{ github.ref_name }}.tar.gz spiffe-helper
- name: Archive artifact
uses: actions/upload-artifact@v4
with:
name: spiffe-helper
path: |
spiffe-helper-${{ github.ref_name }}.tar.gz
spiffe-helper-image.tar
release:
runs-on: ubuntu-22.04
needs: build
permissions:
contents: write
packages: write
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download archived artifact
uses: actions/download-artifact@v4
with:
name: spiffe-helper
path: .
- name: Log in to GHCR
uses: docker/[email protected]
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Install regctl
uses: regclient/actions/regctl-installer@main
- name: Push docker image
run: ./.github/workflows/scripts/push-images.sh ${{ github.ref_name }}
- name: Create Release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# Create the release using the version number as the title
run: gh release create "${GITHUB_REF#refs/tags/}" ./spiffe-helper-${{ github.ref_name }}.tar.gz --title "${GITHUB_REF#refs/tags/}"