Skip to content

Merge branch 'develop' into Pidp-1086-Streamlining-Zero-Touch-Enrollm… #2561

Merge branch 'develop' into Pidp-1086-Streamlining-Zero-Touch-Enrollm…

Merge branch 'develop' into Pidp-1086-Streamlining-Zero-Touch-Enrollm… #2561

Workflow file for this run

name: Build All - PR - GOLD
on:
workflow_dispatch:
push:
# paths:
# - "workspace/**"
# - "backend/services.plr-intake/**"
# - "backend/services.plr-intake.tests/**"
# - "backend/webapi/**"
# - "backend/webapi.tests/**"
branches-ignore:
- 'develop'
- 'test'
- 'main'
pull_request:
types: [opened]
branches-ignore:
- 'test'
- 'master'
permissions: read-all
# This will terminate builds that are previously, but continuing to run. Saves GHA hours.
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
get-pr-number:
runs-on: ubuntu-latest
defaults:
run:
working-directory: "./workspace"
outputs:
pr_number: ${{ steps.find-pr.outputs.pr }}
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: find-pr
id: find-pr
uses: jwalton/gh-find-current-pr@v1
with:
state: open
- name: job1
id: job1
run: echo "Your PR is ${PR}"
if: success() && steps.find-pr.outputs.number
env:
PR: ${{ steps.find-pr.outputs.pr }}
Yarn-Lint:
name: Frontend Yarn Lint
runs-on: ubuntu-latest
needs: get-pr-number
if: ${{ always() && !cancelled() && needs.get-pr-number.outputs.pr_number != '' }}
defaults:
run:
working-directory: "./workspace"
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: Use Node.js 18.x
uses: actions/setup-node@v3
with:
node-version: 18.x
- name: YARN Install
run: yarn install
- name: YARN Lint
run: yarn lint:all
build-and-push-frontend:
name: Frontend Build & Push
runs-on: ubuntu-latest
needs: get-pr-number
if: ${{ always() && !cancelled() && needs.get-pr-number.outputs.pr_number != '' }}
defaults:
run:
working-directory: "./workspace"
permissions:
contents: read
id-token: write
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: Use Node.js 18.x
uses: actions/setup-node@v3
with:
node-version: 18.x
- name: YARN Install
run: yarn install
- name: YARN Build
run: yarn build
- name: YARN Test
run: |
yarn test:ci
- name: "Docker Build"
run: |
docker build -t image-registry.apps.gold.devops.gov.bc.ca/f088b1-tools/pidp-frontend:pr-${{ needs.get-pr-number.outputs.pr_number }} .
# Uses the builder service account token
- name: "Docker Login to Gold OCP"
uses: docker/login-action@v2
with:
registry: image-registry.apps.gold.devops.gov.bc.ca
username: builder
password: ${{ secrets.GOLD_TOOLS_BUILDER_TOKEN }}
- name: "Push image"
run: |
docker push image-registry.apps.gold.devops.gov.bc.ca/f088b1-tools/pidp-frontend:pr-${{ needs.get-pr-number.outputs.pr_number }}
unit-test-webapi:
needs: get-pr-number
if: ${{ always() && !cancelled() && needs.get-pr-number.outputs.pr_number != '' }}
runs-on: ubuntu-latest
defaults:
run:
working-directory: "./backend/webapi.tests"
permissions:
contents: read
id-token: write
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: Setup .NET Core
uses: actions/setup-dotnet@v3
with:
dotnet-version: 8.0.x
- name: Build backend
run: dotnet build --configuration Release
- name: Run Tests
run: dotnet test --configuration Release
unit-test-plr-intake:
needs: get-pr-number
if: ${{ always() && !cancelled() && needs.get-pr-number.outputs.pr_number != '' }}
runs-on: ubuntu-latest
defaults:
run:
working-directory: "./backend/services.plr-intake.tests"
permissions:
contents: read
id-token: write
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: Setup .NET Core
uses: actions/setup-dotnet@v3
with:
dotnet-version: 6.0.x
- name: Build backend
run: dotnet build --configuration Release
- name: Run Tests
run: dotnet test --configuration Release
build-and-push-plr-intake:
name: PLR Intake Backend Build & Push
needs: [get-pr-number, unit-test-plr-intake]
if: ${{ !(contains(needs.*.result, 'failure')) && needs.get-pr-number.outputs.pr_number != '' }}
runs-on: ubuntu-latest
defaults:
run:
working-directory: "./backend/services.plr-intake"
permissions:
contents: read
id-token: write
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: "Docker Build"
run: |
docker build -t image-registry.apps.gold.devops.gov.bc.ca/f088b1-tools/pidp-plr-intake:pr-${{ needs.get-pr-number.outputs.pr_number }} .
# Uses the builder service account token
- name: "Docker Login to Gold OCP"
uses: docker/login-action@v2
with:
registry: image-registry.apps.gold.devops.gov.bc.ca
username: builder
password: ${{ secrets.GOLD_TOOLS_BUILDER_TOKEN }}
- name: "Push image"
run: |
docker push image-registry.apps.gold.devops.gov.bc.ca/f088b1-tools/pidp-plr-intake:pr-${{ needs.get-pr-number.outputs.pr_number }}
build-and-push-webapi:
name: WebAPI Backend Build & Push
needs: [get-pr-number, unit-test-webapi]
if: ${{ !(contains(needs.*.result, 'failure')) && needs.get-pr-number.outputs.pr_number != '' }}
runs-on: ubuntu-latest
defaults:
run:
working-directory: "./backend/webapi"
permissions:
contents: read
id-token: write
steps:
- name: "Checkout Code"
uses: actions/checkout@master
- name: "Docker Build Gold"
run: |
docker build -t image-registry.apps.gold.devops.gov.bc.ca/f088b1-tools/pidp-webapi:pr-${{ needs.get-pr-number.outputs.pr_number }} .
# Uses the builder service account token
- name: "Docker Login to Gold OCP"
uses: docker/login-action@v2
with:
registry: image-registry.apps.gold.devops.gov.bc.ca
username: builder
password: ${{ secrets.GOLD_TOOLS_BUILDER_TOKEN }}
- name: "Push image"
run: |
docker push image-registry.apps.gold.devops.gov.bc.ca/f088b1-tools/pidp-webapi:pr-${{ needs.get-pr-number.outputs.pr_number }}
helm-deployment:
needs: [build-and-push-webapi, build-and-push-plr-intake, build-and-push-frontend]
runs-on: 'ubuntu-latest'
permissions:
contents: read
id-token: write
steps:
- uses: actions/checkout@master
- name: Install CLI tools from GitHub
uses: redhat-actions/openshift-tools-installer@v1
with:
oc: "4"
- name: Authenticate and set context
uses: redhat-actions/[email protected]
with:
openshift_server_url: ${{secrets.GOLD_OPENSHIFT_CLUSTER_URL}}
openshift_token: ${{secrets.GOLD_PIPELINE_SERVICE_ACCOUNT_TOKEN}}
namespace: f088b1-dev
- name: Get pr number from GH cli command (pushing to pr)
if: ${{ github.event.number == ''}}
run: echo "pr_number=$(gh pr view --json number -q .number || echo "")" >> "$GITHUB_ENV"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Get pr number from github.event.number (opening a pr)
if: ${{ github.event.number != ''}}
run: echo "pr_number=${{ github.event.number }}" >> "$GITHUB_ENV"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Helm Deploy / install command
run: |
echo current installed helm releases
helm list --namespace f088b1-dev
echo installing helm chart...
helm upgrade --install --wait --values ./deploy/pr_values.yaml --namespace f088b1-dev pr-${{ env.pr_number }} charts/pidp --debug --set global.image.tag=pr-${{ env.pr_number }}