add assertion if mirroredBoots is used in vm test

This commit is contained in:
Jörg Thalheim 2024-02-22 00:23:54 +01:00 committed by mergify[bot]
parent 1ae1f57dad
commit 590245271a

View File

@ -114,7 +114,7 @@ let
}; };
installedTopLevel = ((if extendModules != null then extendModules else installed-system-eval.extendModules) { installedTopLevel = ((if extendModules != null then extendModules else installed-system-eval.extendModules) {
modules = [{ modules = [({config, ...}: {
imports = [ imports = [
extraSystemConfig extraSystemConfig
({ modulesPath, ... }: { ({ modulesPath, ... }: {
@ -141,8 +141,20 @@ let
boot.zfs.devNodes = "/dev/disk/by-uuid"; # needed because /dev/disk/by-id is empty in qemu-vms boot.zfs.devNodes = "/dev/disk/by-uuid"; # needed because /dev/disk/by-id is empty in qemu-vms
# grub will install to these devices, we need to force those or we are offset by 1 # grub will install to these devices, we need to force those or we are offset by 1
boot.loader.grub.devices = lib.mkForce testConfigInstall.boot.loader.grub.devices; # we use mkOveride 70, so that users can override this with mkForce in case they are testing grub mirrored boots
}]; boot.loader.grub.devices = lib.mkOverride 70 testConfigInstall.boot.loader.grub.devices;
assertions = [
{
assertion = builtins.length config.boot.loader.grub.mirroredBoots > 1 -> config.boot.loader.grub.devices == [];
message = ''
When using `--vm-test` in combination with `mirroredBoots`,
it is necessary to configure `boot.loader.grub.devices` as an empty list by setting `boot.loader.grub.devices = lib.mkForce [];`.
This adjustment is crucial because the `--vm-test` mechanism automatically overrides the grub boot devices as part of the virtual machine test.
'';
}
];
})];
}).config.system.build.toplevel; }).config.system.build.toplevel;
in in