mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-27 17:33:09 +00:00
Merge pull request #125474 from jojosch/dnsdist-1.6.0
This commit is contained in:
commit
42cbcca501
@ -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,19 +1,26 @@
|
|||||||
{ 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, nixosTests
|
||||||
}:
|
}:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
pname = "dnsdist";
|
pname = "dnsdist";
|
||||||
version = "1.5.2";
|
version = "1.7.0";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "https://downloads.powerdns.com/releases/dnsdist-${version}.tar.bz2";
|
url = "https://downloads.powerdns.com/releases/dnsdist-${version}.tar.bz2";
|
||||||
sha256 = "sha256-K9e1M9Lae7RWY8amLkftDS8Zigd/WNxzDEY7eXNjZ0k=";
|
sha256 = "sha256-eMxyywzPf7Xz8vrgnHntplpSVjdNoJu1Qbc16mho/GQ=";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# Disable tests requiring networking:
|
||||||
|
# "Error connecting to new server with address 192.0.2.1:53: connecting socket to 192.0.2.1:53: Network is unreachable"
|
||||||
|
./disable-network-tests.patch
|
||||||
|
];
|
||||||
|
|
||||||
nativeBuildInputs = [ pkg-config protobuf ];
|
nativeBuildInputs = [ pkg-config protobuf ];
|
||||||
buildInputs = [ systemd boost libsodium libedit re2 net-snmp lua openssl zlib h2o ];
|
buildInputs = [ systemd boost libsodium libedit re2 net-snmp lua openssl zlib h2o nghttp2 ];
|
||||||
|
|
||||||
configureFlags = [
|
configureFlags = [
|
||||||
"--with-libsodium"
|
"--with-libsodium"
|
||||||
@ -32,10 +39,14 @@ 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";
|
||||||
license = licenses.gpl2;
|
license = licenses.gpl2;
|
||||||
maintainers = with maintainers; [ SuperSandro2000 ];
|
maintainers = with maintainers; [ jojosch ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
28
pkgs/servers/dns/dnsdist/disable-network-tests.patch
Normal file
28
pkgs/servers/dns/dnsdist/disable-network-tests.patch
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
diff --git a/test-dnsdisttcp_cc.cc b/test-dnsdisttcp_cc.cc
|
||||||
|
index 1fbb00e..dc04137 100644
|
||||||
|
--- a/test-dnsdisttcp_cc.cc
|
||||||
|
+++ b/test-dnsdisttcp_cc.cc
|
||||||
|
@@ -848,6 +848,7 @@ BOOST_AUTO_TEST_CASE(test_IncomingConnectionWithProxyProtocol_SelfAnswered)
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(test_IncomingConnection_BackendNoOOOR)
|
||||||
|
{
|
||||||
|
+ return;
|
||||||
|
auto local = getBackendAddress("1", 80);
|
||||||
|
ClientState localCS(local, true, false, false, "", {});
|
||||||
|
auto tlsCtx = std::make_shared<MockupTLSCtx>();
|
||||||
|
@@ -1711,6 +1712,7 @@ BOOST_AUTO_TEST_CASE(test_IncomingConnection_BackendNoOOOR)
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(test_IncomingConnectionOOOR_BackendOOOR)
|
||||||
|
{
|
||||||
|
+ return;
|
||||||
|
auto local = getBackendAddress("1", 80);
|
||||||
|
ClientState localCS(local, true, false, false, "", {});
|
||||||
|
/* enable out-of-order on the front side */
|
||||||
|
@@ -3677,6 +3679,7 @@ BOOST_AUTO_TEST_CASE(test_IncomingConnectionOOOR_BackendOOOR)
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(test_IncomingConnectionOOOR_BackendNotOOOR)
|
||||||
|
{
|
||||||
|
+ return;
|
||||||
|
auto local = getBackendAddress("1", 80);
|
||||||
|
ClientState localCS(local, true, false, false, "", {});
|
||||||
|
/* enable out-of-order on the front side */
|
Loading…
Reference in New Issue
Block a user