nix/tests/nix-copy-closure.nix

65 lines
2.2 KiB
Nix
Raw Normal View History

# Test nix-copy-closure.
2011-10-11 13:58:47 +00:00
{ nixpkgs, system, nix }:
2011-10-11 13:58:47 +00:00
2018-02-05 20:48:09 +00:00
with import (nixpkgs + "/nixos/lib/testing.nix") { inherit system; };
2011-10-11 13:58:47 +00:00
2016-03-30 15:20:53 +00:00
makeTest (let pkgA = pkgs.cowsay; pkgB = pkgs.wget; pkgC = pkgs.hello; in {
2011-10-11 13:58:47 +00:00
nodes =
{ client =
2019-11-05 10:12:25 +00:00
{ config, lib, pkgs, ... }:
2011-10-11 13:58:47 +00:00
{ virtualisation.writableStore = true;
virtualisation.pathsInNixDB = [ pkgA ];
2014-04-15 13:32:27 +00:00
nix.package = nix;
2019-11-05 10:12:25 +00:00
nix.binaryCaches = lib.mkForce [ ];
2011-10-11 13:58:47 +00:00
};
2011-10-11 13:58:47 +00:00
server =
{ config, pkgs, ... }:
{ services.openssh.enable = true;
virtualisation.writableStore = true;
2014-07-09 23:50:29 +00:00
virtualisation.pathsInNixDB = [ pkgB pkgC ];
2014-04-15 13:32:27 +00:00
nix.package = nix;
};
2011-10-11 13:58:47 +00:00
};
testScript = { nodes }:
''
startAll;
# Create an SSH key on the client.
my $key = `${pkgs.openssh}/bin/ssh-keygen -t ed25519 -f key -N ""`;
2011-10-11 13:58:47 +00:00
$client->succeed("mkdir -m 700 /root/.ssh");
$client->copyFileFromHost("key", "/root/.ssh/id_ed25519");
$client->succeed("chmod 600 /root/.ssh/id_ed25519");
2011-10-11 13:58:47 +00:00
# Install the SSH key on the server.
$server->succeed("mkdir -m 700 /root/.ssh");
$server->copyFileFromHost("key.pub", "/root/.ssh/authorized_keys");
$server->waitForUnit("sshd");
$client->waitForUnit("network.target");
2011-10-11 13:58:47 +00:00
$client->succeed("ssh -o StrictHostKeyChecking=no " . $server->name() . " 'echo hello world'");
# Copy the closure of package A from the client to the server.
$server->fail("nix-store --check-validity ${pkgA}");
$client->succeed("nix-copy-closure --to server --gzip ${pkgA} >&2");
$server->succeed("nix-store --check-validity ${pkgA}");
# Copy the closure of package B from the server to the client.
$client->fail("nix-store --check-validity ${pkgB}");
$client->succeed("nix-copy-closure --from server --gzip ${pkgB} >&2");
$client->succeed("nix-store --check-validity ${pkgB}");
2014-07-09 23:50:29 +00:00
# Copy the closure of package C via the SSH substituter.
$client->fail("nix-store -r ${pkgC}");
# FIXME
#$client->succeed(
# "nix-store --option use-ssh-substituter true"
# . " --option ssh-substituter-hosts root\@server"
# . " -r ${pkgC} >&2");
#$client->succeed("nix-store --check-validity ${pkgC}");
2011-10-11 13:58:47 +00:00
'';
})