Skip to content

Build and deploy

Build and deploy #1882

Workflow file for this run

name: Build and deploy
on:
push:
branches:
- main
- sandbox
- catbox
- magicbox
- dreambox
- coffeebox
- codebox
paths-ignore:
- '.gitignore'
- 'CODEOWNERS'
- 'LICENSE.md'
- 'README.md'
workflow_dispatch:
inputs:
prod:
description: Deploy to production
type: boolean
required: false
jobs:
build:
name: Build application
runs-on: ubuntu-latest
permissions: write-all
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js v22.11.0
uses: actions/setup-node@v4
with:
node-version: '22.11.0'
registry-url: 'https://npm.pkg.github.com'
- name: Cache node modules
id: cache-node
uses: actions/cache@v4
with:
path: |
node_modules
~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
- name: Install dependencies
if: steps.cache-node.outputs.cache-hit != 'true'
run: npm ci
env:
NODE_AUTH_TOKEN: ${{ secrets.READER_TOKEN }}
- name: Fetch openapi backend types
run: npx openapi-typescript ${{ github.event.inputs.prod == 'true' && 'https://www.nav.no/pensjon/kalkulator/v3/api-docs/current' || 'https://staging.ekstern.dev.nav.no/pensjon/kalkulator/v3/api-docs/current' }} -o ./src/types/schema.d.ts
- name: Format backend scheme
run: npm run format:types
- name: Build staging application
if: github.event.inputs.prod != 'true'
run: npm run build
- name: Build production application
if: github.event.inputs.prod == 'true'
run: npm run build:production
- name: Build backend for frontend
run: npm run build:server
- name: Save build folder
uses: actions/upload-artifact@v4
with:
name: dist
path: dist
if-no-files-found: error
retention-days: 1
- name: Create Docker image
id: image-creation
uses: nais/docker-build-push@v0
with:
dockerfile: .docker/Dockerfile
team: pensjonskalkulator
identity_provider: ${{ secrets.NAIS_WORKLOAD_IDENTITY_PROVIDER }}
project_id: ${{ vars.NAIS_MANAGEMENT_PROJECT_ID }}
outputs:
image: ${{ steps.image-creation.outputs.image }}
run-unit-tests:
name: Run unit tests
runs-on: ubuntu-latest
needs: build
strategy:
fail-fast: true
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js v22.11.0
uses: actions/setup-node@v4
with:
node-version: '22.11.0'
registry-url: 'https://npm.pkg.github.com'
- name: Cache node modules
id: cache-node
uses: actions/cache@v4
with:
path: |
node_modules
~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
- name: Install dependencies
if: steps.cache-node.outputs.cache-hit != 'true'
run: npm ci
env:
NODE_AUTH_TOKEN: ${{ secrets.READER_TOKEN }}
- name: Run unit tests
run: npm run test
- name: Archive code coverage results
uses: actions/upload-artifact@v4
with:
name: code-coverage-report
path: coverage
run-integration-tests:
name: Run integration tests
runs-on: ubuntu-latest
needs: build
strategy:
fail-fast: true
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use Node.js v22.11.0
uses: actions/setup-node@v4
with:
node-version: '22.11.0'
registry-url: 'https://npm.pkg.github.com'
- name: Cache node modules
id: cache-node
uses: actions/cache@v4
with:
path: |
node_modules
~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
- name: Cache Cypress binary
id: cache-cypress
uses: actions/cache@v4
with:
path: ~/.cache/Cypress
key: ${{ runner.os }}-cypress-${{ hashFiles('**/package.json') }}
- name: Download the build folders
uses: actions/download-artifact@v4
with:
name: dist
path: dist
- name: Install dependencies
if: steps.cache-node.outputs.cache-hit != 'true'
run: npm ci
env:
NODE_AUTH_TOKEN: ${{ secrets.READER_TOKEN }}
- name: Install cypress
if: steps.cache-cypress.outputs.cache-hit != 'true'
run: npx cypress install
- name: Run integration tests on staging application
if: github.event.inputs.prod != 'true'
run: npm run cy:test
- name: Run integration tests on production application
if: github.event.inputs.prod == 'true'
run: npm run cy:test:production
- name: Archive Cypress artifacts
uses: actions/upload-artifact@v4
if: failure()
with:
name: screenshots
path: cypress/screenshots
deploy-staging:
name: Deploy to staging
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/main'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to staging
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-staging.yml
- name: Deploy veiledning to staging
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-staging.yml
deploy-sandbox:
name: Deploy to sandbox
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/sandbox'
env:
IMAGE: ghcr.io/${{ github.repository }}/pensjonskalkulator-frontend-node:${{ github.sha }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to sandbox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-sandbox.yml
- name: Deploy veiledning to sandbox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-sandbox.yml
deploy-catbox:
name: Deploy to catbox
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/catbox'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to catbox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-catbox.yml
- name: Deploy veiledning to catbox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-catbox.yml
deploy-magicbox:
name: Deploy to magicbox
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/magicbox'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to magicbox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-magicbox.yml
- name: Deploy veiledning to magicbox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-magicbox.yml
deploy-dreambox:
name: Deploy to dreambox
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/dreambox'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to dreambox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-dreambox.yml
- name: Deploy veiledning to dreambox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-dreambox.yml
deploy-coffeebox:
name: Deploy to coffeebox
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/coffeebox'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to coffeebox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-coffeebox.yml
- name: Deploy veiledning to coffeebox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-coffeebox.yml
deploy-codebox:
name: Deploy to codebox
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
(github.event_name == 'push' ||
github.event_name == 'workflow_dispatch') &&
github.event.inputs.prod != 'true' &&
github.ref == 'refs/heads/codebox'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to codebox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-codebox.yml
- name: Deploy veiledning to codebox
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-codebox.yml
deploy-prod:
name: Deploy to prod-gcp
needs: [build, run-unit-tests, run-integration-tests]
permissions: write-all
runs-on: ubuntu-latest
if: |
github.ref == 'refs/heads/main' &&
github.event_name == 'workflow_dispatch' &&
github.event.inputs.prod == 'true'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Deploy to prod-gcp
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: prod-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-prod.yml
- name: Deploy veiledning to prod-gcp
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: prod-gcp
IMAGE: ${{ needs.build.outputs.image }}
RESOURCE: .nais/deploy-veiledning-prod.yml