name: Test and Build on: push: branches: - main pull_request: types: - opened - synchronize jobs: test: container: image: docker.matri.cx/nix-runner:v0.1.0 credentials: username: ${{ secrets.REGISTRY_USERNAME }} password: ${{ secrets.REGISTRY_PASSWORD }} steps: - name: Checkout code uses: actions/checkout@v3 - name: Set up cache for Cabal uses: actions/cache@v4 with: path: | ~/.cache/cabal ~/.config/cabal ~/.local/state/cabal key: cabal-${{ hashFiles('tricu.cabal') }} restore-keys: | cabal- - name: Set up cache for Nix uses: actions/cache@v4 with: path: | /nix/store /nix/var/nix/cache key: nix-${{ hashFiles('flake.lock') }} restore-keys: | nix- - name: Initialize Cabal and update package list run: | nix develop --command cabal update - name: Run test suite run: | nix develop --command cabal test build: needs: test container: image: docker.matri.cx/nix-runner:v0.1.0 credentials: username: ${{ secrets.REGISTRY_USERNAME }} password: ${{ secrets.REGISTRY_PASSWORD }} steps: - name: Checkout code uses: actions/checkout@v3 - name: Set up cache for Cabal uses: actions/cache@v4 with: path: | ~/.cache/cabal ~/.config/cabal ~/.local/state/cabal key: cabal-${{ hashFiles('tricu.cabal') }} restore-keys: | cabal- - name: Set up cache for Nix uses: actions/cache@v4 with: path: | /nix/store /nix/var/nix/cache key: nix-${{ hashFiles('flake.lock') }} restore-keys: | nix- - name: Build binary run: | nix build ls -alh ./result/bin/tricu