51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| # verifies:
 | |
| #   1. jenkins service starts on master node
 | |
| #   2. jenkins user can be extended on both master and slave
 | |
| #   3. jenkins service not started on slave node
 | |
| 
 | |
| import ./make-test.nix ({ pkgs, ...} : {
 | |
|   name = "jenkins";
 | |
|   meta = with pkgs.stdenv.lib.maintainers; {
 | |
|     maintainers = [ bjornfor coconnor domenkozar eelco chaoflow ];
 | |
|   };
 | |
| 
 | |
|   nodes = {
 | |
| 
 | |
|     master =
 | |
|       { ... }:
 | |
|       { services.jenkins.enable = true;
 | |
| 
 | |
|         # should have no effect
 | |
|         services.jenkinsSlave.enable = true;
 | |
| 
 | |
|         users.users.jenkins.extraGroups = [ "users" ];
 | |
| 
 | |
|         systemd.services.jenkins.serviceConfig.TimeoutStartSec = "6min";
 | |
|       };
 | |
| 
 | |
|     slave =
 | |
|       { ... }:
 | |
|       { services.jenkinsSlave.enable = true;
 | |
| 
 | |
|         users.users.jenkins.extraGroups = [ "users" ];
 | |
|       };
 | |
| 
 | |
|   };
 | |
| 
 | |
|   testScript = ''
 | |
|     startAll;
 | |
| 
 | |
|     $master->waitForUnit("jenkins");
 | |
| 
 | |
|     $master->mustSucceed("curl http://localhost:8080 | grep 'Authentication required'");
 | |
| 
 | |
|     print $master->execute("sudo -u jenkins groups");
 | |
|     $master->mustSucceed("sudo -u jenkins groups | grep jenkins | grep users");
 | |
| 
 | |
|     print $slave->execute("sudo -u jenkins groups");
 | |
|     $slave->mustSucceed("sudo -u jenkins groups | grep jenkins | grep users");
 | |
| 
 | |
|     $slave->mustFail("systemctl is-enabled jenkins.service");
 | |
|   '';
 | |
| })
 | 
