nixos/tests: add nginx-sso basic functionality test
This commit is contained in:
parent
43fcfc274d
commit
20b1febace
@ -153,6 +153,7 @@ in
|
|||||||
nfs4 = handleTest ./nfs.nix { version = 4; };
|
nfs4 = handleTest ./nfs.nix { version = 4; };
|
||||||
nghttpx = handleTest ./nghttpx.nix {};
|
nghttpx = handleTest ./nghttpx.nix {};
|
||||||
nginx = handleTest ./nginx.nix {};
|
nginx = handleTest ./nginx.nix {};
|
||||||
|
nginx-sso = handleTest ./nginx-sso.nix {};
|
||||||
nix-ssh-serve = handleTest ./nix-ssh-serve.nix {};
|
nix-ssh-serve = handleTest ./nix-ssh-serve.nix {};
|
||||||
novacomd = handleTestOn ["x86_64-linux"] ./novacomd.nix {};
|
novacomd = handleTestOn ["x86_64-linux"] ./novacomd.nix {};
|
||||||
nsd = handleTest ./nsd.nix {};
|
nsd = handleTest ./nsd.nix {};
|
||||||
|
44
nixos/tests/nginx-sso.nix
Normal file
44
nixos/tests/nginx-sso.nix
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import ./make-test.nix ({ pkgs, ... }: {
|
||||||
|
name = "nginx-sso";
|
||||||
|
meta = {
|
||||||
|
maintainers = with pkgs.stdenv.lib.maintainers; [ delroth ];
|
||||||
|
};
|
||||||
|
|
||||||
|
machine = {
|
||||||
|
services.nginx.sso = {
|
||||||
|
enable = true;
|
||||||
|
configuration = {
|
||||||
|
listen = { addr = "127.0.0.1"; port = 8080; };
|
||||||
|
|
||||||
|
providers.token.tokens = {
|
||||||
|
myuser = "MyToken";
|
||||||
|
};
|
||||||
|
|
||||||
|
acl = {
|
||||||
|
rule_sets = [
|
||||||
|
{
|
||||||
|
rules = [ { field = "x-application"; equals = "MyApp"; } ];
|
||||||
|
allow = [ "myuser" ];
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
testScript = ''
|
||||||
|
startAll;
|
||||||
|
|
||||||
|
$machine->waitForUnit("nginx-sso.service");
|
||||||
|
$machine->waitForOpenPort(8080);
|
||||||
|
|
||||||
|
# No valid user -> 401.
|
||||||
|
$machine->fail("curl -sSf http://localhost:8080/auth");
|
||||||
|
|
||||||
|
# Valid user but no matching ACL -> 403.
|
||||||
|
$machine->fail("curl -sSf -H 'Authorization: Token MyToken' http://localhost:8080/auth");
|
||||||
|
|
||||||
|
# Valid user and matching ACL -> 200.
|
||||||
|
$machine->succeed("curl -sSf -H 'Authorization: Token MyToken' -H 'X-Application: MyApp' http://localhost:8080/auth");
|
||||||
|
'';
|
||||||
|
})
|
Loading…
x
Reference in New Issue
Block a user