6d80870832
In particular, using fetchGit means we don't need hackery to clean the source tree when building from an unclean tree.
64 lines
2.2 KiB
Nix
64 lines
2.2 KiB
Nix
# Test ‘nix-copy-closure’.
|
||
|
||
{ nixpkgs, system, nix }:
|
||
|
||
with import (nixpkgs + /nixos/lib/testing.nix) { inherit system; };
|
||
|
||
makeTest (let pkgA = pkgs.cowsay; pkgB = pkgs.wget; pkgC = pkgs.hello; in {
|
||
|
||
nodes =
|
||
{ client =
|
||
{ config, pkgs, ... }:
|
||
{ virtualisation.writableStore = true;
|
||
virtualisation.pathsInNixDB = [ pkgA ];
|
||
nix.package = nix;
|
||
nix.binaryCaches = [ ];
|
||
};
|
||
|
||
server =
|
||
{ config, pkgs, ... }:
|
||
{ services.openssh.enable = true;
|
||
virtualisation.writableStore = true;
|
||
virtualisation.pathsInNixDB = [ pkgB pkgC ];
|
||
nix.package = nix;
|
||
};
|
||
};
|
||
|
||
testScript = { nodes }:
|
||
''
|
||
startAll;
|
||
|
||
# Create an SSH key on the client.
|
||
my $key = `${pkgs.openssh}/bin/ssh-keygen -t dsa -f key -N ""`;
|
||
$client->succeed("mkdir -m 700 /root/.ssh");
|
||
$client->copyFileFromHost("key", "/root/.ssh/id_dsa");
|
||
$client->succeed("chmod 600 /root/.ssh/id_dsa");
|
||
|
||
# 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");
|
||
$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}");
|
||
|
||
# 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}");
|
||
'';
|
||
|
||
})
|