nixos/hydra: switch to runTest, refactor

zowoq b16f158e ab2a3d7d

Changed files
+38 -60
nixos
pkgs
by-name
hy
hydra
+1 -1
nixos/tests/all-tests.nix
···
hostname = handleTest ./hostname.nix { };
hound = handleTest ./hound.nix { };
hub = handleTest ./git/hub.nix { };
-
hydra = handleTest ./hydra { };
+
hydra = runTest ./hydra;
i3wm = handleTest ./i3wm.nix { };
icingaweb2 = runTest ./icingaweb2.nix;
ifm = handleTest ./ifm.nix { };
+1 -2
nixos/tests/hydra/common.nix
···
-
{ system, ... }:
{
baseConfig =
{ pkgs, ... }:
···
trivialJob = pkgs.writeTextDir "trivial.nix" ''
{ trivial = builtins.derivation {
name = "trivial";
-
system = "${system}";
+
system = "${pkgs.stdenv.hostPlatform.system}";
builder = "/bin/sh";
allowSubstitutes = false;
preferLocalBuild = true;
+35 -56
nixos/tests/hydra/default.nix
···
+
{ pkgs, ... }:
+
let
+
inherit (import ./common.nix) baseConfig;
+
in
{
-
system ? builtins.currentSystem,
-
config ? { },
-
pkgs ? import ../../.. { inherit system config; },
-
}:
-
-
with import ../../lib/testing-python.nix { inherit system pkgs; };
-
with pkgs.lib;
-
-
let
-
-
inherit (import ./common.nix { inherit system; }) baseConfig;
-
-
hydraPkgs = {
-
inherit (pkgs) hydra;
+
name = "hydra";
+
meta = with pkgs.lib.maintainers; {
+
maintainers = [ lewo ];
};
-
makeHydraTest =
-
with pkgs.lib;
-
name: package:
-
makeTest {
-
name = "hydra-${name}";
-
meta = with pkgs.lib.maintainers; {
-
maintainers = [ lewo ];
-
};
+
nodes.machine =
+
{ pkgs, lib, ... }:
+
{
+
imports = [ baseConfig ];
+
};
-
nodes.machine =
-
{ pkgs, lib, ... }:
-
{
-
imports = [ baseConfig ];
-
services.hydra = { inherit package; };
-
};
+
testScript = ''
+
# let the system boot up
+
machine.wait_for_unit("multi-user.target")
+
# test whether the database is running
+
machine.wait_for_unit("postgresql.service")
+
# test whether the actual hydra daemons are running
+
machine.wait_for_unit("hydra-init.service")
+
machine.require_unit_state("hydra-queue-runner.service")
+
machine.require_unit_state("hydra-evaluator.service")
+
machine.require_unit_state("hydra-notify.service")
-
testScript = ''
-
# let the system boot up
-
machine.wait_for_unit("multi-user.target")
-
# test whether the database is running
-
machine.wait_for_unit("postgresql.service")
-
# test whether the actual hydra daemons are running
-
machine.wait_for_unit("hydra-init.service")
-
machine.require_unit_state("hydra-queue-runner.service")
-
machine.require_unit_state("hydra-evaluator.service")
-
machine.require_unit_state("hydra-notify.service")
+
machine.succeed("hydra-create-user admin --role admin --password admin")
-
machine.succeed("hydra-create-user admin --role admin --password admin")
+
# create a project with a trivial job
+
machine.wait_for_open_port(3000)
-
# create a project with a trivial job
-
machine.wait_for_open_port(3000)
+
# make sure the build as been successfully built
+
machine.succeed("create-trivial-project.sh")
-
# make sure the build as been successfully built
-
machine.succeed("create-trivial-project.sh")
-
-
machine.wait_until_succeeds(
-
'curl -L -s http://localhost:3000/build/1 -H "Accept: application/json" | jq .buildstatus | xargs test 0 -eq'
-
)
-
-
machine.wait_until_succeeds(
-
'journalctl -eu hydra-notify.service -o cat | grep -q "sending mail notification to hydra@localhost"'
-
)
-
'';
-
};
+
machine.wait_until_succeeds(
+
'curl -L -s http://localhost:3000/build/1 -H "Accept: application/json" | jq .buildstatus | xargs test 0 -eq'
+
)
-
in
-
-
mapAttrs makeHydraTest hydraPkgs
+
machine.wait_until_succeeds(
+
'journalctl -eu hydra-notify.service -o cat | grep -q "sending mail notification to hydra@localhost"'
+
)
+
'';
+
}
+1 -1
pkgs/by-name/hy/hydra/package.nix
···
passthru = {
inherit nix perlDeps;
-
tests.basic = nixosTests.hydra.hydra;
+
tests = { inherit (nixosTests) hydra; };
updateScript = unstableGitUpdater { };
};