name: CI on: [push, pull_request] # Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages permissions: contents: read pages: write id-token: write # 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" cancel-in-progress: false jobs: build-and-push: runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v3 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Build and push Docker image uses: docker/build-push-action@v5 with: context: . push: true tags: user/app:latest cache-from: type=gha cache-to: type=gha,mode=max test: strategy: matrix: os: [ubuntu-latest] environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} runs-on: ${{matrix.os}} steps: - name: Checkout uses: actions/checkout@v4 with: path: uvm32 - name: Build run: make dockerbuild_cached && make docker working-directory: uvm32 - name: CI test run: make dockerci working-directory: uvm32 - name: Setup Pages uses: actions/configure-pages@v5 - name: Upload Artifact uses: actions/upload-pages-artifact@v3 with: path: uvm32/test/badge.svg name: badge.svg - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v4