-
Notifications
You must be signed in to change notification settings - Fork 0
161 lines (160 loc) · 6.42 KB
/
nodejs.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
147
148
149
150
151
152
153
154
155
156
157
158
159
160
name: Build Node.js
on:
workflow_dispatch:
inputs:
image_name:
description: Docker image name
required: true
default: nodejs
image_version:
description: Docker image version
required: true
default: 18
type: choice
options:
- 20
- 18
- 16
- 14
- 12
- 10
- 8
image_variant:
description: Docker image variant
required: true
default: all
type: choice
options:
- all
- alpine
- alpine-glibc
- alpine-oci
- debian
- debian-oci
jobs:
build_specific:
if: ${{ inputs.image_variant != 'all' }}
name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-${{ inputs.image_variant }}"
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-${{ inputs.image_variant }}"
uses: docker/build-push-action@v3
with:
context: ${{ inputs.image_name }}
file: ${{ inputs.image_name }}/Dockerfile-${{ inputs.image_version }}_${{ inputs.image_variant }}
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ inputs.image_name }}:${{ inputs.image_version }}-${{ inputs.image_variant }}
build_nodejs_alpine:
if: ${{ inputs.image_variant == 'all' }}
name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-alpine"
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-alpine"
uses: docker/build-push-action@v3
with:
context: ${{ inputs.image_name }}
file: ${{ inputs.image_name }}/Dockerfile-${{ inputs.image_version }}_alpine
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ inputs.image_name }}:${{ inputs.image_version }}-alpine
build_nodejs_alpine_glibc:
if: ${{ inputs.image_variant == 'all' }}
name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-alpine-glibc"
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-alpine-glibc"
uses: docker/build-push-action@v3
with:
context: ${{ inputs.image_name }}
file: ${{ inputs.image_name }}/Dockerfile-${{ inputs.image_version }}_alpine-glibc
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ inputs.image_name }}:${{ inputs.image_version }}-alpine-glibc
build_nodejs_alpine_oci:
if: ${{ inputs.image_variant == 'all' }}
name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-alpine-oci"
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-alpine-oci"
uses: docker/build-push-action@v3
with:
context: ${{ inputs.image_name }}
file: ${{ inputs.image_name }}/Dockerfile-${{ inputs.image_version }}_alpine-oci
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ inputs.image_name }}:${{ inputs.image_version }}-alpine-oci
build_nodejs_debian:
if: ${{ inputs.image_variant == 'all' }}
name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-debian"
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-debian"
uses: docker/build-push-action@v3
with:
context: ${{ inputs.image_name }}
file: ${{ inputs.image_name }}/Dockerfile-${{ inputs.image_version }}_debian
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ inputs.image_name }}:${{ inputs.image_version }}-debian
build_nodejs_debian_oci:
if: ${{ inputs.image_variant == 'all' }}
name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-debian-oci"
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: "Build and push to registry ${{ inputs.image_name }}:${{ inputs.image_version }}-debian-oci"
uses: docker/build-push-action@v3
with:
context: ${{ inputs.image_name }}
file: ${{ inputs.image_name }}/Dockerfile-${{ inputs.image_version }}_debian-oci
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ inputs.image_name }}:${{ inputs.image_version }}-debian-oci