-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathflake.nix
68 lines (65 loc) · 1.76 KB
/
flake.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
nix-vm-test.url = "github:numtide/nix-vm-test";
systems.url = "github:nix-systems/default";
};
outputs = inputs @ {
flake-parts,
nixpkgs,
nix-vm-test,
self,
...
}:
flake-parts.lib.mkFlake {inherit inputs;} {
systems = nixpkgs.lib.systems.flakeExposed;
flake = {
overlays.default = import ./overlay.nix;
nixosModules.paretosecurity = ./modules/paretosecurity.nix;
nixosModules.default = self.nixosModules.paretosecurity;
};
perSystem = {
config,
pkgs,
lib,
self,
system,
...
}: let
flakePackage = import ./package.nix {inherit pkgs lib;};
testPackage = {
distro,
version,
script,
}:
(inputs.nix-vm-test.lib.x86_64-linux.${distro}.${version} {
sharedDirs.packageDir = {
source = "${toString ./.}/pkg";
target = "/mnt/package";
};
testScript = builtins.readFile "${toString ./.}/test/integration/${script}";
})
.driver;
in {
packages.default = flakePackage;
checks.test-nixos = import ./test/integration/nixos.nix {
inherit pkgs system flakePackage;
};
packages.test-debian = testPackage {
distro = "debian";
version = "13";
script = "debian.py";
};
packages.test-fedora = testPackage {
distro = "fedora";
version = "40";
script = "fedora.py";
};
packages.test-ubuntu = testPackage {
distro = "ubuntu";
version = "23_10";
script = "ubuntu.py";
};
};
};
}