mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2025-01-19 09:36:47 +02:00
Merge pull request #8506 from corngood/ssh-master
Pass NIX_SSHOPTS when checking for an ssh master connection.
This commit is contained in:
commit
0e3a7e34a0
2 changed files with 13 additions and 1 deletions
|
@ -42,7 +42,10 @@ void SSHMaster::addCommonSSHOpts(Strings & args)
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SSHMaster::isMasterRunning() {
|
bool SSHMaster::isMasterRunning() {
|
||||||
auto res = runProgram(RunOptions {.program = "ssh", .args = {"-O", "check", host}, .mergeStderrToStdout = true});
|
Strings args = {"-O", "check", host};
|
||||||
|
addCommonSSHOpts(args);
|
||||||
|
|
||||||
|
auto res = runProgram(RunOptions {.program = "ssh", .args = args, .mergeStderrToStdout = true});
|
||||||
return res.first == 0;
|
return res.first == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -79,6 +79,15 @@ in {
|
||||||
server.copy_from_host("key.pub", "/root/.ssh/authorized_keys")
|
server.copy_from_host("key.pub", "/root/.ssh/authorized_keys")
|
||||||
server.succeed("systemctl restart sshd")
|
server.succeed("systemctl restart sshd")
|
||||||
client.succeed(f"ssh -o StrictHostKeyChecking=no {server.name} 'echo hello world'")
|
client.succeed(f"ssh -o StrictHostKeyChecking=no {server.name} 'echo hello world'")
|
||||||
|
client.succeed(f"ssh -O check {server.name}")
|
||||||
|
client.succeed(f"ssh -O exit {server.name}")
|
||||||
|
client.fail(f"ssh -O check {server.name}")
|
||||||
|
|
||||||
|
# Check that an explicit master will work
|
||||||
|
client.succeed(f"ssh -MNfS /tmp/master {server.name}")
|
||||||
|
client.succeed(f"ssh -S /tmp/master -O check {server.name}")
|
||||||
|
client.succeed("NIX_SSHOPTS='-oControlPath=/tmp/master' nix copy --to ssh://server ${pkgA} >&2")
|
||||||
|
client.succeed(f"ssh -S /tmp/master -O exit {server.name}")
|
||||||
|
|
||||||
# Copy the closure of package B from the server to the client, using ssh-ng.
|
# Copy the closure of package B from the server to the client, using ssh-ng.
|
||||||
client.fail("nix-store --check-validity ${pkgB}")
|
client.fail("nix-store --check-validity ${pkgB}")
|
||||||
|
|
Loading…
Reference in a new issue