X-Git-Url: http://git.scottworley.com/syncthing-autoregister/blobdiff_plain/cefa20b6ac66bfe7793f6ded33a7eb9e2354379f..2475b5344ca33d7aad5b57f42310994d60b80ee3:/tests/automatic-enrollment.nix diff --git a/tests/automatic-enrollment.nix b/tests/automatic-enrollment.nix index 4694048..1a6b360 100644 --- a/tests/automatic-enrollment.nix +++ b/tests/automatic-enrollment.nix @@ -17,6 +17,18 @@ import ({ pkgs, lib, ... }: environment.systemPackages = with pkgs; [ nix ]; } ''; + initialConfiguration = pkgs.writeText "initial-configuration.nix" '' + { + imports = [ "${configuration}" ]; + system.activationScripts.installInitialConfiguration = { + text = ''' + mkdir -p /etc/nixos + cp "${configuration}" /etc/nixos/configuration.nix + '''; + deps = [ ]; + }; + } + ''; configurationWithDeviceIDs = pkgs.writeText "configuration-with-device-ids.nix" '' { @@ -31,8 +43,8 @@ import ({ pkgs, lib, ... }: name = "syncthing"; nodes = { - a = "${configuration}"; - b = "${configuration}"; + a = "${initialConfiguration}"; + b = "${initialConfiguration}"; }; testScript = '' @@ -40,16 +52,19 @@ import ({ pkgs, lib, ... }: machine.copy_from_host(config, "/etc/nixos/configuration.nix") - initialConfiguration = "${configuration}" + def verifyDeviceIDSet(machine, expectedDevice): + machine.succeed( + '(( "$(nix eval --raw -f "" config.services.syncthing.declarative.devices.%s.id | wc -c)" == 63 ))' + % expectedDevice + ) + + configurationWithDeviceIDs = ( "${configurationWithDeviceIDs}" ) - setConfig(a, initialConfiguration) a.wait_for_unit("syncthing-autoregister.service") setConfig(a, configurationWithDeviceIDs) - a.succeed( - '(( "$(nix eval --raw -f "" config.services.syncthing.declarative.devices.a.id | wc -c)" == 63 ))' - ) + verifyDeviceIDSet(a, "a") ''; })