2020-12-12 13:39:58 +00:00
|
|
|
{
|
|
|
|
system ? builtins.currentSystem,
|
|
|
|
config ? { },
|
|
|
|
pkgs ? import ../.. { inherit system config; },
|
|
|
|
lib ? pkgs.lib,
|
|
|
|
testing ? import ../lib/testing-python.nix { inherit system pkgs; },
|
|
|
|
}:
|
|
|
|
let
|
|
|
|
secretInStore = pkgs.writeText "topsecret" "iamasecret";
|
|
|
|
testWithCompressor =
|
|
|
|
compressor:
|
|
|
|
testing.makeTest {
|
|
|
|
name = "initrd-secrets-${compressor}";
|
|
|
|
|
2024-06-21 12:41:50 +01:00
|
|
|
meta.maintainers = [ ];
|
2020-12-12 13:39:58 +00:00
|
|
|
|
2022-03-20 23:15:30 +00:00
|
|
|
nodes.machine =
|
|
|
|
{ ... }:
|
|
|
|
{
|
2020-12-12 13:39:58 +00:00
|
|
|
virtualisation.useBootLoader = true;
|
2021-07-11 21:00:06 +01:00
|
|
|
boot.initrd.secrets = {
|
|
|
|
"/test" = secretInStore;
|
|
|
|
|
|
|
|
# This should *not* need to be copied in postMountCommands
|
|
|
|
"/run/keys/test" = secretInStore;
|
|
|
|
};
|
2020-12-12 13:39:58 +00:00
|
|
|
boot.initrd.postMountCommands = ''
|
|
|
|
cp /test /mnt-root/secret-from-initramfs
|
2024-12-10 19:26:33 +00:00
|
|
|
'';
|
2020-12-12 13:39:58 +00:00
|
|
|
boot.initrd.compressor = compressor;
|
|
|
|
# zstd compression is only supported from 5.9 onwards. Remove when 5.10 becomes default.
|
|
|
|
boot.kernelPackages = pkgs.linuxPackages_latest;
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
|
|
|
|
2020-12-12 13:39:58 +00:00
|
|
|
testScript = ''
|
|
|
|
start_all()
|
|
|
|
machine.wait_for_unit("multi-user.target")
|
|
|
|
machine.succeed(
|
2021-07-11 21:00:06 +01:00
|
|
|
"cmp ${secretInStore} /secret-from-initramfs",
|
|
|
|
"cmp ${secretInStore} /run/keys/test",
|
2024-12-10 19:26:33 +00:00
|
|
|
)
|
2020-12-12 13:39:58 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
in
|
|
|
|
lib.flip lib.genAttrs testWithCompressor [
|
|
|
|
"cat"
|
|
|
|
"gzip"
|
|
|
|
"bzip2"
|
|
|
|
"xz"
|
|
|
|
"lzma"
|
|
|
|
"lzop"
|
|
|
|
"pigz"
|
|
|
|
"pixz"
|
|
|
|
"zstd"
|
|
|
|
]
|