-
Notifications
You must be signed in to change notification settings - Fork 5
160 lines (153 loc) · 4.78 KB
/
on-push.yml
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
name: On push
on:
push:
branches-ignore:
- release
paths:
- 'src/*'
- 'tests/*'
- 'Dockerfile'
workflow_dispatch:
env:
PLATFORMS: "linux/386,linux/amd64,linux/arm/v6,linux/arm/v7,linux/arm64/v8,linux/ppc64le,linux/riscv64,linux/s390x"
jobs:
shellcheck:
name: shellcheck
runs-on: ubuntu-latest
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Install shellcheck
run: sudo apt-get install -y bash shellcheck
- name: Analyse with shellcheck
run: |
set -e
shellcheck -V
shellcheck src/*.sh tests/*.sh
set +e
tests:
name: Run tests
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
test_suit:
- test_new_image_
- test_SERVICES_
- test_jobs_
- test_MANIFEST_
- test_no_running_tasks_
- test_rollback_
- test_options_
- test_login_
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/[email protected]
- name: Login to GitHub Container Registry
uses: docker/[email protected]
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ github.token }}
- name: Run tests
run: |
export GANTRY_TEST_ENABLE_TESTS="${{ matrix.test_suit }}"
./tests/run_all_tests.sh "${{ github.repository }}" "ghcr.io" "${{ github.repository_owner }}" "${{ github.token }}"
build_and_push:
name: Build and push Docker image
runs-on: ubuntu-latest
needs:
- shellcheck
- tests
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/[email protected]
- name: Login to Docker Hub
uses: docker/[email protected]
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}
- name: Login to GitHub Container Registry
uses: docker/[email protected]
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ github.token }}
- name: Docker meta
id: meta
uses: docker/metadata-action@v5
with:
images: |
${{ github.repository }}
ghcr.io/${{ github.repository }}
tags: |
type=raw,value=dev-{{date 'X'}}
type=raw,value=development
type=ref,event=branch
type=edge,branch=main
- name: Build and push
uses: docker/[email protected]
with:
platforms: ${{ env.PLATFORMS }}
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
# - name: Post push tests
# run: |
# echo "Start running tests"
# export GANTRY_TEST_CONTAINER_REPO_TAG="${{ github.repository }}:${{ steps.git.outputs.image_tag }}"
# export GANTRY_TEST_ENABLE_TESTS="new_image"
# ./tests/run_all_tests.sh "${{ github.repository }}" "ghcr.io" "${{ github.repository_owner }}" "${{ github.token }}"
# echo "Done running tests"
clean-ghcr-dev:
name: Delete old dev container images
runs-on: ubuntu-latest
needs:
- build_and_push
steps:
- name: Delete dev images
uses: snok/container-retention-policy@v2
with:
image-names: gantry
cut-off: One day ago UTC
account-type: personal
token: ${{ secrets.TOKEN_DELETE_GHCR_IMAGES }}
keep-at-least: 5
skip-tags: latest, development
filter-tags: "dev-*"
dry-run: False
clean-ghcr-tests:
name: Delete old tests container images
runs-on: ubuntu-latest
needs:
- tests
steps:
- name: Delete old test images
uses: snok/container-retention-policy@v2
with:
image-names: gantry
# leave some margins in case multiple actions run in parallel
cut-off: 5 minutes ago UTC
account-type: personal
token: ${{ secrets.TOKEN_DELETE_GHCR_IMAGES }}
keep-at-least: 0
skip-tags: latest, development
filter-tags: "for-test-*"
dry-run: False
- name: Delete untagged images
uses: snok/container-retention-policy@v2
with:
image-names: gantry
cut-off: 1 second ago UTC
account-type: personal
token: ${{ secrets.TOKEN_DELETE_GHCR_IMAGES }}
keep-at-least: 0
untagged-only: True
skip-tags: latest, development
dry-run: False