2023-11-20 20:16:02 +00:00
|
|
|
{
|
|
|
|
system ? builtins.currentSystem,
|
|
|
|
config ? { },
|
|
|
|
pkgs ? import ../.. { inherit system config; },
|
|
|
|
}:
|
|
|
|
|
|
|
|
with import ../lib/testing-python.nix { inherit system pkgs; };
|
|
|
|
|
2022-04-18 10:22:39 +00:00
|
|
|
let
|
|
|
|
hosts = ''
|
|
|
|
192.168.2.101 acme.test
|
|
|
|
'';
|
|
|
|
|
|
|
|
in
|
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
builtins.listToAttrs (
|
|
|
|
builtins.map
|
|
|
|
(nginxPackage: {
|
|
|
|
name = pkgs.lib.getName nginxPackage;
|
|
|
|
value = makeTest {
|
|
|
|
name = "nginx-http3-${pkgs.lib.getName nginxPackage}";
|
|
|
|
meta.maintainers = with pkgs.lib.maintainers; [ izorkin ];
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
nodes = {
|
|
|
|
server =
|
|
|
|
{ lib, pkgs, ... }:
|
|
|
|
{
|
|
|
|
networking = {
|
|
|
|
interfaces.eth1 = {
|
|
|
|
ipv4.addresses = [
|
|
|
|
{
|
|
|
|
address = "192.168.2.101";
|
|
|
|
prefixLength = 24;
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
extraHosts = hosts;
|
|
|
|
firewall.allowedTCPPorts = [ 443 ];
|
|
|
|
firewall.allowedUDPPorts = [ 443 ];
|
|
|
|
};
|
2022-04-18 10:22:39 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
security.pki.certificates = [
|
|
|
|
(builtins.readFile ./common/acme/server/ca.cert.pem)
|
|
|
|
];
|
2022-06-25 18:31:26 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
services.nginx = {
|
|
|
|
enable = true;
|
|
|
|
package = nginxPackage;
|
2022-04-18 10:22:39 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
virtualHosts."acme.test" = {
|
|
|
|
onlySSL = true;
|
|
|
|
sslCertificate = ./common/acme/server/acme.test.cert.pem;
|
|
|
|
sslCertificateKey = ./common/acme/server/acme.test.key.pem;
|
|
|
|
http2 = true;
|
|
|
|
http3 = true;
|
|
|
|
http3_hq = false;
|
|
|
|
quic = true;
|
|
|
|
reuseport = true;
|
|
|
|
root = lib.mkForce (
|
|
|
|
pkgs.runCommandLocal "testdir" { } ''
|
|
|
|
mkdir "$out"
|
|
|
|
cat > "$out/index.html" <<EOF
|
|
|
|
<html><body>Hello World!</body></html>
|
|
|
|
EOF
|
|
|
|
cat > "$out/example.txt" <<EOF
|
|
|
|
Check http3 protocol.
|
|
|
|
EOF
|
|
|
|
''
|
|
|
|
);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2022-04-18 10:22:39 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
client =
|
|
|
|
{ pkgs, ... }:
|
|
|
|
{
|
|
|
|
environment.systemPackages = [ pkgs.curlHTTP3 ];
|
|
|
|
networking = {
|
|
|
|
interfaces.eth1 = {
|
|
|
|
ipv4.addresses = [
|
|
|
|
{
|
|
|
|
address = "192.168.2.201";
|
|
|
|
prefixLength = 24;
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
extraHosts = hosts;
|
|
|
|
};
|
2022-04-18 10:22:39 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
security.pki.certificates = [
|
|
|
|
(builtins.readFile ./common/acme/server/ca.cert.pem)
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
testScript = ''
|
|
|
|
start_all()
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
server.wait_for_unit("nginx")
|
|
|
|
server.wait_for_open_port(443)
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
# Check http connections
|
|
|
|
client.succeed("curl --verbose --http3-only https://acme.test | grep 'Hello World!'")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
# Check downloadings
|
|
|
|
client.succeed("curl --verbose --http3-only https://acme.test/example.txt --output /tmp/example.txt")
|
|
|
|
client.succeed("cat /tmp/example.txt | grep 'Check http3 protocol.'")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
# Check header reading
|
|
|
|
client.succeed("curl --verbose --http3-only --head https://acme.test | grep 'content-type'")
|
|
|
|
client.succeed("curl --verbose --http3-only --head https://acme.test | grep 'HTTP/3 200'")
|
|
|
|
client.succeed("curl --verbose --http3-only --head https://acme.test/error | grep 'HTTP/3 404'")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
# Check change User-Agent
|
|
|
|
client.succeed("curl --verbose --http3-only --user-agent 'Curl test 3.0' https://acme.test")
|
|
|
|
server.succeed("cat /var/log/nginx/access.log | grep 'Curl test 3.0'")
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-11-20 20:16:02 +00:00
|
|
|
server.shutdown()
|
|
|
|
client.shutdown()
|
2024-12-10 19:26:33 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
})
|
2023-11-20 20:16:02 +00:00
|
|
|
[
|
|
|
|
pkgs.angieQuic
|
|
|
|
pkgs.nginxQuic
|
|
|
|
]
|
|
|
|
)
|