Skip to content

nixpkgs-review #365681 #17

nixpkgs-review #365681

nixpkgs-review #365681 #17

# This is a basic workflow to help you get started with Actions
name: nixpkgs-review a nixpkgs PR
run-name: 'nixpkgs-review #${{ github.event.inputs.pr }}'
# Controls when the action will run. Triggers the workflow on push or pull request
# events but only for the master branch
on:
workflow_dispatch:
inputs:
pr:
description: "PR number"
type: number
required: true
extra-args:
description: "Extra args for nixpkgs-review"
type: string
default: ""
required: false
free-space:
description: "Run workflow to increase free space (tradeoff: runs faster vs runs bigger PRs)"
type: boolean
default: true
required: true
concurrency:
group: review-${{ github.event.inputs.pr }}
cancel-in-progress: true
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
# This workflow contains a single job called "build"
build:
name: 'nixpkgs-review #${{ github.event.inputs.pr }}'
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- name: Free up space
uses: lucasew/action-i-only-care-about-nix@main
if: ${{ github.event.inputs.free-space == 'true' }}
- name: Prepare for Nix if cleaned up
run: |
sudo mkdir -p /nix/build
df -h
- name: Install Nix
uses: cachix/install-nix-action@v30
with:
nix_path: nixpkgs=channel:nixos-unstable
extra_nix_config: |
experimental-features = nix-command flakes
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
build-dir = /nix/build
- name: Try to fetch nixpkgs clone from cache
id: git-nixpkgs
uses: actions/cache@v4
with:
path: |
nixpkgs
key: git-nixpkgs
- name: Fetch nixpkgs from git if not
if: steps.git-nixpkgs.outputs.cache-hit != 'true'
run: git clone https://github.com/NixOS/nixpkgs nixpkgs
- uses: DeterminateSystems/magic-nix-cache-action@main
- name: Run review
env:
GITHUB_TOKEN: ${{ secrets.GH_TOKEN_NIXPKGS_REVIEW }}
run: |
{ while true; do df -h; uptime; sleep 60; done } &
git config --global user.email "user@example.com"
git config --global user.name "user"
cd nixpkgs
nix run nixpkgs#nixpkgs-review -- pr ${{ github.event.inputs.pr }} --post-result --no-shell ${{ github.event.inputs.extra-args }}
- uses: actions/upload-artifact@v4
with:
name: build-logs
path: /nix/var/log/nix/drvs
include-hidden-files: true