Chore/refactor config #15
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Pull Request Check | |
on: | |
pull_request: | |
branches: ['main'] | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
node-version: [22.x] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
cache: 'npm' | |
- run: npm ci | |
- run: npm run lint | |
- run: npm run build --if-present | |
- run: npm test | |
- name: Upload test coverage | |
uses: actions/upload-artifact@v4 | |
with: | |
name: coverage | |
path: coverage/ | |
if-no-files-found: warn | |
docker-build: | |
runs-on: ubuntu-latest | |
# Ensures the docker-build job runs after the build job | |
needs: build | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
with: | |
driver: docker-container | |
- name: Build Docker image for validation | |
uses: docker/build-push-action@v5 | |
with: | |
context: . | |
tags: metalheads/metal-api:pr-${{ github.event.pull_request.number }} | |
push: false # Keeps the image local to the runner | |
load: true # Loads the image into the local Docker daemon | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
- name: Save Docker image as an artifact | |
run: docker save metalheads/metal-api:pr-${{ github.event.pull_request.number }} -o metal-api.tar | |
- name: Verify image tar exists before upload | |
run: ls -l metal-api.tar | |
- name: Upload image artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: metal-api-image | |
path: metal-api.tar | |
vulnerability-scan: | |
runs-on: ubuntu-latest | |
needs: docker-build # Runs after docker-build job | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Download image artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: metal-api-image | |
- name: Load Docker image | |
run: docker load -i metal-api.tar | |
- name: Install Grype | |
run: | | |
curl -sSfL https://raw.githubusercontent.com/anchore/grype/main/install.sh | sh | |
- name: Run Grype for Vulnerability Scanning | |
run: | | |
./bin/grype metalheads/metal-api:pr-${{ github.event.pull_request.number }} --fail-on high |