mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-08 05:54:24 +00:00
a4cb90bdbd
Co-authored-by: jnetod <49963580+jnetod@users.noreply.github.com>
131 lines
4.1 KiB
Nix
131 lines
4.1 KiB
Nix
{ system ? builtins.currentSystem,
|
|
config ? {},
|
|
pkgs ? import ../.. { inherit system config; }
|
|
}:
|
|
|
|
with import ../lib/testing-python.nix { inherit system pkgs; };
|
|
|
|
let
|
|
|
|
makeZfsTest = name:
|
|
{ kernelPackage ? if enableUnstable then pkgs.linuxPackages_latest else pkgs.linuxPackages
|
|
, enableUnstable ? false
|
|
, extraTest ? ""
|
|
}:
|
|
makeTest {
|
|
name = "zfs-" + name;
|
|
meta = with pkgs.lib.maintainers; {
|
|
maintainers = [ adisbladis ];
|
|
};
|
|
|
|
machine = { pkgs, lib, ... }:
|
|
let
|
|
usersharePath = "/var/lib/samba/usershares";
|
|
in {
|
|
virtualisation.emptyDiskImages = [ 4096 ];
|
|
networking.hostId = "deadbeef";
|
|
boot.kernelPackages = kernelPackage;
|
|
boot.supportedFilesystems = [ "zfs" ];
|
|
boot.zfs.enableUnstable = enableUnstable;
|
|
|
|
services.samba = {
|
|
enable = true;
|
|
extraConfig = ''
|
|
registry shares = yes
|
|
usershare path = ${usersharePath}
|
|
usershare allow guests = yes
|
|
usershare max shares = 100
|
|
usershare owner only = no
|
|
'';
|
|
};
|
|
systemd.services.samba-smbd.serviceConfig.ExecStartPre =
|
|
"${pkgs.coreutils}/bin/mkdir -m +t -p ${usersharePath}";
|
|
|
|
environment.systemPackages = [ pkgs.parted ];
|
|
|
|
# Setup regular fileSystems machinery to ensure forceImportAll can be
|
|
# tested via the regular service units.
|
|
virtualisation.fileSystems = {
|
|
"/forcepool" = {
|
|
device = "forcepool";
|
|
fsType = "zfs";
|
|
options = [ "noauto" ];
|
|
};
|
|
};
|
|
|
|
# forcepool doesn't exist at first boot, and we need to manually test
|
|
# the import after tweaking the hostId.
|
|
systemd.services.zfs-import-forcepool.wantedBy = lib.mkVMOverride [];
|
|
systemd.targets.zfs.wantedBy = lib.mkVMOverride [];
|
|
boot.zfs.forceImportAll = true;
|
|
# /dev/disk/by-id doesn't get populated in the NixOS test framework
|
|
boot.zfs.devNodes = "/dev/disk/by-uuid";
|
|
};
|
|
|
|
testScript = ''
|
|
machine.succeed(
|
|
"modprobe zfs",
|
|
"zpool status",
|
|
"ls /dev",
|
|
"mkdir /tmp/mnt",
|
|
"udevadm settle",
|
|
"parted --script /dev/vdb mklabel msdos",
|
|
"parted --script /dev/vdb -- mkpart primary 1024M -1s",
|
|
"udevadm settle",
|
|
"zpool create rpool /dev/vdb1",
|
|
"zfs create -o mountpoint=legacy rpool/root",
|
|
# shared datasets cannot have legacy mountpoint
|
|
"zfs create rpool/shared_smb",
|
|
"mount -t zfs rpool/root /tmp/mnt",
|
|
"udevadm settle",
|
|
# wait for samba services
|
|
"systemctl is-system-running --wait",
|
|
"zfs set sharesmb=on rpool/shared_smb",
|
|
"zfs share rpool/shared_smb",
|
|
"smbclient -gNL localhost | grep rpool_shared_smb",
|
|
"umount /tmp/mnt",
|
|
"zpool destroy rpool",
|
|
"udevadm settle",
|
|
)
|
|
|
|
machine.succeed(
|
|
'echo password | zpool create -o altroot="/tmp/mnt" '
|
|
+ "-O encryption=aes-256-gcm -O keyformat=passphrase rpool /dev/vdb1",
|
|
"zfs create -o mountpoint=legacy rpool/root",
|
|
"mount -t zfs rpool/root /tmp/mnt",
|
|
"udevadm settle",
|
|
"umount /tmp/mnt",
|
|
"zpool destroy rpool",
|
|
"udevadm settle",
|
|
)
|
|
|
|
with subtest("boot.zfs.forceImportAll works"):
|
|
machine.succeed(
|
|
"rm /etc/hostid",
|
|
"zgenhostid deadcafe",
|
|
"zpool create forcepool /dev/vdb1 -O mountpoint=legacy",
|
|
)
|
|
machine.shutdown()
|
|
machine.start()
|
|
machine.succeed("udevadm settle")
|
|
machine.fail("zpool import forcepool")
|
|
machine.succeed(
|
|
"systemctl start zfs-import-forcepool.service",
|
|
"mount -t zfs forcepool /tmp/mnt",
|
|
)
|
|
'' + extraTest;
|
|
|
|
};
|
|
|
|
|
|
in {
|
|
|
|
stable = makeZfsTest "stable" { };
|
|
|
|
unstable = makeZfsTest "unstable" {
|
|
enableUnstable = true;
|
|
};
|
|
|
|
installer = (import ./installer.nix { }).zfsroot;
|
|
}
|