2020-10-20 10:04:41 +00:00
|
|
|
# This test runs PowerDNS authoritative server with the
|
|
|
|
# generic MySQL backend (gmysql) to connect to a
|
|
|
|
# MariaDB server using UNIX sockets authentication.
|
|
|
|
|
|
|
|
import ./make-test-python.nix (
|
|
|
|
{ pkgs, lib, ... }:
|
|
|
|
{
|
2018-02-17 13:36:28 +00:00
|
|
|
name = "powerdns";
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2018-07-20 20:56:59 +00:00
|
|
|
nodes.server =
|
|
|
|
{ ... }:
|
|
|
|
{
|
2018-02-17 13:36:28 +00:00
|
|
|
services.powerdns.enable = true;
|
2020-10-20 10:04:41 +00:00
|
|
|
services.powerdns.extraConfig = ''
|
|
|
|
launch=gmysql
|
|
|
|
gmysql-user=pdns
|
2022-03-14 13:51:32 +00:00
|
|
|
zone-cache-refresh-interval=0
|
2020-10-20 10:04:41 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
services.mysql = {
|
|
|
|
enable = true;
|
|
|
|
package = pkgs.mariadb;
|
|
|
|
ensureDatabases = [ "powerdns" ];
|
|
|
|
ensureUsers = lib.singleton {
|
|
|
|
name = "pdns";
|
|
|
|
ensurePermissions = {
|
|
|
|
"powerdns.*" = "ALL PRIVILEGES";
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
2020-10-20 10:04:41 +00:00
|
|
|
};
|
|
|
|
};
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2020-10-20 10:04:41 +00:00
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
dnsutils
|
|
|
|
powerdns
|
|
|
|
mariadb
|
|
|
|
];
|
2018-02-17 13:36:28 +00:00
|
|
|
};
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2018-02-17 13:36:28 +00:00
|
|
|
testScript = ''
|
2020-10-20 10:04:41 +00:00
|
|
|
with subtest("PowerDNS database exists"):
|
|
|
|
server.wait_for_unit("mysql")
|
|
|
|
server.succeed("echo 'SHOW DATABASES;' | sudo -u pdns mysql -u pdns >&2")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2020-10-20 10:04:41 +00:00
|
|
|
with subtest("Loading the MySQL schema works"):
|
|
|
|
server.succeed(
|
|
|
|
"sudo -u pdns mysql -u pdns -D powerdns <"
|
|
|
|
"${pkgs.powerdns}/share/doc/pdns/schema.mysql.sql"
|
|
|
|
)
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2020-10-20 10:04:41 +00:00
|
|
|
with subtest("PowerDNS server starts"):
|
|
|
|
server.wait_for_unit("pdns")
|
|
|
|
server.succeed("dig version.bind txt chaos @127.0.0.1 >&2")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2020-10-20 10:04:41 +00:00
|
|
|
with subtest("Adding an example zone works"):
|
|
|
|
# Extract configuration file needed by pdnsutil
|
2023-02-25 16:02:36 +00:00
|
|
|
pdnsutil = "sudo -u pdns pdnsutil "
|
2020-10-20 10:04:41 +00:00
|
|
|
server.succeed(f"{pdnsutil} create-zone example.com ns1.example.com")
|
|
|
|
server.succeed(f"{pdnsutil} add-record example.com ns1 A 192.168.1.2")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2020-10-20 10:04:41 +00:00
|
|
|
with subtest("Querying the example zone works"):
|
|
|
|
reply = server.succeed("dig +noall +answer ns1.example.com @127.0.0.1")
|
|
|
|
assert (
|
|
|
|
"192.168.1.2" in reply
|
|
|
|
), f""""
|
|
|
|
The reply does not contain the expected IP address:
|
|
|
|
Expected:
|
|
|
|
ns1.example.com. 3600 IN A 192.168.1.2
|
|
|
|
Reply:
|
|
|
|
{reply}"""
|
2018-02-17 13:36:28 +00:00
|
|
|
'';
|
|
|
|
}
|
|
|
|
)
|