2017-11-27 09:14:17 +01:00
|
|
|
import ../make-test.nix ({ pkgs, lib, ... }:
|
2017-09-18 14:52:07 +02:00
|
|
|
|
2017-11-27 09:14:17 +01:00
|
|
|
{
|
2017-09-18 14:52:07 +02:00
|
|
|
name = "initrd-network-ssh";
|
|
|
|
meta = with lib.maintainers; {
|
|
|
|
maintainers = [ willibutz ];
|
|
|
|
};
|
|
|
|
|
|
|
|
nodes = with lib; rec {
|
|
|
|
server =
|
|
|
|
{ config, pkgs, ... }:
|
|
|
|
{
|
|
|
|
boot.kernelParams = [
|
2017-12-03 05:14:54 +01:00
|
|
|
"ip=${config.networking.primaryIPAddress}:::255.255.255.0::eth1:none"
|
2017-09-18 14:52:07 +02:00
|
|
|
];
|
|
|
|
boot.initrd.network = {
|
|
|
|
enable = true;
|
|
|
|
ssh = {
|
|
|
|
enable = true;
|
2017-11-27 09:14:17 +01:00
|
|
|
authorizedKeys = [ "${readFile ./openssh.pub}" ];
|
2017-09-18 14:52:07 +02:00
|
|
|
port = 22;
|
2017-11-27 09:14:17 +01:00
|
|
|
hostRSAKey = ./dropbear.priv;
|
2017-09-18 14:52:07 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
boot.initrd.preLVMCommands = ''
|
|
|
|
while true; do
|
|
|
|
if [ -f fnord ]; then
|
|
|
|
poweroff
|
|
|
|
fi
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
client =
|
|
|
|
{ config, pkgs, ... }:
|
|
|
|
{
|
|
|
|
environment.etc.knownHosts = {
|
|
|
|
text = concatStrings [
|
|
|
|
"server,"
|
|
|
|
"${toString (head (splitString " " (
|
|
|
|
toString (elemAt (splitString "\n" config.networking.extraHosts) 2)
|
|
|
|
)))} "
|
2017-11-27 09:14:17 +01:00
|
|
|
"${readFile ./dropbear.pub}"
|
2017-09-18 14:52:07 +02:00
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
testScript = ''
|
|
|
|
startAll;
|
|
|
|
$client->waitForUnit("network.target");
|
2017-11-27 09:14:17 +01:00
|
|
|
$client->copyFileFromHost("${./openssh.priv}","/etc/sshKey");
|
2017-09-18 14:52:07 +02:00
|
|
|
$client->succeed("chmod 0600 /etc/sshKey");
|
|
|
|
$client->waitUntilSucceeds("ping -c 1 server");
|
|
|
|
$client->succeed("ssh -i /etc/sshKey -o UserKnownHostsFile=/etc/knownHosts server 'touch /fnord'");
|
|
|
|
$client->shutdown;
|
|
|
|
'';
|
|
|
|
})
|