nixos/dnsdist: add test
This commit is contained in:
parent
30ae792cd0
commit
612ad7776a
3 changed files with 54 additions and 1 deletions
|
@ -104,6 +104,7 @@ in
|
||||||
discourse = handleTest ./discourse.nix {};
|
discourse = handleTest ./discourse.nix {};
|
||||||
dnscrypt-proxy2 = handleTestOn ["x86_64-linux"] ./dnscrypt-proxy2.nix {};
|
dnscrypt-proxy2 = handleTestOn ["x86_64-linux"] ./dnscrypt-proxy2.nix {};
|
||||||
dnscrypt-wrapper = handleTestOn ["x86_64-linux"] ./dnscrypt-wrapper {};
|
dnscrypt-wrapper = handleTestOn ["x86_64-linux"] ./dnscrypt-wrapper {};
|
||||||
|
dnsdist = handleTest ./dnsdist.nix {};
|
||||||
doas = handleTest ./doas.nix {};
|
doas = handleTest ./doas.nix {};
|
||||||
docker = handleTestOn ["x86_64-linux"] ./docker.nix {};
|
docker = handleTestOn ["x86_64-linux"] ./docker.nix {};
|
||||||
docker-rootless = handleTestOn ["x86_64-linux"] ./docker-rootless.nix {};
|
docker-rootless = handleTestOn ["x86_64-linux"] ./docker-rootless.nix {};
|
||||||
|
|
48
nixos/tests/dnsdist.nix
Normal file
48
nixos/tests/dnsdist.nix
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
import ./make-test-python.nix (
|
||||||
|
{ pkgs, ... }: {
|
||||||
|
name = "dnsdist";
|
||||||
|
meta = with pkgs.lib; {
|
||||||
|
maintainers = with maintainers; [ jojosch ];
|
||||||
|
};
|
||||||
|
|
||||||
|
machine = { pkgs, lib, ... }: {
|
||||||
|
services.bind = {
|
||||||
|
enable = true;
|
||||||
|
extraOptions = "empty-zones-enable no;";
|
||||||
|
zones = lib.singleton {
|
||||||
|
name = ".";
|
||||||
|
master = true;
|
||||||
|
file = pkgs.writeText "root.zone" ''
|
||||||
|
$TTL 3600
|
||||||
|
. IN SOA ns.example.org. admin.example.org. ( 1 3h 1h 1w 1d )
|
||||||
|
. IN NS ns.example.org.
|
||||||
|
|
||||||
|
ns.example.org. IN A 192.168.0.1
|
||||||
|
ns.example.org. IN AAAA abcd::1
|
||||||
|
|
||||||
|
1.0.168.192.in-addr.arpa IN PTR ns.example.org.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
services.dnsdist = {
|
||||||
|
enable = true;
|
||||||
|
listenPort = 5353;
|
||||||
|
extraConfig = ''
|
||||||
|
newServer({address="127.0.0.1:53", name="local-bind"})
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [ dig ];
|
||||||
|
};
|
||||||
|
|
||||||
|
testScript = ''
|
||||||
|
machine.wait_for_unit("bind.service")
|
||||||
|
machine.wait_for_open_port(53)
|
||||||
|
machine.succeed("dig @127.0.0.1 +short -x 192.168.0.1 | grep -qF ns.example.org")
|
||||||
|
|
||||||
|
machine.wait_for_unit("dnsdist.service")
|
||||||
|
machine.wait_for_open_port(5353)
|
||||||
|
machine.succeed("dig @127.0.0.1 -p 5353 +short -x 192.168.0.1 | grep -qF ns.example.org")
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
)
|
|
@ -1,7 +1,7 @@
|
||||||
{ lib, stdenv, fetchurl, pkg-config, systemd
|
{ lib, stdenv, fetchurl, pkg-config, systemd
|
||||||
, boost, libsodium, libedit, re2
|
, boost, libsodium, libedit, re2
|
||||||
, net-snmp, lua, protobuf, openssl, zlib, h2o
|
, net-snmp, lua, protobuf, openssl, zlib, h2o
|
||||||
, nghttp2
|
, nghttp2, nixosTests
|
||||||
}:
|
}:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
|
@ -39,6 +39,10 @@ stdenv.mkDerivation rec {
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
passthru.tests = {
|
||||||
|
inherit (nixosTests) dnsdist;
|
||||||
|
};
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
description = "DNS Loadbalancer";
|
description = "DNS Loadbalancer";
|
||||||
homepage = "https://dnsdist.org";
|
homepage = "https://dnsdist.org";
|
||||||
|
|
Loading…
Reference in a new issue