 25bef2d8f9
			
		
	
	
		25bef2d8f9
		
	
	
	
	
		
			
			The library does not depend on stdenv, that `stdenv` exposes `lib` is an artifact of the ancient origins of nixpkgs.
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| 
 | |
| import ./make-test-python.nix ({ pkgs, ...} : {
 | |
|   name = "ferm";
 | |
|   meta = with pkgs.lib.maintainers; {
 | |
|     maintainers = [ mic92 ];
 | |
|   };
 | |
| 
 | |
|   nodes =
 | |
|     { client =
 | |
|         { pkgs, ... }:
 | |
|         with pkgs.lib;
 | |
|         {
 | |
|           networking = {
 | |
|             dhcpcd.enable = false;
 | |
|             interfaces.eth1.ipv6.addresses = mkOverride 0 [ { address = "fd00::2"; prefixLength = 64; } ];
 | |
|             interfaces.eth1.ipv4.addresses = mkOverride 0 [ { address = "192.168.1.2"; prefixLength = 24; } ];
 | |
|           };
 | |
|       };
 | |
|       server =
 | |
|         { pkgs, ... }:
 | |
|         with pkgs.lib;
 | |
|         {
 | |
|           networking = {
 | |
|             dhcpcd.enable = false;
 | |
|             useNetworkd = true;
 | |
|             useDHCP = false;
 | |
|             interfaces.eth1.ipv6.addresses = mkOverride 0 [ { address = "fd00::1"; prefixLength = 64; } ];
 | |
|             interfaces.eth1.ipv4.addresses = mkOverride 0 [ { address = "192.168.1.1"; prefixLength = 24; } ];
 | |
|           };
 | |
| 
 | |
|           services = {
 | |
|             ferm.enable = true;
 | |
|             ferm.config = ''
 | |
|               domain (ip ip6) table filter chain INPUT {
 | |
|                 interface lo ACCEPT;
 | |
|                 proto tcp dport 8080 REJECT reject-with tcp-reset;
 | |
|               }
 | |
|             '';
 | |
|             nginx.enable = true;
 | |
|             nginx.httpConfig = ''
 | |
|               server {
 | |
|                 listen 80;
 | |
|                 listen [::]:80;
 | |
|                 listen 8080;
 | |
|                 listen [::]:8080;
 | |
| 
 | |
|                 location /status { stub_status on; }
 | |
|               }
 | |
|             '';
 | |
|           };
 | |
|         };
 | |
|     };
 | |
| 
 | |
|   testScript =
 | |
|     ''
 | |
|       start_all()
 | |
| 
 | |
|       client.wait_for_unit("network-online.target")
 | |
|       server.wait_for_unit("network-online.target")
 | |
|       server.wait_for_unit("ferm.service")
 | |
|       server.wait_for_unit("nginx.service")
 | |
|       server.wait_until_succeeds("ss -ntl | grep -q 80")
 | |
| 
 | |
|       with subtest("port 80 is allowed"):
 | |
|           client.succeed("curl --fail -g http://192.168.1.1:80/status")
 | |
|           client.succeed("curl --fail -g http://[fd00::1]:80/status")
 | |
| 
 | |
|       with subtest("port 8080 is not allowed"):
 | |
|           server.succeed("curl --fail -g http://192.168.1.1:8080/status")
 | |
|           server.succeed("curl --fail -g http://[fd00::1]:8080/status")
 | |
| 
 | |
|           client.fail("curl --fail -g http://192.168.1.1:8080/status")
 | |
|           client.fail("curl --fail -g http://[fd00::1]:8080/status")
 | |
|     '';
 | |
| })
 |