nixos/dnsdist: add test

This commit is contained in:
Johannes Schleifenbaum 2022-01-18 08:59:57 +01:00
parent 30ae792cd0
commit 612ad7776a
No known key found for this signature in database
GPG key ID: 059093B1A278BCD0
3 changed files with 54 additions and 1 deletions

View file

@ -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
View 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")
'';
}
)

View file

@ -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";