blob: d7cbf640abe49b2f59373beb0047bce97eaaed58 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
{ lib, pkgs, ... }:
let
initrdLowerdir = pkgs.runCommand "initrd-lowerdir" { } ''
mkdir -p $out
echo "initrd" > $out/initrd.txt
'';
initrdLowerdir2 = pkgs.runCommand "initrd-lowerdir-2" { } ''
mkdir -p $out
echo "initrd2" > $out/initrd2.txt
'';
userspaceLowerdir = pkgs.runCommand "userspace-lowerdir" { } ''
mkdir -p $out
echo "userspace" > $out/userspace.txt
'';
userspaceLowerdir2 = pkgs.runCommand "userspace-lowerdir-2" { } ''
mkdir -p $out
echo "userspace2" > $out/userspace2.txt
'';
in
{
name = "writable-overlays";
meta.maintainers = with lib.maintainers; [ nikstur ];
nodes.machine = { config, pkgs, ... }: {
boot.initrd.systemd.enable = true;
boot.initrd.availableKernelModules = [ "overlay" ];
virtualisation.fileSystems = {
"/initrd-overlay" = {
overlay = {
lowerdir = [ initrdLowerdir ];
upperdir = "/.rw-initrd-overlay/upper";
workdir = "/.rw-initrd-overlay/work";
};
neededForBoot = true;
};
"/userspace-overlay" = {
overlay = {
lowerdir = [ userspaceLowerdir ];
upperdir = "/.rw-userspace-overlay/upper";
workdir = "/.rw-userspace-overlay/work";
};
};
"/ro-initrd-overlay" = {
overlay.lowerdir = [
initrdLowerdir
initrdLowerdir2
];
neededForBoot = true;
};
"/ro-userspace-overlay" = {
overlay.lowerdir = [
userspaceLowerdir
userspaceLowerdir2
];
};
};
};
testScript = ''
machine.wait_for_unit("default.target")
with subtest("Initrd overlay"):
machine.wait_for_file("/initrd-overlay/initrd.txt", 5)
machine.succeed("touch /initrd-overlay/writable.txt")
machine.succeed("findmnt --kernel --types overlay /initrd-overlay")
with subtest("Userspace overlay"):
machine.wait_for_file("/userspace-overlay/userspace.txt", 5)
machine.succeed("touch /userspace-overlay/writable.txt")
machine.succeed("findmnt --kernel --types overlay /userspace-overlay")
with subtest("Read only initrd overlay"):
machine.wait_for_file("/ro-initrd-overlay/initrd.txt", 5)
machine.wait_for_file("/ro-initrd-overlay/initrd2.txt", 5)
machine.fail("touch /ro-initrd-overlay/not-writable.txt")
machine.succeed("findmnt --kernel --types overlay /ro-initrd-overlay")
with subtest("Read only userspace overlay"):
machine.wait_for_file("/ro-userspace-overlay/userspace.txt", 5)
machine.wait_for_file("/ro-userspace-overlay/userspace2.txt", 5)
machine.fail("touch /ro-userspace-overlay/not-writable.txt")
machine.succeed("findmnt --kernel --types overlay /ro-userspace-overlay")
'';
}
|