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
							 | 
						||
| 
								 | 
							
								              ''}"
							 | 
						||
| 
								 | 
							
								          )
							 | 
						||
| 
								 | 
							
								    '';
							 | 
						||
| 
								 | 
							
								})
							 |