forked from argoproj/rollouts-demo
-
Notifications
You must be signed in to change notification settings - Fork 0
59 lines (55 loc) · 1.99 KB
/
build-and-push-images.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
name: Rollouts Demo -- Build and Push Container Images to GAR
on:
push:
branches:
- main
workflow_dispatch: {}
env:
IMAGE_NAME: rollouts-demo
GAR_LOCATION: us
GCP_PROJECT_ID: moz-fx-cicd-demos-nonprod
IMAGE_NAMESPACE: us-docker.pkg.dev/moz-fx-cicd-demos-nonprod/cicd-demos-nonprod
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Run the release script to build demo container images
run: release.sh
build:
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
steps:
- uses: actions/checkout@v4
- uses: docker/setup-buildx-action@v2
- id: gcp-auth
name: Google authentication
uses: google-github-actions/auth@v2
with:
token_format: "access_token"
service_account: artifact-writer@${{ env.GCP_PROJECT_ID }}.iam.gserviceaccount.com
workload_identity_provider: ${{ vars.GCPV2_GITHUB_WORKLOAD_IDENTITY_PROVIDER }}
- name: Log in to the container registry
uses: docker/login-action@v2
with:
registry: ${{ env.GAR_LOCATION }}-docker.pkg.dev
username: oauth2accesstoken
password: ${{ steps.gcp-auth.outputs.access_token }}
- name: Push images to GAR
uses: docker/build-push-action@v3
with:
context: .
tags: |
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:red
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:orange
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:blue
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:purple
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:slow-orange
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:slow-red
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:bad-orange
${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:bad-red
push: true
cache-from: type=gha
cache-to: type=gha,mode=max