-
Notifications
You must be signed in to change notification settings - Fork 10
79 lines (65 loc) · 2.82 KB
/
build-prod-release.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
# Create a Docker build for a production release
# To trigger a release:
# Update the version numbers in portal-core and portal API pom files
# Tag with v<POM_VERSION> e.g. v6.3.0
# This action will compare the pom version with the tag v# to ensure they match
# If they do it will build the new image and push it to the GitHub Container Registry tagged with that version
# Check the new image appears in the container registry and that the tags are correct
# To Deploy:
# Goto Azure and make a new revision of portalapi-prod
# Select the new version number as the image tag name
name: build-prod-release
on:
push:
tags:
- v*
env:
IMAGE_NAME: auscope-portal-api-prod-release
jobs:
# Push image to GitHub Packages.
push:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 1.17
uses: actions/setup-java@v1
with:
java-version: 1.17
- name: Cache Maven packages
uses: actions/cache@v2
with:
path: ~/.m2
key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ runner.os }}-m2
- name: set application.yaml to default
run: |
mv ./src/main/resources/application.yaml.default ./src/main/resources/application.yaml
- name: Set Release versions from tag and pom
run: |
echo "RELEASE_VERSION=$(mvn help:evaluate -Dexpression=project.version -q -DforceStdout)" >> "$GITHUB_ENV"
echo "ARTIFACTID=$(mvn help:evaluate -Dexpression=project.artifactId -q -DforceStdout)" >> "$GITHUB_ENV"
echo "WAR_VERSION=$(echo "${{ github.ref_name }}" | sed 's/v//')" >> "$GITHUB_ENV"
- name: Check version numbers match
if: ${{ env.WAR_VERSION != env.RELEASE_VERSION }}
run: exit 1
- name: Build with Maven
run: |
mvn -B clean package spring-boot:build-image --file pom.xml
- name: Log into registry
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin
- name: Push image
run: |
IMAGE_ID=ghcr.io/${{ github.repository }}/$IMAGE_NAME
# Change all uppercase to lowercase
IMAGE_ID=$(echo $IMAGE_ID | tr '[A-Z]' '[a-z]')
VERSION=${{ env.RELEASE_VERSION }}
echo IMAGE_ID=$IMAGE_ID
echo VERSION=$VERSION
docker tag auscope-portal-api:$VERSION $IMAGE_ID:$VERSION
docker tag auscope-portal-api:$VERSION $IMAGE_ID:latest
docker push --all-tags $IMAGE_ID
- name: Upload war PROD file artifact
uses: actions/upload-artifact@v4
with:
name: auscope-portal-api production release war file
path: 'target/${{ env.ARTIFACTID }}-${{ env.RELEASE_VERSION }}.war'