diff options
author | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2025-04-24 19:24:49 +0200 |
---|---|---|
committer | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2025-04-24 19:24:49 +0200 |
commit | 9c293b33e0eaa1f427bbd4c5a7cb2bd165564d71 (patch) | |
tree | a2ebfa172cabc87333d4b8ea432a0f3a99af8504 /tests | |
parent | modules/system-info: Provide a nice warning message, if a port is not yet reg... (diff) | |
download | nixos-server-9c293b33e0eaa1f427bbd4c5a7cb2bd165564d71.zip |
This is, for some reason, needed for image uploads to sharkey.
Diffstat (limited to '')
-rw-r--r-- | tests/by-name/sh/sharkey-images/test.nix | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/tests/by-name/sh/sharkey-images/test.nix b/tests/by-name/sh/sharkey-images/test.nix new file mode 100644 index 0000000..d4f9332 --- /dev/null +++ b/tests/by-name/sh/sharkey-images/test.nix @@ -0,0 +1,82 @@ +{ + nixos-lib, + pkgsUnstable, + nixpkgs-unstable, + vhackPackages, + pkgs, + extraModules, + nixLib, + ... +}: +nixos-lib.runTest { + hostPkgs = pkgs; # the Nixpkgs package set used outside the VMs + + name = "sharkey-images"; + + node = { + specialArgs = {inherit pkgsUnstable extraModules vhackPackages nixpkgs-unstable nixLib;}; + + # Use the nixpkgs as constructed by the `nixpkgs.*` options + pkgs = null; + }; + + nodes = { + server = {config, ...}: { + imports = + extraModules + ++ [ + ../../../../modules + ]; + + vhack = { + persist.enable = true; + nginx.enable = true; + sharkey = { + enable = true; + fqdn = "sharkey.server"; + }; + }; + systemd.services = { + # Avoid an error from this service. + "acme-sharkey.server".serviceConfig.ExecStart = pkgs.lib.mkForce "${pkgs.lib.getExe' pkgs.coreutils "true"}"; + + # Test, that sharkey's hardening still allows access to the CPUs. + sharkey.serviceConfig.ExecStart = let + nodejs = pkgs.lib.getExe pkgsUnstable.nodejs; + script = pkgs.writeTextFile { + name = "script.js"; + text = '' + import * as os from 'node:os'; + + console.log(os.cpus()[0].model) + console.log(os.cpus().length) + ''; + }; + in + pkgs.lib.mkForce "${nodejs} ${script}"; + }; + }; + }; + + testScript = {nodes, ...}: + /* + python + */ + '' + from time import sleep + + start_all() + server.wait_for_unit("sharkey.service") + + # Give the service time to start. + sleep(3) + + with subtest("All services running"): + import json + def all_services_running(host): + (status, output) = host.systemctl("list-units --state=failed --plain --no-pager --output=json") + host_failed = json.loads(output) + assert len(host_failed) == 0, f"Expected zero failing services, but found: {json.dumps(host_failed, indent=4)}" + all_services_running(server) + ''; +} |