-
Notifications
You must be signed in to change notification settings - Fork 0
118 lines (106 loc) · 3.92 KB
/
nvme-stable.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
---
name: build nvme multi-arch containers for stable distros
on:
push:
branches:
- master
jobs:
build-multi:
runs-on: ubuntu-20.04
strategy:
fail-fast: false
matrix:
# trusty doesn't have meson
os:
- debian-bookworm
- debian-bullseye
- debian-buster
- fedora-40
- centos-8
- opensuse-leap
- ubuntu-jammy
- ubuntu-noble
steps:
- name: set arch list (64bit)
if: |
startswith(matrix.os, 'fedora-') ||
startswith(matrix.os, 'opensuse-leap') ||
matrix.os == 'ubuntu-jammy' || matrix.os == 'ubuntu-kinetic' ||
matrix.os == 'ubuntu-noble'
run: >-
echo PLATFORMS=linux/amd64,linux/arm64,linux/ppc64le,linux/s390x
>> $GITHUB_ENV
- name: set arch list (centos)
if: ${{ startswith(matrix.os, 'centos-') }}
run: echo PLATFORMS=linux/amd64,linux/arm64,linux/ppc64le >> $GITHUB_ENV
- name: set arch list (debian / ubuntu oldstable)
if: |
matrix.os == 'debian-buster' || matrix.os == 'debian-jessie' ||
matrix.os == 'ubuntu-trusty'
run: echo PLATFORMS=linux/amd64,linux/arm/v7,linux/386 >> $GITHUB_ENV
- name: set arch list (arch linux / SLE)
# SLES: need different secret for every arch, ours works only for x86_64
if: ${{ matrix.os == 'arch' || startswith(matrix.os, 'sles-') }}
run: echo PLATFORMS=linux/amd64 >> $GITHUB_ENV
- name: set arch list (full / fallback)
if: env.PLATFORMS == ''
run: >-
echo PLATFORMS=linux/amd64,linux/arm64,linux/ppc64le,linux/s390x,
linux/arm/v7,linux/386 >> $GITHUB_ENV
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@master
- name: Login to ghcr.io
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Checkout
uses: actions/checkout@v2
- name: Set up QEMU
id: qemu
uses: docker/setup-qemu-action@v2
with:
image: tonistiigi/binfmt:latest
- name: Create Dockerfile
id: m4
run: |
mkdir ./container
m4 -I m4 -D DISTRO=${{ matrix.os }} -DPACKAGE=nvme \
header.m4 dockerfile.m4 >./container/Dockerfile
cat ./container/Dockerfile
- name: Cache Docker layers
uses: actions/cache@v3
with:
path: /tmp/.buildx-cache-${{ matrix.os }}
key: nvme-stable-${{ matrix.os }}
- name: Build and push container
if: ${{ ! startswith(matrix.os, 'sles') }}
uses: docker/build-push-action@v3
with:
context: ./container
push: true
platforms: ${{ env.PLATFORMS }}
tags: ghcr.io/mwilck/nvme-build-${{ matrix.os }}:latest
cache-from: type=local,src=/tmp/.buildx-cache-${{ matrix.os }}
cache-to: type=local,dest=/tmp/.new-buildx-cache-${{ matrix.os }}
- name: Build and push container (SLES)
if: ${{ startswith(matrix.os, 'sles') }}
uses: docker/build-push-action@v3
with:
context: ./container
push: true
platforms: ${{ env.PLATFORMS }}
tags: ghcr.io/mwilck/nvme-build-${{ matrix.os }}:latest
secrets: |
"SUSEConnect=${{ secrets.SUSECONNECT }}"
"SCCcredentials=${{ secrets.SCCCREDENTIALS }}"
cache-from: type=local,src=/tmp/.buildx-cache-${{ matrix.os }}
cache-to: type=local,dest=/tmp/.new-buildx-cache-${{ matrix.os }}
- name: Move cache
# Avoid cache growing too large
# https://github.com/docker/build-push-action/issues/252
run: |
rm -rf /tmp/.buildx-cache-${{ matrix.os }}
mv /tmp/.new-buildx-cache-${{ matrix.os }} \
/tmp/.buildx-cache-${{ matrix.os }}