Skip to content

Commit

Permalink
Merge pull request #687 from DFE-Digital/build-concurrency
Browse files Browse the repository at this point in the history
Split workflow into concurrent build and import stages
  • Loading branch information
DrizzlyOwl authored Feb 3, 2025
2 parents c9de0a9 + bdf0224 commit 03d1942
Showing 1 changed file with 55 additions and 40 deletions.
95 changes: 55 additions & 40 deletions .github/workflows/build-and-push-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,89 +14,104 @@ on:
concurrency:
group: ${{ github.workflow }}-${{ github.event.inputs.environment }}

env:
IMAGE_NAME: tramsapi-app

jobs:
set-env:
name: Determine environment
runs-on: ubuntu-24.04
outputs:
environment: ${{ steps.var.outputs.environment }}
branch: ${{ steps.var.outputs.branch }}
release: ${{ steps.var.outputs.release }}
checked-out-sha: ${{ steps.var.outputs.checked-out-sha }}
image-name: ${{ steps.var.outputs.image-name }}
steps:
- name: Checkout
uses: actions/checkout@v4

- name: Get branch name for push/dispatch event
run: |
GIT_REF=${{ github.ref_name }}
echo "branch_ref=${GIT_REF}" >> $GITHUB_ENV
- id: var
run: |
GIT_REF=${{ env.branch_ref }}
GIT_BRANCH=${GIT_REF##*/}
INPUT=${{ github.event.inputs.environment }}
ENVIRONMENT=${INPUT:-"development"}
CHECKED_OUT_SHA="$(git log -1 '--format=format:%H')"
RELEASE=${ENVIRONMENT,,}-`date +%Y-%m-%d`.${{ github.run_number }}
echo "environment=${ENVIRONMENT,,}" >> $GITHUB_OUTPUT
echo "branch=$GIT_BRANCH" >> $GITHUB_OUTPUT
echo "checked-out-sha=${CHECKED_OUT_SHA}" >> $GITHUB_OUTPUT
echo "release=${RELEASE}" >> $GITHUB_OUTPUT
echo "image-name=${{ env.IMAGE_NAME }}" >> $GITHUB_OUTPUT
build-import-init-container:
build:
name: Build
needs: [ set-env ]
permissions:
id-token: write
contents: read
packages: write
name: Build and import Init Container
needs: [ set-env ]
uses: DFE-Digital/deploy-azure-container-apps-action/.github/workflows/[email protected]
uses: DFE-Digital/deploy-azure-container-apps-action/.github/workflows/[email protected]
strategy:
matrix:
stage: [
"final",
"initcontainer"
]
include:
- stage: "final"
tag-prefix: ""
- stage: "initcontainer"
tag-prefix: "init-"
with:
docker-image-name: tramsapi-app
docker-build-target: initcontainer
docker-tag-prefix: init-
environment: ${{ needs.set-env.outputs.environment }}
import-without-deploy: true
docker-image-name: ${{ needs.set-env.outputs.image-name }}
docker-build-file-name: ${{ inputs.docker-build-file-name }}
docker-build-context: ${{ inputs.docker-build-context }}
docker-build-args: CI=true
docker-build-target: ${{ matrix.stage }}
docker-tag-prefix: ${{ matrix.tag-prefix }}

import:
name: Import
needs: [ set-env, build ]
permissions:
id-token: write
uses: DFE-Digital/deploy-azure-container-apps-action/.github/workflows/[email protected]
strategy:
matrix:
stage: [
"final",
"initcontainer"
]
include:
- stage: "final"
tag-prefix: ""
- stage: "initcontainer"
tag-prefix: "init-"
with:
environment: ${{ needs.set-env.outputs.environment }}
docker-image-name: ${{ needs.set-env.outputs.image-name }}
docker-tag-prefix: ${{ matrix.tag-prefix }}
secrets:
azure-tenant-id: ${{ secrets.AZURE_TENANT_ID }}
azure-subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
azure-acr-client-id: ${{ secrets.ACR_CLIENT_ID }}
azure-acr-name: ${{ secrets.ACR_NAME }}
azure-aca-client-id: ${{ secrets.ACA_CLIENT_ID }}
azure-aca-name: ${{ secrets.ACA_CONTAINERAPP_NAME }}
azure-aca-resource-group: ${{ secrets.ACA_RESOURCE_GROUP }}

build-import-deploy-app:
deploy:
name: Deploy
needs: [ set-env, import ]
permissions:
id-token: write
contents: read
packages: write
name: Build, import and deploy App Container
needs: [ build-import-init-container ]
uses: DFE-Digital/deploy-azure-container-apps-action/.github/workflows/[email protected]
uses: DFE-Digital/deploy-azure-container-apps-action/.github/workflows/[email protected]
with:
docker-image-name: tramsapi-app
docker-build-target: final
environment: ${{ needs.set-env.outputs.environment }}
docker-image-name: ${{ needs.set-env.outputs.image-name }}
annotate-release: true
docker-build-args: |
COMMIT_SHA="${{ needs.set-env.outputs.checked-out-sha }}"
CI=true
secrets:
azure-tenant-id: ${{ secrets.AZURE_TENANT_ID }}
azure-subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
azure-acr-client-id: ${{ secrets.ACR_CLIENT_ID }}
azure-acr-name: ${{ secrets.ACR_NAME }}
azure-aca-client-id: ${{ secrets.ACA_CLIENT_ID }}
azure-aca-name: ${{ secrets.ACA_CONTAINERAPP_NAME }}
azure-aca-resource-group: ${{ secrets.ACA_RESOURCE_GROUP }}
azure-acr-name: ${{ secrets.ACR_NAME }}

create-tag:
name: Tag and release
needs: [ set-env, build-import-deploy-app ]
needs: [ set-env, deploy ]
runs-on: ubuntu-24.04
steps:
- uses: actions/checkout@v4
Expand Down Expand Up @@ -147,7 +162,7 @@ jobs:
cypress-tests:
name: Run Cypress Tests
needs: [ set-env, create-tag ]
needs: [ set-env, deploy ]
if: needs.set-env.outputs.environment == 'test' || needs.set-env.outputs.environment == 'development'
uses: ./.github/workflows/cypress-tests.yml
with:
Expand Down

0 comments on commit 03d1942

Please sign in to comment.