Skip to content

WIP: Remove deploy_key input #77

WIP: Remove deploy_key input

WIP: Remove deploy_key input #77

Workflow file for this run

name: Pipeline
on:
push:
branches: [main]
pull_request:
branches: [main]
# Allow to run this workflow manually
workflow_dispatch:
env:
IMAGE_NAME: ${{ github.repository }}
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: "pages" # FIXME
cancel-in-progress: false
jobs:
test:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node
uses: actions/setup-node@v4
with:
node-version-file: .node-version
cache: npm
- name: Cache npm dependencies
id: cache-npm-deps
uses: actions/cache@v4
with:
path: |
**/node_modules
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- name: Install dependencies
if: steps.cache-npm-deps.outputs.cache-hit != 'true'
run: npm ci
- name: Build for tests
run: npm run build
- name: Check format
run: npm run format:check
- name: Lint
run: npm run lint:check
- name: Check types
run: npm run typecheck
- name: Run unit tests
run: npm test
- name: Install E2E & A11y test dependencies
run: |
npx --yes playwright install --with-deps
- name: Run E2E tests
id: e2e
run: npm run test:e2e
- uses: actions/upload-artifact@v4
if: ${{ failure() && steps.e2e.outcome == 'failure' }}
with:
name: playwright-e2e-test-results
path: packages/*/test/e2e/playwright-report
- name: Run A11y tests
id: a11y
run: npm run test:a11y
env:
# Use a different port (from the one used with E2E tests) to workaround problem in CI/GitHub Actions,
# starting to occur with playwright/test 1.28.0:
# Error: http://localhost:4173 is already used ...
# See https://github.com/digitalservicebund/typescript-vite-application-template/actions/runs/3486985178/jobs/5834089375
VITE_PORT: 4183
- uses: actions/upload-artifact@v4
if: ${{ failure() && steps.a11y.outcome == 'failure' }}
with:
name: playwright-a11y-test-results
path: packages/*/test/a11y/playwright-report
- name: Send failure to Slack
uses: digitalservicebund/notify-on-failure-gha@814d0c4b2ad6a3443e89c991f8657b10126510bf # v1.5.0
if: ${{ failure() }}
with:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
audit-licenses:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node
uses: actions/setup-node@v4
with:
node-version-file: .node-version
cache: npm
- name: Cache npm dependencies
id: cache-npm-deps
uses: actions/cache@v4
with:
path: |
**/node_modules
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- name: Install dependencies
if: steps.cache-npm-deps.outputs.cache-hit != 'true'
run: npm ci
- name: Audit used licences
run: npm run audit:licences
- name: Send status to Slack
uses: digitalservicebund/notify-on-failure-gha@814d0c4b2ad6a3443e89c991f8657b10126510bf # v1.5.0
if: ${{ failure() }}
with:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
vulnerability-scan:
runs-on: ubuntu-latest
permissions:
contents: read
actions: read
security-events: write
steps:
- uses: actions/checkout@v4
- name: validate github workflow files to have pinned versions
uses: digitalservicebund/github-actions-linter@dccac3ada437947aada4bc901daff08ceb87c3f1 # v0.1.11
- name: Run Trivy vulnerability scanner
uses: aquasecurity/trivy-action@d710430a6722f083d3b36b8339ff66b32f22ee55 # v0.19.0
env:
TRIVY_USERNAME: ${{ github.actor }}
TRIVY_PASSWORD: ${{ secrets.GITHUB_TOKEN }}
with:
scan-type: "fs"
skip-dirs: "node_modules" # See https://github.com/aquasecurity/trivy/issues/1283
format: "sarif"
output: "trivy-results.sarif"
severity: "CRITICAL,HIGH"
exit-code: "1" # Fail the build!
- name: Upload Trivy scan results to GitHub Security tab
uses: github/codeql-action/upload-sarif@4355270be187e1b672a7a1c7c7bae5afdc1ab94a # v3.24.10
if: always() # Bypass non-zero exit code..
with:
sarif_file: "trivy-results.sarif"
- name: Send status to Slack
uses: digitalservicebund/notify-on-failure-gha@814d0c4b2ad6a3443e89c991f8657b10126510bf # v1.5.0
if: ${{ failure() }}
with:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
build-and-deploy:
needs:
- test
- audit-licenses
- vulnerability-scan
if: ${{ github.ref == 'refs/heads/main' }}
uses: ./.github/workflows/build-and-deploy.yml
# strategy:
# fail-fast: false
# matrix:
# packages:
# - name: digitalcheck-dito
# directory: packages/dito
# - name: digitalcheck-tool-finder
# directory: packages/tool-finder
with:
name: digitalcheck-tool-finder
directory: packages/tool-finder
secrets: inherit
# build-and-push-image:
# runs-on: ubuntu-latest
# if: ${{ github.ref == 'refs/heads/main' }}
# needs:
# - test
# - audit-licenses
# - vulnerability-scan
# permissions:
# contents: read
# id-token: write # This is used to complete the identity challenge with sigstore/fulcio.
# packages: write
# steps:
# - name: Checkout code
# uses: actions/checkout@v4
#
# - name: validate github workflow files to have pinned versions
# uses: digitalservicebund/github-actions-linter@dccac3ada437947aada4bc901daff08ceb87c3f1
#
# - name: Build image from Dockerfile
# run: |
# docker build -t ${{ env.IMAGE_NAME }}:${{ github.sha }} . -f packages/tool-finder/Dockerfile --build-arg COMMIT_SHA=${{ github.sha }}
#
# - name: Generate cosign vulnerability scan record
# # Third-party action, pin to commit SHA!
# # See https://docs.github.com/en/actions/security-guides/security-hardening-for-github-actions
# uses: aquasecurity/trivy-action@d710430a6722f083d3b36b8339ff66b32f22ee55 # v0.19.0
# with:
# image-ref: ${{ env.IMAGE_NAME }}:${{ github.sha }}
# format: "cosign-vuln"
# output: "vulnerabilities.json"
#
# - name: Upload cosign vulnerability scan record
# uses: actions/upload-artifact@v4
# with:
# name: "vulnerabilities.json"
# path: "vulnerabilities.json"
# if-no-files-found: error
#
# - name: Install cosign
# # Third-party action, pin to commit SHA!
# # See https://docs.github.com/en/actions/security-guides/security-hardening-for-github-actions
# uses: sigstore/cosign-installer@59acb6260d9c0ba8f4a2f9d9b48431a222b68e20 # v3.5.0
#
# - name: Login to container registry
# uses: docker/login-action@e92390c5fb421da1463c202d546fed0ec5c39f20 # v3.1.0
# with:
# registry: "ghcr.io"
# username: ${{ github.actor }}
# password: ${{ secrets.GITHUB_TOKEN }}
#
# - name: Push image
# run: |
# docker tag ${{ env.IMAGE_NAME }}:${{ github.sha }} ghcr.io/${{ env.IMAGE_NAME }}
# docker tag ${{ env.IMAGE_NAME }}:${{ github.sha }} ghcr.io/${{ env.IMAGE_NAME }}:${{ github.sha }}
# docker push --all-tags ghcr.io/${{ env.IMAGE_NAME }}
#
# - name: Sign the published Docker image
# run: cosign sign --yes ghcr.io/${{ env.IMAGE_NAME }}:${{ github.sha }}
#
# - name: Attest the vulnerability scan
# run: cosign attest --yes --replace --predicate vulnerabilities.json --type vuln ghcr.io/${{ env.IMAGE_NAME }}:${{ github.sha }}
#
# - name: Create SBOM
# uses: digitalservicebund/create-sbom@095884614dac5ea922dfcb09cce2e22f3d6391a3
# with:
# image_name: ${{ github.repository }}:${{ github.sha }}
#
# deploy:
# needs: [build-and-push-image]
# runs-on: ubuntu-latest
# if: ${{ github.ref == 'refs/heads/main' }}
# timeout-minutes: 10
# permissions:
# packages: read
# environment: production
# steps:
# - name: Deploy latest container image
# uses: digitalservicebund/argocd-deploy@4fac1bb67c92ed168f6d9b22f8779ce241a9e412 # v1.0.0
# with:
# environment: production
# version: ${{ github.sha }}
# deploying_repo: digitalcheck-tool-finder
# infra_repo: ${{ github.event.repository.name }}-infra
# deploy_key: ${{ secrets.DEPLOY_KEY }}
# app: digitalcheck-tool-finder-production
# argocd_pipeline_password: ${{ secrets.ARGOCD_PIPELINE_PASSWORD }}
# argocd_server: ${{ secrets.ARGOCD_SERVER }}
#
# - name: Report Deployment
# uses: digitalservicebund/github-actions/track-deployment@34a48d29a9c4cc2fd6710b8eb37e13618a08fa88 # v1.0.0
# with:
# project: ${{ github.event.repository.name }}
# environment: production
# metrics_deployment_webhook_url: ${{ secrets.METRICS_DEPLOYMENT_WEBHOOK_URL }}
# metrics_webhook_token: ${{ secrets.METRICS_WEBHOOK_TOKEN }}