push sheeet
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

This commit is contained in:
Dark Steveneq
2025-10-09 14:15:47 +02:00
commit 646b892680
49168 changed files with 5897842 additions and 0 deletions

View File

@@ -0,0 +1,47 @@
# A basic test with no webserver, no API, just checking DNS functionality
{
lib,
pkgs,
...
}:
{
name = "pihole-ftl-basic";
meta.maintainers = with lib.maintainers; [ averyvigolo ];
nodes.machine =
{ pkgs, lib, ... }:
{
services.pihole-ftl = {
enable = true;
openFirewallDNS = true;
};
environment.systemPackages = with pkgs; [ dig ];
};
nodes.client =
{ pkgs, lib, ... }:
{
environment.systemPackages = with pkgs; [ dig ];
};
testScript =
{ nodes, ... }:
''
machine.wait_for_unit("pihole-ftl.service")
machine.wait_for_open_port(53)
client.wait_for_unit("network.target")
with subtest("the pi-hole machine resolves properly"):
ret, out = machine.execute("dig @localhost +short pi.hole")
assert ret == 0, "pi.hole should resolve on the local machine"
assert out.rstrip() == "127.0.0.1", "pi.hole should resolve to localhost on the local machine"
machine_address = "${(builtins.head nodes.machine.networking.interfaces.eth1.ipv4.addresses).address}"
with subtest("a client machine resolves properly"):
ret, out = client.execute(f"dig @{machine_address} +short pi.hole")
assert ret == 0, "pi.hole should resolve on a client machine"
assert out.rstrip() == machine_address, "pi.hole should resolve to the machine's address"
'';
}