-
Notifications
You must be signed in to change notification settings - Fork 0
40 lines (33 loc) · 1.3 KB
/
build-push-image-gcp.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
name: Build and Push to GCP Artifact registry
on:
push:
branches:
- main
paths:
- producer/**
- .github/**
workflow_dispatch:
env:
PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }}
REPOSITORY_NAME: fraud-detection
IMAGE_NAME: event-producer
GCP_REGION: europe-west3
jobs:
build-push:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: google-github-actions/auth@v0
with:
credentials_json: ${{ secrets.GCP_CREDENTIALS }}
- name: Set up Cloud SDK
uses: google-github-actions/setup-gcloud@v0
- name: Configure Docker Client
run: gcloud auth configure-docker $GCP_REGION-docker.pkg.dev --quiet
- name: Push Docker Image to GCP Artifact Registry
run: |-
gcloud builds submit --tag $GCP_REGION-docker.pkg.dev/$PROJECT_ID/$REPOSITORY_NAME/$IMAGE_NAME:${GITHUB_SHA::7}
gcloud container images add-tag $GCP_REGION-docker.pkg.dev/$PROJECT_ID/$REPOSITORY_NAME/$IMAGE_NAME:${GITHUB_SHA::7} $GCP_REGION-docker.pkg.dev/$PROJECT_ID/$REPOSITORY_NAME/$IMAGE_NAME:latest
- name: Deploy Cloud Run from GCP Artifact Registry
run: |-
gcloud run deploy producer --image $GCP_REGION-docker.pkg.dev/$PROJECT_ID/$REPOSITORY_NAME/$IMAGE_NAME:${GITHUB_SHA::7} --region $GCP_REGION