Declarative configuration of your continuous integration CI in Nix
Tom Hubrecht
829e83af9c
All checks were successful
Run pre-commit on all files / pre-push (push) Successful in 25s
|
||
---|---|---|
.forgejo/workflows | ||
LICENSES | ||
modules | ||
npins | ||
.envrc | ||
.gitignore | ||
default.nix | ||
LICENSE | ||
README.md | ||
REUSE.toml | ||
shell.nix |
Integration of Forgejo/Gitea/GitHub workflows with Nix
Features
- Provides checked workflow files thanks to action-validator
- You can use all the power of Nix to declare workflows:
genAttrs
,readDir
, ...
Getting started
npins
- Add
nix-actions
to your sources:
npins add git https://git.dgnum.eu/DGNum/nix-actions
- Integrate workflows to
shell.nix
:
let
sources = import ./npins;
workflows = (import sources.nix-actions { }).install {
src = ./.;
workflows.build = {
name = "Build something";
on = [ "push" ];
...
};
};
in
with (import sources.nixpkgs { });
mkShell {
packages = [ ... ];
inherit (workflows) shellHook;
}
Options
src
: the root of the project, required for the workflows checksplatform
: one offorgejo
,gitea
, orgithub
, this will impact the location of the installed workflow files. Defaults toforgejo
.removeUnknown
: whether to remove workflow files not created bynix-actions
. Defaults totrue
.
Ensuring all workflows are up to date
Simply add a new workflow for this !
{
name = "Check workflows";
on = [
"pull_request"
"push"
];
jobs = {
check_workflows = {
runs-on = "nix";
steps = [
{ uses = "actions/checkout@v3"; }
{
name = "Check that the workflows are up to date";
run = "nix-shell --run '[ $(git status --porcelain | wc -l) -eq 0 ]'";
}
];
};
};
}
Examples
The main example is used by the DGNum infrastructure, workflows are defined in https://git.dgnum.eu/DGNum/infrastructure/src/branch/main/workflows . Be aware that the runners used there are a bit funky and already come with Lix installed (c.f. https://git.hubrecht.ovh/hubrecht/nix-modules/src/branch/main/services/forgejo-nix-runners/default.nix ).