mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-15 18:56:16 +02:00
41 lines
1.3 KiB
Nix
41 lines
1.3 KiB
Nix
|
{ nixpkgs, ... }:
|
||
|
|
||
|
{
|
||
|
name = "cgroups";
|
||
|
|
||
|
nodes =
|
||
|
{
|
||
|
host =
|
||
|
{ config, pkgs, ... }:
|
||
|
{ virtualisation.additionalPaths = [ pkgs.stdenvNoCC ];
|
||
|
nix.extraOptions =
|
||
|
''
|
||
|
extra-experimental-features = nix-command auto-allocate-uids cgroups
|
||
|
extra-system-features = uid-range
|
||
|
'';
|
||
|
nix.settings.use-cgroups = true;
|
||
|
nix.nixPath = [ "nixpkgs=${nixpkgs}" ];
|
||
|
};
|
||
|
};
|
||
|
|
||
|
testScript = { nodes }: ''
|
||
|
start_all()
|
||
|
|
||
|
host.wait_for_unit("multi-user.target")
|
||
|
|
||
|
# Start build in background
|
||
|
host.execute("NIX_REMOTE=daemon nix build --auto-allocate-uids --file ${./hang.nix} >&2 &")
|
||
|
service = "/sys/fs/cgroup/system.slice/nix-daemon.service"
|
||
|
|
||
|
# Wait for cgroups to be created
|
||
|
host.succeed(f"until [ -e {service}/nix-daemon ]; do sleep 1; done", timeout=30)
|
||
|
host.succeed(f"until [ -e {service}/nix-build-uid-* ]; do sleep 1; done", timeout=30)
|
||
|
|
||
|
# Check that there aren't processes where there shouldn't be, and that there are where there should be
|
||
|
host.succeed(f'[ -z "$(cat {service}/cgroup.procs)" ]')
|
||
|
host.succeed(f'[ -n "$(cat {service}/nix-daemon/cgroup.procs)" ]')
|
||
|
host.succeed(f'[ -n "$(cat {service}/nix-build-uid-*/cgroup.procs)" ]')
|
||
|
'';
|
||
|
|
||
|
}
|