Files
nixpkgs/nixos/tests/nzbget.nix
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

55 lines
1.4 KiB
Nix

{ pkgs, ... }:
{
name = "nzbget";
meta = with pkgs.lib.maintainers; {
maintainers = [
aanderse
flokli
];
};
nodes = {
server =
{ ... }:
{
services.nzbget.enable = true;
# provide some test settings
services.nzbget.settings = {
"MainDir" = "/var/lib/nzbget";
"DirectRename" = true;
"DiskSpace" = 0;
"Server1.Name" = "this is a test";
};
# hack, don't add (unfree) unrar to nzbget's path,
# so we can run this test in CI
systemd.services.nzbget.path = pkgs.lib.mkForce [ pkgs.p7zip ];
};
};
testScript =
{ nodes, ... }:
''
start_all()
server.wait_for_unit("nzbget.service")
server.wait_for_unit("network.target")
server.wait_for_open_port(6789)
assert "This file is part of nzbget" in server.succeed(
"curl -f -s -u nzbget:tegbzn6789 http://127.0.0.1:6789"
)
server.succeed(
"${pkgs.nzbget}/bin/nzbget -n -o Control_iP=127.0.0.1 -o Control_port=6789 -o Control_password=tegbzn6789 -V"
)
config = server.succeed("${nodes.server.systemd.services.nzbget.serviceConfig.ExecStart} --printconfig")
# confirm the test settings are applied
assert 'MainDir = "/var/lib/nzbget"' in config
assert 'DirectRename = "yes"' in config
assert 'DiskSpace = "0"' in config
assert 'Server1.Name = "this is a test"' in config
'';
}