summaryrefslogtreecommitdiffstats
path: root/nixos/tests
diff options
context:
space:
mode:
authorSandro <sandro.jaeckel@gmail.com>2021-04-08 22:32:12 +0200
committerGitHub <noreply@github.com>2021-04-08 22:32:12 +0200
commit26f16c1cef5d4467423bb78ade2e47b0f0c392f8 (patch)
tree8ca79d1d4b8c385d57553aa8714ec89bfea31a8c /nixos/tests
parente630784ffa30843e1afc82be0dad8c1bd3dad564 (diff)
parent20481bd027e378037bb912ca707549d838f43587 (diff)
Merge pull request #91318 from stephank/pkg-doh-proxy-rust
Diffstat (limited to 'nixos/tests')
-rw-r--r--nixos/tests/doh-proxy-rust.nix43
1 files changed, 43 insertions, 0 deletions
diff --git a/nixos/tests/doh-proxy-rust.nix b/nixos/tests/doh-proxy-rust.nix
new file mode 100644
index 000000000000..ca150cafab50
--- /dev/null
+++ b/nixos/tests/doh-proxy-rust.nix
@@ -0,0 +1,43 @@
+import ./make-test-python.nix ({ lib, pkgs, ... }: {
+ name = "doh-proxy-rust";
+ meta = with lib.maintainers; {
+ maintainers = [ stephank ];
+ };
+
+ nodes = {
+ 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
+ '';
+ };
+ };
+ services.doh-proxy-rust = {
+ enable = true;
+ flags = [
+ "--server-address=127.0.0.1:53"
+ ];
+ };
+ };
+ };
+
+ testScript = { nodes, ... }: ''
+ url = "http://localhost:3000/dns-query"
+ query = "AAABAAABAAAAAAAAAm5zB2V4YW1wbGUDb3JnAAABAAE=" # IN A ns.example.org.
+ bin_ip = r"$'\xC0\xA8\x00\x01'" # 192.168.0.1, as shell binary string
+
+ machine.wait_for_unit("bind.service")
+ machine.wait_for_unit("doh-proxy-rust.service")
+ machine.wait_for_open_port(53)
+ machine.wait_for_open_port(3000)
+ machine.succeed(f"curl --fail '{url}?dns={query}' | grep -qF {bin_ip}")
+ '';
+})