nixos/nginx: add test for status page
This commit is contained in:
parent
d803f78e7c
commit
25b7b82ee0
|
@ -538,6 +538,7 @@ in {
|
||||||
nginx-pubhtml = handleTest ./nginx-pubhtml.nix {};
|
nginx-pubhtml = handleTest ./nginx-pubhtml.nix {};
|
||||||
nginx-sandbox = handleTestOn ["x86_64-linux"] ./nginx-sandbox.nix {};
|
nginx-sandbox = handleTestOn ["x86_64-linux"] ./nginx-sandbox.nix {};
|
||||||
nginx-sso = handleTest ./nginx-sso.nix {};
|
nginx-sso = handleTest ./nginx-sso.nix {};
|
||||||
|
nginx-status-page = handleTest ./nginx-status-page.nix {};
|
||||||
nginx-variants = handleTest ./nginx-variants.nix {};
|
nginx-variants = handleTest ./nginx-variants.nix {};
|
||||||
nginx-proxyprotocol = handleTest ./nginx-proxyprotocol {};
|
nginx-proxyprotocol = handleTest ./nginx-proxyprotocol {};
|
||||||
nifi = handleTestOn ["x86_64-linux"] ./web-apps/nifi.nix {};
|
nifi = handleTestOn ["x86_64-linux"] ./web-apps/nifi.nix {};
|
||||||
|
|
72
nixos/tests/nginx-status-page.nix
Normal file
72
nixos/tests/nginx-status-page.nix
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
import ./make-test-python.nix ({ pkgs, ... }: {
|
||||||
|
name = "nginx-status-page";
|
||||||
|
meta = with pkgs.lib.maintainers; {
|
||||||
|
maintainers = [ h7x4 ];
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes = {
|
||||||
|
webserver = { ... }: {
|
||||||
|
virtualisation.vlans = [ 1 ];
|
||||||
|
|
||||||
|
networking = {
|
||||||
|
useNetworkd = true;
|
||||||
|
useDHCP = false;
|
||||||
|
firewall.enable = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.network.networks."01-eth1" = {
|
||||||
|
name = "eth1";
|
||||||
|
networkConfig.Address = "10.0.0.1/24";
|
||||||
|
};
|
||||||
|
|
||||||
|
services.nginx = {
|
||||||
|
enable = true;
|
||||||
|
statusPage = true;
|
||||||
|
virtualHosts."localhost".locations."/index.html".return = "200 'hello world\n'";
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [ curl ];
|
||||||
|
};
|
||||||
|
|
||||||
|
client = { ... }: {
|
||||||
|
virtualisation.vlans = [ 1 ];
|
||||||
|
|
||||||
|
networking = {
|
||||||
|
useNetworkd = true;
|
||||||
|
useDHCP = false;
|
||||||
|
firewall.enable = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.network.networks."01-eth1" = {
|
||||||
|
name = "eth1";
|
||||||
|
networkConfig.Address = "10.0.0.2/24";
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [ curl ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
testScript = { nodes, ... }: ''
|
||||||
|
start_all()
|
||||||
|
|
||||||
|
webserver.wait_for_unit("nginx")
|
||||||
|
webserver.wait_for_open_port(80)
|
||||||
|
|
||||||
|
def expect_http_code(node, code, url):
|
||||||
|
http_code = node.succeed(f"curl -w '%{{http_code}}' '{url}'")
|
||||||
|
assert http_code.split("\n")[-1].strip() == code, \
|
||||||
|
f"expected {code} but got following response:\n{http_code}"
|
||||||
|
|
||||||
|
with subtest("localhost can access status page"):
|
||||||
|
expect_http_code(webserver, "200", "http://localhost/nginx_status")
|
||||||
|
|
||||||
|
with subtest("localhost can access other page"):
|
||||||
|
expect_http_code(webserver, "200", "http://localhost/index.html")
|
||||||
|
|
||||||
|
with subtest("client can not access status page"):
|
||||||
|
expect_http_code(client, "403", "http://10.0.0.1/nginx_status")
|
||||||
|
|
||||||
|
with subtest("client can access other page"):
|
||||||
|
expect_http_code(client, "200", "http://10.0.0.1/index.html")
|
||||||
|
'';
|
||||||
|
})
|
|
@ -178,7 +178,7 @@ stdenv.mkDerivation {
|
||||||
passthru = {
|
passthru = {
|
||||||
inherit modules;
|
inherit modules;
|
||||||
tests = {
|
tests = {
|
||||||
inherit (nixosTests) nginx nginx-auth nginx-etag nginx-globalredirect nginx-http3 nginx-pubhtml nginx-sandbox nginx-sso nginx-proxyprotocol;
|
inherit (nixosTests) nginx nginx-auth nginx-etag nginx-globalredirect nginx-http3 nginx-pubhtml nginx-sandbox nginx-sso nginx-proxyprotocol nginx-status-page;
|
||||||
variants = lib.recurseIntoAttrs nixosTests.nginx-variants;
|
variants = lib.recurseIntoAttrs nixosTests.nginx-variants;
|
||||||
acme-integration = nixosTests.acme;
|
acme-integration = nixosTests.acme;
|
||||||
} // passthru.tests;
|
} // passthru.tests;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user