142 lines (132 loc) · 3.71 KB
/
build.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
name: build
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
on:
push:
branches:
- 'main'
pull_request:
env:
BUILDER_NAME: remote-builder
jobs:
validate:
runs-on: ubuntu-20.04
steps:
-
name: Checkout
uses: actions/checkout@v3
-
name: Run
uses: docker/bake-action@v2
with:
targets: validate
build:
runs-on: ubuntu-20.04
strategy:
fail-fast: false
matrix:
name:
- docker-engine
- docker-cli
- containerd
- buildx
- compose
- scan
- credential-helpers
pkg:
- deb
- rpm
- static
steps:
-
name: Checkout
uses: actions/checkout@v3
-
name: Set up QEMU
uses: docker/setup-qemu-action@v2
-
name: Set up BuildKit container
id: builder
uses: docker/setup-buildx-action@v2
-
name: Set up Docker Buildx
# FIXME: use docker/setup-buildx-action@v2 when https://github.com/docker/setup-buildx-action/pull/165 merged
uses: crazy-max/docker-setup-buildx-action@append
with:
driver: remote
endpoint: docker-container://buildx_buildkit_${{ steps.builder.outputs.name }}0
append: |
- name: aws_graviton2
endpoint: tcp://${{ secrets.AWS_ARM64_HOST }}:1234
platforms: darwin/arm64,linux/arm64,linux/arm/v5,linux/arm/v6,linux/arm/v7,windows/arm64
- name: linuxone_s390x
endpoint: tcp://${{ secrets.LINUXONE_S390X_HOST }}:1234
platforms: linux/s390x
env:
BUILDER_NODE_1_AUTH_TLS_CACERT: ${{ secrets.AWS_ARM64_CACERT }}
BUILDER_NODE_1_AUTH_TLS_CERT: ${{ secrets.AWS_ARM64_CERT }}
BUILDER_NODE_1_AUTH_TLS_KEY: ${{ secrets.AWS_ARM64_KEY }}
BUILDER_NODE_2_AUTH_TLS_CACERT: ${{ secrets.LINUXONE_S390X_CACERT }}
BUILDER_NODE_2_AUTH_TLS_CERT: ${{ secrets.LINUXONE_S390X_CERT }}
BUILDER_NODE_2_AUTH_TLS_KEY: ${{ secrets.LINUXONE_S390X_KEY }}
-
# necessary to use gha cache export
name: Expose GitHub Runtime
uses: crazy-max/ghaction-github-runtime@v2
-
name: Build
run: |
make -j$(nproc) -C pkg/${{ matrix.name }} all-${{ matrix.pkg }}
env:
BUILD_CACHE_SCOPE: build-${{ matrix.name }}-${{ matrix.pkg }}
-
name: List artifacts
run: |
tree -nh ./pkg/${{ matrix.name }}/bin
# FIXME: Uncomment when repo made public
# -
# name: Upload artifacts
# uses: actions/upload-artifact@v3
# with:
# name: ${{ matrix.name }}
# path: ./pkg/${{ matrix.name }}/bin/*
# if-no-files-found: error
# retention-days: 1
# dummy-release:
# runs-on: ubuntu-20.04
# needs:
# - build
# strategy:
# fail-fast: false
# matrix:
# name:
# - docker-cli
# - buildx
# - compose
# - credential-helpers
# steps:
# -
# name: Checkout
# uses: actions/checkout@v3
# -
# name: Set up Docker Buildx
# uses: docker/setup-buildx-action@v2
# -
# name: Download binaries
# uses: actions/download-artifact@v3
# with:
# name: ${{ matrix.name }}
# path: ./pkg/${{ matrix.name }}/bin
# -
# name: Release
# uses: docker/bake-action@v2
# with:
# workdir: ./pkg/${{ matrix.name }}
# targets: release
# set: |
# *.output=/tmp/release
# -
# name: List release artifacts
# run: |
# tree /tmp/release