-
Notifications
You must be signed in to change notification settings - Fork 0
146 lines (146 loc) · 4.91 KB
/
test.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
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
name: gha-docker-image-exists Test
on:
workflow_dispatch:
env:
REGISTRY_PORT: 5000
REGISTRY_USERNAME: "test-registry-username"
REGISTRY_PASSWORD: "test-registry-password"
jobs:
valid-image-no-auth:
runs-on: ubuntu-latest
steps:
- name: GHA Docker Image Exists
id: gha-docker-image-exists
continue-on-error: true
uses: Y0sh1dk/gha-docker-image-exists@feature/registry-basic-auth
with:
image: nginx:latest
- name: Check output
run: |
if [ ${{ steps.gha-docker-image-exists.outcome == 'success' }} ]; then
exit 0
else
exit 1
fi
invalid-image-no-auth:
runs-on: ubuntu-latest
steps:
- name: GHA Docker Image Exists
id: gha-docker-image-exists
continue-on-error: true
uses: Y0sh1dk/gha-docker-image-exists@feature/registry-basic-auth
with:
image: nginx:invalid-tag
- name: Check output
run: |
if ${{ steps.gha-docker-image-exists.outcome == 'failure' }}; then
exit 0
else
exit 1
fi
valid-image-auth:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Install Task
uses: arduino/setup-task@v1
- name: Setup local registry
run: |
task local-registry-up
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: localhost:${{ env.REGISTRY_PORT }}
username: ${{ env.REGISTRY_USERNAME }}
password: ${{ env.REGISTRY_PASSWORD }}
- name: Push image to local registry
run: |
docker pull nginx:latest
docker tag nginx:latest localhost:${{ env.REGISTRY_PORT }}/nginx:latest
docker push localhost:${{ env.REGISTRY_PORT }}/nginx:latest
- name: GHA Docker Image Exists
id: gha-docker-image-exists
continue-on-error: true
uses: Y0sh1dk/gha-docker-image-exists@feature/registry-basic-auth
with:
image: localhost:${{ env.REGISTRY_PORT }}/nginx:latest
username: ${{ env.REGISTRY_USERNAME }}
password: ${{ env.REGISTRY_PASSWORD }}
serverAddress: localhost:${{ env.REGISTRY_PORT }}
- name: Check output
run: |
if ${{ steps.gha-docker-image-exists.outcome == 'success' }}; then
exit 0
else
exit 1
fi
valid-image-invalid-auth:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Install Task
uses: arduino/setup-task@v1
- name: Setup local registry
run: |
task local-registry-up
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: localhost:${{ env.REGISTRY_PORT }}
username: ${{ env.REGISTRY_USERNAME }}
password: ${{ env.REGISTRY_PASSWORD }}
- name: Push image to local registry
run: |
docker pull nginx:latest
docker tag nginx:latest localhost:${{ env.REGISTRY_PORT }}/nginx:latest
docker push localhost:${{ env.REGISTRY_PORT }}/nginx:latest
- name: GHA Docker Image Exists
id: gha-docker-image-exists
continue-on-error: true
uses: Y0sh1dk/gha-docker-image-exists@feature/registry-basic-auth
with:
image: localhost:${{ env.REGISTRY_PORT }}/nginx:latest
username: ${{ env.REGISTRY_USERNAME }}-foo
password: ${{ env.REGISTRY_PASSWORD }}-foo
serverAddress: localhost:${{ env.REGISTRY_PORT }}
- name: Check output
run: |
if ${{ steps.gha-docker-image-exists.outcome == 'failure' }}; then
exit 0
else
exit 1
fi
invalid-image-auth:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Install Task
uses: arduino/setup-task@v1
- name: Setup local registry
run: |
task local-registry-up
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: localhost:${{ env.REGISTRY_PORT }}
username: ${{ env.REGISTRY_USERNAME }}
password: ${{ env.REGISTRY_PASSWORD }}
- name: GHA Docker Image Exists
id: gha-docker-image-exists
continue-on-error: true
uses: Y0sh1dk/gha-docker-image-exists@feature/registry-basic-auth
with:
image: localhost:${{ env.REGISTRY_PORT }}/nginx:invalid-tag
username: ${{ env.REGISTRY_USERNAME }}
password: ${{ env.REGISTRY_PASSWORD }}
serverAddress: localhost:${{ env.REGISTRY_PORT }}
- name: Check output
run: |
if ${{ steps.gha-docker-image-exists.outcome == 'failure' }}; then
exit 0
else
exit 1
fi