name: "Build and populate cache" on: pull_request: push: branches: - master #schedule: # rebuild everyday at 4:55 # TIP: Choose a random time here so not all repositories are build at once: # https://www.random.org/clock-times/?num=1&earliest=01%3A00&latest=08%3A00&interval=5&format=html&rnd=new #- cron: '55 4 * * *' jobs: tests: strategy: matrix: # Set this to notify the global nur package registry that changes are # available. # # The repo name as used in # https://github.com/nix-community/NUR/blob/master/repos.json nurRepo: - 'fliegendewurst' # Set this to cache your build results in cachix for faster builds # in CI and for everyone who uses your cache. # # Format: Your cachix cache host name without the ".cachix.org" suffix. # Example: mycache (for mycache.cachix.org) # # For this to work, you also need to set the CACHIX_SIGNING_KEY or # CACHIX_AUTH_TOKEN secret in your repository secrets settings in # Github found at # https://github.com//nur-packages/settings/secrets #cachixName: # - nixPath: # - nixpkgs=channel:nixos-unstable # - nixpkgs=channel:nixpkgs-unstable - nixpkgs=channel:nixos-24.05 runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install nix uses: DeterminateSystems/nix-installer-action@main with: nix_path: "${{ matrix.nixPath }}" # nix 2.6 breaks restrict-eval, when using the NIX_PATH # see https://github.com/NixOS/nix/issues/5980 extra_nix_config: | experimental-features = nix-command flakes access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - uses: DeterminateSystems/magic-nix-cache-action@main - name: Show nixpkgs version run: nix-instantiate --eval -E '(import {}).lib.version' #- name: Setup cachix # uses: cachix/cachix-action@v10 # # Don't replace here! # if: ${{ matrix.cachixName != '' }} # with: # name: ${{ matrix.cachixName }} # signingKey: '${{ secrets.CACHIX_SIGNING_KEY }}' # authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}' - name: Check evaluation run: | nix-env -f . -qa \* --meta --xml \ --allowed-uris https://static.rust-lang.org \ --option restrict-eval true \ --option allow-import-from-derivation true \ --drv-path --show-trace \ -I nixpkgs=$(nix-instantiate --find-file nixpkgs) \ -I $PWD - name: Build nix packages run: nix shell -f '' nix-build-uncached -c nix-build-uncached ci.nix -A cacheOutputs - name: Trigger NUR update # Don't replace here! if: ${{ matrix.nurRepo != '' }} run: curl -XPOST "https://nur-update.nix-community.org/update?repo=${{ matrix.nurRepo }}"