···
1
-
import ./make-test-python.nix (
5
-
meta.maintainers = with lib.maintainers; [
18
-
security.apparmor.enable = lib.mkDefault true;
22
-
machine.wait_for_unit("multi-user.target")
24
-
with subtest("AppArmor profiles are loaded"):
25
-
machine.succeed("systemctl status apparmor.service")
27
-
# AppArmor securityfs
28
-
with subtest("AppArmor securityfs is mounted"):
29
-
machine.succeed("mountpoint -q /sys/kernel/security")
30
-
machine.succeed("cat /sys/kernel/security/apparmor/profiles")
32
-
# Test apparmorRulesFromClosure by:
33
-
# 1. Prepending a string of the relevant packages' name and version on each line.
34
-
# 2. Sorting according to those strings.
35
-
# 3. Removing those prepended strings.
36
-
# 4. Using `diff` against the expected output.
37
-
with subtest("apparmorRulesFromClosure"):
39
-
"${pkgs.diffutils}/bin/diff -u ${pkgs.writeText "expected.rules" ''
40
-
ixr ${pkgs.bash}/libexec/**,
41
-
mr ${pkgs.bash}/lib/**.so*,
42
-
mr ${pkgs.bash}/lib64/**.so*,
43
-
mr ${pkgs.bash}/share/**,
45
-
r ${pkgs.bash}/etc/**,
46
-
r ${pkgs.bash}/lib/**,
47
-
r ${pkgs.bash}/lib64/**,
48
-
x ${pkgs.bash}/foo/**,
49
-
ixr ${pkgs.glibc}/libexec/**,
50
-
mr ${pkgs.glibc}/lib/**.so*,
51
-
mr ${pkgs.glibc}/lib64/**.so*,
52
-
mr ${pkgs.glibc}/share/**,
54
-
r ${pkgs.glibc}/etc/**,
55
-
r ${pkgs.glibc}/lib/**,
56
-
r ${pkgs.glibc}/lib64/**,
57
-
x ${pkgs.glibc}/foo/**,
58
-
ixr ${pkgs.libcap}/libexec/**,
59
-
mr ${pkgs.libcap}/lib/**.so*,
60
-
mr ${pkgs.libcap}/lib64/**.so*,
61
-
mr ${pkgs.libcap}/share/**,
63
-
r ${pkgs.libcap}/etc/**,
64
-
r ${pkgs.libcap}/lib/**,
65
-
r ${pkgs.libcap}/lib64/**,
66
-
x ${pkgs.libcap}/foo/**,
67
-
ixr ${pkgs.libcap.lib}/libexec/**,
68
-
mr ${pkgs.libcap.lib}/lib/**.so*,
69
-
mr ${pkgs.libcap.lib}/lib64/**.so*,
70
-
mr ${pkgs.libcap.lib}/share/**,
71
-
r ${pkgs.libcap.lib},
72
-
r ${pkgs.libcap.lib}/etc/**,
73
-
r ${pkgs.libcap.lib}/lib/**,
74
-
r ${pkgs.libcap.lib}/lib64/**,
75
-
x ${pkgs.libcap.lib}/foo/**,
76
-
ixr ${pkgs.libidn2.out}/libexec/**,
77
-
mr ${pkgs.libidn2.out}/lib/**.so*,
78
-
mr ${pkgs.libidn2.out}/lib64/**.so*,
79
-
mr ${pkgs.libidn2.out}/share/**,
80
-
r ${pkgs.libidn2.out},
81
-
r ${pkgs.libidn2.out}/etc/**,
82
-
r ${pkgs.libidn2.out}/lib/**,
83
-
r ${pkgs.libidn2.out}/lib64/**,
84
-
x ${pkgs.libidn2.out}/foo/**,
85
-
ixr ${pkgs.libunistring}/libexec/**,
86
-
mr ${pkgs.libunistring}/lib/**.so*,
87
-
mr ${pkgs.libunistring}/lib64/**.so*,
88
-
mr ${pkgs.libunistring}/share/**,
89
-
r ${pkgs.libunistring},
90
-
r ${pkgs.libunistring}/etc/**,
91
-
r ${pkgs.libunistring}/lib/**,
92
-
r ${pkgs.libunistring}/lib64/**,
93
-
x ${pkgs.libunistring}/foo/**,
94
-
ixr ${pkgs.glibc.libgcc}/libexec/**,
95
-
mr ${pkgs.glibc.libgcc}/lib/**.so*,
96
-
mr ${pkgs.glibc.libgcc}/lib64/**.so*,
97
-
mr ${pkgs.glibc.libgcc}/share/**,
98
-
r ${pkgs.glibc.libgcc},
99
-
r ${pkgs.glibc.libgcc}/etc/**,
100
-
r ${pkgs.glibc.libgcc}/lib/**,
101
-
r ${pkgs.glibc.libgcc}/lib64/**,
102
-
x ${pkgs.glibc.libgcc}/foo/**,
104
-
pkgs.runCommand "actual.rules" { preferLocalBuild = true; } ''
105
-
${pkgs.gnused}/bin/sed -e 's:^[^ ]* ${builtins.storeDir}/[^,/-]*-\([^/,]*\):\1 \0:' ${
106
-
pkgs.apparmorRulesFromClosure {
108
-
additionalRules = [ "x $path/foo/**" ];
111
-
${pkgs.coreutils}/bin/sort -n -k1 |
112
-
${pkgs.gnused}/bin/sed -e 's:^[^ ]* ::' >$out