-
Notifications
You must be signed in to change notification settings - Fork 16
executable file
·65 lines (56 loc) · 1.82 KB
/
CDImage.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
---
# Update NuWro container image registry with newest updates
name: Image CD
# The events that trigger the workflow
on:
push:
branches:
- master
tags:
- 'v*'
permissions:
contents: read
packages: write
jobs:
build:
runs-on: ubuntu-latest
strategy:
fail-fast: false # KS: Prevents cancellation of remaining jobs if one fails
matrix:
include:
- os: alma9
file: doc/docker/alma9/Dockerfile
tag_latest: alma9latest
name: Image CD ${{ matrix.os }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Log in to GitHub Container Registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Build Docker image
run: |
if [ "${{ github.ref_type }}" == "tag" ]; then
docker build . \
--file "${{ matrix.file }}" \
--tag "ghcr.io/nuwro/nuwro:${{ matrix.os }}${{ github.ref_name }}" \
--build-arg NUWRO_VERSION="${{ github.ref_name }}"
else
docker build . \
--file "${{ matrix.file }}" \
--tag "ghcr.io/nuwro/nuwro:${{ matrix.tag_latest }}" \
--build-arg NUWRO_VERSION="master"
fi
- name: Push Docker image
run: |
if [ "${{ github.ref_type }}" == "tag" ]; then
docker push "ghcr.io/nuwro/nuwro:${{ matrix.os }}${{ github.ref_name }}"
else
docker push "ghcr.io/nuwro/nuwro:${{ matrix.tag_latest }}"
fi
- name: Delete old images
uses: actions/delete-package-versions@v5
with:
package-name: 'nuwro'
package-type: 'container'
min-versions-to-keep: 5
delete-only-untagged-versions: 'true'