nixos/tests/chromium: Add ungoogled-chromium and Google Chrome
By default only `chromium` will be tested but other "channels" can be selected using e.g.: nix-build nixos/tests/chromium.nix -A ungoogled This also adds me as secondary maintainer (I'd like to get notified on PRs/issues and can review them).
This commit is contained in:
		
							parent
							
								
									9a1b21a39f
								
							
						
					
					
						commit
						ff8866e243
					
				| @ -1,10 +1,14 @@ | ||||
| { system ? builtins.currentSystem | ||||
| , config ? {} | ||||
| , pkgs ? import ../.. { inherit system config; } | ||||
| , channelMap ? { | ||||
| , channelMap ? { # Maps "channels" to packages | ||||
|     stable        = pkgs.chromium; | ||||
|     beta          = pkgs.chromiumBeta; | ||||
|     dev           = pkgs.chromiumDev; | ||||
|     ungoogled     = pkgs.ungoogled-chromium; | ||||
|     chrome-stable = pkgs.google-chrome; | ||||
|     chrome-beta   = pkgs.google-chrome-beta; | ||||
|     chrome-dev    = pkgs.google-chrome-dev; | ||||
|   } | ||||
| }: | ||||
| 
 | ||||
| @ -14,7 +18,7 @@ with pkgs.lib; | ||||
| mapAttrs (channel: chromiumPkg: makeTest rec { | ||||
|   name = "chromium-${channel}"; | ||||
|   meta = { | ||||
|     maintainers = with maintainers; [ aszlig ]; | ||||
|     maintainers = with maintainers; [ aszlig primeos ]; | ||||
|     # https://github.com/NixOS/hydra/issues/591#issuecomment-435125621 | ||||
|     inherit (chromiumPkg.meta) timeout; | ||||
|   }; | ||||
| @ -58,6 +62,19 @@ mapAttrs (channel: chromiumPkg: makeTest rec { | ||||
|         return "su - ${user} -c " + shlex.quote(cmd) | ||||
| 
 | ||||
| 
 | ||||
|     def get_browser_binary(): | ||||
|         """Returns the name of the browser binary.""" | ||||
|         pname = "${getName chromiumPkg.name}" | ||||
|         if pname.find("chromium") != -1: | ||||
|             return "chromium"  # Same name for all channels and ungoogled-chromium | ||||
|         if pname == "google-chrome": | ||||
|             return "google-chrome-stable" | ||||
|         if pname == "google-chrome-dev": | ||||
|             return "google-chrome-unstable" | ||||
|         # For google-chrome-beta and as fallback: | ||||
|         return pname | ||||
| 
 | ||||
| 
 | ||||
|     def create_new_win(): | ||||
|         with machine.nested("Creating a new Chromium window"): | ||||
|             machine.execute( | ||||
| @ -153,7 +170,14 @@ mapAttrs (channel: chromiumPkg: makeTest rec { | ||||
|     machine.wait_for_x() | ||||
| 
 | ||||
|     url = "file://${startupHTML}" | ||||
|     machine.succeed(ru(f'ulimit -c unlimited; chromium "{url}" & disown')) | ||||
|     machine.succeed(ru(f'ulimit -c unlimited; "{get_browser_binary()}" "{url}" & disown')) | ||||
| 
 | ||||
|     if get_browser_binary().startswith("google-chrome"): | ||||
|         # Need to click away the first window: | ||||
|         machine.wait_for_text("Make Google Chrome the default browser") | ||||
|         machine.screenshot("google_chrome_default_browser_prompt") | ||||
|         machine.send_key("ret") | ||||
| 
 | ||||
|     machine.wait_for_text("startup done") | ||||
|     machine.wait_until_succeeds( | ||||
|         ru( | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Michael Weiss
						Michael Weiss