83 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
		
		
			
		
	
	
			83 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
|   | import ./make-test-python.nix ({ pkgs, ... } : { | ||
|  |   name = "apparmor"; | ||
|  |   meta = with pkgs.lib.maintainers; { | ||
|  |     maintainers = [ julm ]; | ||
|  |   }; | ||
|  | 
 | ||
|  |   machine = | ||
|  |     { lib, pkgs, config, ... }: | ||
|  |     with lib; | ||
|  |     { | ||
|  |       security.apparmor.enable = mkDefault true; | ||
|  |     }; | ||
|  | 
 | ||
|  |   testScript = | ||
|  |     ''
 | ||
|  |       machine.wait_for_unit("multi-user.target") | ||
|  | 
 | ||
|  |       with subtest("AppArmor profiles are loaded"): | ||
|  |           machine.succeed("systemctl status apparmor.service") | ||
|  | 
 | ||
|  |       # AppArmor securityfs | ||
|  |       with subtest("AppArmor securityfs is mounted"): | ||
|  |           machine.succeed("mountpoint -q /sys/kernel/security") | ||
|  |           machine.succeed("cat /sys/kernel/security/apparmor/profiles") | ||
|  | 
 | ||
|  |       # Test apparmorRulesFromClosure by: | ||
|  |       # 1. Prepending a string of the relevant packages' name and version on each line. | ||
|  |       # 2. Sorting according to those strings. | ||
|  |       # 3. Removing those prepended strings. | ||
|  |       # 4. Using `diff` against the expected output. | ||
|  |       with subtest("apparmorRulesFromClosure"): | ||
|  |           machine.succeed( | ||
|  |               "${pkgs.diffutils}/bin/diff ${pkgs.writeText "expected.rules" ''
 | ||
|  |                   mr ${pkgs.bash}/lib/**.so*,
 | ||
|  |                   r ${pkgs.bash}, | ||
|  |                   r ${pkgs.bash}/etc/**,
 | ||
|  |                   r ${pkgs.bash}/lib/**,
 | ||
|  |                   r ${pkgs.bash}/share/**,
 | ||
|  |                   x ${pkgs.bash}/foo/**,
 | ||
|  |                   mr ${pkgs.glibc}/lib/**.so*,
 | ||
|  |                   r ${pkgs.glibc}, | ||
|  |                   r ${pkgs.glibc}/etc/**,
 | ||
|  |                   r ${pkgs.glibc}/lib/**,
 | ||
|  |                   r ${pkgs.glibc}/share/**,
 | ||
|  |                   x ${pkgs.glibc}/foo/**,
 | ||
|  |                   mr ${pkgs.libcap}/lib/**.so*,
 | ||
|  |                   r ${pkgs.libcap}, | ||
|  |                   r ${pkgs.libcap}/etc/**,
 | ||
|  |                   r ${pkgs.libcap}/lib/**,
 | ||
|  |                   r ${pkgs.libcap}/share/**,
 | ||
|  |                   x ${pkgs.libcap}/foo/**,
 | ||
|  |                   mr ${pkgs.libcap.lib}/lib/**.so*,
 | ||
|  |                   r ${pkgs.libcap.lib}, | ||
|  |                   r ${pkgs.libcap.lib}/etc/**,
 | ||
|  |                   r ${pkgs.libcap.lib}/lib/**,
 | ||
|  |                   r ${pkgs.libcap.lib}/share/**,
 | ||
|  |                   x ${pkgs.libcap.lib}/foo/**,
 | ||
|  |                   mr ${pkgs.libidn2.out}/lib/**.so*,
 | ||
|  |                   r ${pkgs.libidn2.out}, | ||
|  |                   r ${pkgs.libidn2.out}/etc/**,
 | ||
|  |                   r ${pkgs.libidn2.out}/lib/**,
 | ||
|  |                   r ${pkgs.libidn2.out}/share/**,
 | ||
|  |                   x ${pkgs.libidn2.out}/foo/**,
 | ||
|  |                   mr ${pkgs.libunistring}/lib/**.so*,
 | ||
|  |                   r ${pkgs.libunistring}, | ||
|  |                   r ${pkgs.libunistring}/etc/**,
 | ||
|  |                   r ${pkgs.libunistring}/lib/**,
 | ||
|  |                   r ${pkgs.libunistring}/share/**,
 | ||
|  |                   x ${pkgs.libunistring}/foo/**,
 | ||
|  |               ''} ${pkgs.runCommand "actual.rules" { preferLocalBuild = true; } ''
 | ||
|  |                   ${pkgs.gnused}/bin/sed -e 's:^[^ ]* ${builtins.storeDir}/[^,/-]*-\([^/,]*\):\1 \0:' ${ | ||
|  |                       pkgs.apparmorRulesFromClosure { | ||
|  |                         name = "ping"; | ||
|  |                         additionalRules = ["x $path/foo/**"]; | ||
|  |                       } [ pkgs.libcap ] | ||
|  |                   } | | ||
|  |                   ${pkgs.coreutils}/bin/sort -n -k1 | | ||
|  |                   ${pkgs.gnused}/bin/sed -e 's:^[^ ]* ::' >$out | ||
|  |               ''}"
 | ||
|  |           ) | ||
|  |     '';
 | ||
|  | }) |