Skip to content

Build, push, and deploy app to dev #1894

Build, push, and deploy app to dev

Build, push, and deploy app to dev #1894

name: Build, push, and deploy app to dev
on:
workflow_dispatch:
permissions:
id-token: write
contents: read
jobs:
build:
name: Build and push Docker container
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'
cache: npm
registry-url: "https://npm.pkg.github.com"
- name: Npm install
env:
NODE_AUTH_TOKEN: ${{ secrets.READER_TOKEN }}
run: npm ci
- name: Npm run test
run: npm run test
- name: Npm run build
env:
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }}
SENTRY_RELEASE: ${{ github.sha }}
run: npm run build
- name: Npm build server
working-directory: ./server
env:
NODE_AUTH_TOKEN: ${{ secrets.READER_TOKEN }}
run: |
npm ci
npm run build
- name: Push docker image to GAR and sign image
uses: nais/docker-build-push@v0
id: docker-build-push
with:
team: teamfamilie
identity_provider: ${{ secrets.NAIS_WORKLOAD_IDENTITY_PROVIDER }}
project_id: ${{ vars.NAIS_MANAGEMENT_PROJECT_ID }}
outputs:
image: ${{ steps.docker-build-push.outputs.image }}
deploy:
name: Deploy to dev
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: deploy to gcp-dev
uses: nais/deploy/actions/deploy@v2
env:
CLUSTER: dev-gcp
RESOURCE: nais-dev.yaml
IMAGE: ${{ needs.build.outputs.image }}