nixosTests.sourcehut: test user creation and OAuth token generation
This commit is contained in:
parent
ab1ad2b066
commit
3943aa57c0
@ -768,7 +768,7 @@ in {
|
|||||||
solanum = handleTest ./solanum.nix {};
|
solanum = handleTest ./solanum.nix {};
|
||||||
sonarr = handleTest ./sonarr.nix {};
|
sonarr = handleTest ./sonarr.nix {};
|
||||||
sonic-server = handleTest ./sonic-server.nix {};
|
sonic-server = handleTest ./sonic-server.nix {};
|
||||||
sourcehut = handleTest ./sourcehut.nix {};
|
sourcehut = handleTest ./sourcehut/sourcehut.nix {};
|
||||||
spacecookie = handleTest ./spacecookie.nix {};
|
spacecookie = handleTest ./spacecookie.nix {};
|
||||||
spark = handleTestOn [ "x86_64-linux" "aarch64-linux" ] ./spark {};
|
spark = handleTestOn [ "x86_64-linux" "aarch64-linux" ] ./spark {};
|
||||||
sqlite3-to-mysql = handleTest ./sqlite3-to-mysql.nix {};
|
sqlite3-to-mysql = handleTest ./sqlite3-to-mysql.nix {};
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import ./make-test-python.nix ({ pkgs, lib, ... }:
|
import ../make-test-python.nix ({ pkgs, lib, ... }:
|
||||||
let
|
let
|
||||||
domain = "sourcehut.localdomain";
|
domain = "sourcehut.localdomain";
|
||||||
|
|
||||||
@ -118,30 +118,47 @@ in
|
|||||||
enableTCPIP = false;
|
enableTCPIP = false;
|
||||||
settings.unix_socket_permissions = "0770";
|
settings.unix_socket_permissions = "0770";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
(callPackage ./srht-gen-oauth-tok.nix { }) # To automatically generate OAuth tokens
|
||||||
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
testScript = ''
|
testScript =
|
||||||
start_all()
|
let
|
||||||
machine.wait_for_unit("multi-user.target")
|
userName = "nixos-test";
|
||||||
|
userPass = "AutoNixosTestPwd";
|
||||||
|
in
|
||||||
|
''
|
||||||
|
start_all()
|
||||||
|
machine.wait_for_unit("multi-user.target")
|
||||||
|
|
||||||
# Testing metasrht
|
# Testing metasrht
|
||||||
machine.wait_for_unit("metasrht-api.service")
|
machine.wait_for_unit("metasrht-api.service")
|
||||||
machine.wait_for_unit("metasrht.service")
|
machine.wait_for_unit("metasrht.service")
|
||||||
machine.wait_for_unit("metasrht-webhooks.service")
|
machine.wait_for_unit("metasrht-webhooks.service")
|
||||||
machine.wait_for_open_port(5000)
|
machine.wait_for_open_port(5000)
|
||||||
machine.succeed("curl -sL http://localhost:5000 | grep meta.${domain}")
|
machine.succeed("curl -sL http://localhost:5000 | grep meta.${domain}")
|
||||||
machine.succeed("curl -sL http://meta.${domain} | grep meta.${domain}")
|
machine.succeed("curl -sL http://meta.${domain} | grep meta.${domain}")
|
||||||
|
|
||||||
# Testing buildsrht
|
## Create a test user for subsequent tests
|
||||||
machine.wait_for_unit("buildsrht.service")
|
machine.succeed("echo ${userPass} | metasrht-manageuser -ps -e ${userName}@${domain}\
|
||||||
machine.wait_for_open_port(5002)
|
-t active_free ${userName}");
|
||||||
machine.succeed("curl -sL http://localhost:5002 | grep builds.${domain}")
|
|
||||||
#machine.wait_for_unit("buildsrht-worker.service")
|
|
||||||
|
|
||||||
# Testing gitsrht
|
## Obtain a OAuth token to be used for querying APIs directly
|
||||||
machine.wait_for_unit("gitsrht-api.service")
|
(_, token) = machine.execute("srht-gen-oauth-tok -i ${domain} -q ${userName} ${userPass}")
|
||||||
machine.wait_for_unit("gitsrht.service")
|
print(token)
|
||||||
machine.wait_for_unit("gitsrht-webhooks.service")
|
|
||||||
machine.succeed("curl -sL http://git.${domain} | grep git.${domain}")
|
# Testing buildsrht
|
||||||
'';
|
machine.wait_for_unit("buildsrht.service")
|
||||||
|
machine.wait_for_open_port(5002)
|
||||||
|
machine.succeed("curl -sL http://localhost:5002 | grep builds.${domain}")
|
||||||
|
#machine.wait_for_unit("buildsrht-worker.service")
|
||||||
|
|
||||||
|
# Testing gitsrht
|
||||||
|
machine.wait_for_unit("gitsrht-api.service")
|
||||||
|
machine.wait_for_unit("gitsrht.service")
|
||||||
|
machine.wait_for_unit("gitsrht-webhooks.service")
|
||||||
|
machine.succeed("curl -sL http://git.${domain} | grep git.${domain}")
|
||||||
|
'';
|
||||||
})
|
})
|
31
nixos/tests/sourcehut/srht-gen-oauth-tok.nix
Normal file
31
nixos/tests/sourcehut/srht-gen-oauth-tok.nix
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
{ stdenv, pkgs, lib, fetchFromSourcehut }:
|
||||||
|
|
||||||
|
let
|
||||||
|
perl = pkgs.perl.withPackages (pps: [
|
||||||
|
pps.CryptSSLeay
|
||||||
|
pps.WWWMechanize
|
||||||
|
pps.XMLLibXML
|
||||||
|
]);
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
pname = "srht-gen-oauth-tok";
|
||||||
|
version = "0.1";
|
||||||
|
|
||||||
|
src = fetchFromSourcehut {
|
||||||
|
domain = "entropic.network";
|
||||||
|
owner = "~nessdoor";
|
||||||
|
repo = pname;
|
||||||
|
rev = version;
|
||||||
|
hash = "sha256-GcqP3XbVw2sR5n4+aLUmA4fthNkuVAGnhV1h7suJYdI=";
|
||||||
|
};
|
||||||
|
|
||||||
|
buildInputs = [ perl ];
|
||||||
|
nativeBuildInputs = [ perl ];
|
||||||
|
|
||||||
|
installPhase = "install -Dm755 srht-gen-oauth-tok $out/bin/srht-gen-oauth-tok";
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "A script to register a new Sourcehut OAuth token for the given user";
|
||||||
|
license = lib.licenses.gpl3;
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user