2016-03-20 22:20:39 +01:00
|
|
|
{ system ? builtins.currentSystem
|
2018-11-11 09:41:11 +01:00
|
|
|
, config ? {}
|
|
|
|
, pkgs ? import ../.. { inherit system config; }
|
2021-01-18 15:16:27 +01:00
|
|
|
, 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;
|
2016-03-20 22:20:39 +01:00
|
|
|
}
|
|
|
|
}:
|
2016-03-01 00:20:27 +01:00
|
|
|
|
2020-02-06 14:50:47 +01:00
|
|
|
with import ../lib/testing-python.nix { inherit system pkgs; };
|
2016-03-01 00:20:27 +01:00
|
|
|
with pkgs.lib;
|
|
|
|
|
2022-03-18 01:27:04 +01:00
|
|
|
let
|
2020-02-06 14:50:47 +01:00
|
|
|
user = "alice";
|
|
|
|
|
2014-11-18 18:41:56 +01:00
|
|
|
startupHTML = pkgs.writeText "chromium-startup.html" ''
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<title>Chromium startup notifier</title>
|
|
|
|
</head>
|
|
|
|
<body onload="javascript:document.title='startup done'">
|
|
|
|
<img src="file://${pkgs.fetchurl {
|
2020-04-18 22:51:19 +02:00
|
|
|
url = "https://nixos.org/logo/nixos-hex.svg";
|
2020-01-07 19:42:52 +01:00
|
|
|
sha256 = "07ymq6nw8kc22m7kzxjxldhiq8gzmc7f45kq2bvhbdm0w5s112s4";
|
2014-11-18 18:41:56 +01:00
|
|
|
}}" />
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
'';
|
2022-03-18 01:27:04 +01:00
|
|
|
in
|
|
|
|
|
|
|
|
mapAttrs (channel: chromiumPkg: makeTest {
|
|
|
|
name = "chromium-${channel}";
|
|
|
|
meta = {
|
|
|
|
maintainers = with maintainers; [ aszlig primeos ];
|
|
|
|
# https://github.com/NixOS/hydra/issues/591#issuecomment-435125621
|
|
|
|
inherit (chromiumPkg.meta) timeout;
|
|
|
|
};
|
|
|
|
|
|
|
|
enableOCR = true;
|
|
|
|
|
|
|
|
machine.imports = [ ./common/user-account.nix ./common/x11.nix ];
|
|
|
|
machine.virtualisation.memorySize = 2047;
|
|
|
|
machine.test-support.displayManager.auto.user = user;
|
|
|
|
machine.environment = {
|
|
|
|
systemPackages = [ chromiumPkg ];
|
|
|
|
variables."XAUTHORITY" = "/home/alice/.Xauthority";
|
|
|
|
};
|
2014-11-18 18:41:56 +01:00
|
|
|
|
|
|
|
testScript = let
|
|
|
|
xdo = name: text: let
|
|
|
|
xdoScript = pkgs.writeText "${name}.xdo" text;
|
2021-01-24 20:35:29 +01:00
|
|
|
in "${pkgs.xdotool}/bin/xdotool ${xdoScript}";
|
2014-11-18 18:41:56 +01:00
|
|
|
in ''
|
2020-02-06 14:50:47 +01:00
|
|
|
import shlex
|
2021-05-08 22:58:41 +02:00
|
|
|
import re
|
|
|
|
from contextlib import contextmanager
|
2020-02-06 14:50:47 +01:00
|
|
|
|
|
|
|
|
2017-02-07 07:36:56 +01:00
|
|
|
# Run as user alice
|
2020-02-06 14:50:47 +01:00
|
|
|
def ru(cmd):
|
|
|
|
return "su - ${user} -c " + shlex.quote(cmd)
|
|
|
|
|
|
|
|
|
2021-07-09 19:04:04 +02:00
|
|
|
def launch_browser():
|
|
|
|
"""Launches the web browser with the correct options."""
|
2021-07-09 11:24:16 +02:00
|
|
|
# Determine the name of the binary:
|
2021-01-18 15:16:27 +01:00
|
|
|
pname = "${getName chromiumPkg.name}"
|
|
|
|
if pname.find("chromium") != -1:
|
2021-07-09 11:24:16 +02:00
|
|
|
binary = "chromium" # Same name for all channels and ungoogled-chromium
|
|
|
|
elif pname == "google-chrome":
|
|
|
|
binary = "google-chrome-stable"
|
|
|
|
elif pname == "google-chrome-dev":
|
|
|
|
binary = "google-chrome-unstable"
|
|
|
|
else: # For google-chrome-beta and as fallback:
|
|
|
|
binary = pname
|
|
|
|
# Add optional CLI options:
|
2021-07-09 19:04:04 +02:00
|
|
|
options = []
|
nixos/tests/chromium: Add a workaround to fix the test for M96+
Some upstream changes broke the automatic fallback to SwiftShader.
Without this workaround the GPU initialization fails (apparently due to requiring Vulkan):
machine # libva error: vaGetDriverNameByIndex() failed with unknown libva error, driver_name = (null)
machine # [1001:1001:1101/104304.000625:ERROR:viz_main_impl.cc(161)] Exiting GPU process due to errors during initialization
machine # libva error: vaGetDriverNameByIndex() failed with unknown libva error, driver_name = (null)
machine # [1052:1052:1101/104305.060496:ERROR:viz_main_impl.cc(161)] Exiting GPU process due to errors during initialization
machine # [1084:1084:1101/104305.165898:ERROR:angle_platform_impl.cc(44)] Display.cpp:894 (initialize): ANGLE Display::initialize error 0: Internal Vulkan error (-3): Initialization of an object could not be completed for implementation-specific reasons, in ../../third_party/angle/src/libANGLE/renderer/vulkan/RendererVk.cpp, initialize:1048.
machine # [1084:1084:1101/104305.171191:ERROR:gl_surface_egl.cc(782)] EGL Driver message (Critical) eglInitialize: Internal Vulkan error (-3): Initialization of an object could not be completed for implementation-specific reasons, in ../../third_party/angle/src/libANGLE/renderer/vulkan/RendererVk.cpp, initialize:1048.
machine # [1084:1084:1101/104305.178707:ERROR:gl_surface_egl.cc(1382)] eglInitialize SwANGLE failed with error EGL_NOT_INITIALIZED
machine # [1084:1084:1101/104305.180111:ERROR:gl_ozone_egl.cc(20)] GLSurfaceEGL::InitializeOneOff failed.
machine # [1084:1084:1101/104305.189760:ERROR:viz_main_impl.cc(161)] Exiting GPU process due to errors during initialization
machine # [1092:1092:1101/104305.233470:ERROR:gpu_init.cc(457)] Passthrough is not supported, GL is disabled, ANGLE is
This workaround restores the previous result:
machine # [1004:1004:1101/104551.131190:ERROR:gpu_init.cc(457)] Passthrough is not supported, GL is swiftshader, ANGLE is
The workaround is only required for Chromium, not Google Chrome.
2021-11-01 11:40:34 +01:00
|
|
|
major_version = "${versions.major (getVersion chromiumPkg.name)}"
|
|
|
|
if major_version > "95" and not pname.startswith("google-chrome"):
|
|
|
|
# Workaround to avoid a GPU crash:
|
|
|
|
options.append("--use-gl=swiftshader")
|
2021-07-09 19:04:04 +02:00
|
|
|
# Launch the process:
|
2021-07-25 12:12:18 +02:00
|
|
|
options.append("file://${startupHTML}")
|
2021-11-05 21:13:25 +01:00
|
|
|
machine.succeed(ru(f'ulimit -c unlimited; {binary} {shlex.join(options)} >&2 & disown'))
|
2021-07-09 19:04:04 +02:00
|
|
|
if 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")
|
2021-01-18 15:16:27 +01:00
|
|
|
|
|
|
|
|
2020-02-06 14:50:47 +01:00
|
|
|
def create_new_win():
|
2021-01-24 20:35:29 +01:00
|
|
|
"""Creates a new Chromium window."""
|
2020-02-06 14:50:47 +01:00
|
|
|
with machine.nested("Creating a new Chromium window"):
|
2021-01-24 20:35:29 +01:00
|
|
|
machine.wait_until_succeeds(
|
2020-02-06 14:50:47 +01:00
|
|
|
ru(
|
2021-01-24 20:35:29 +01:00
|
|
|
"${xdo "create_new_win-select_main_window" ''
|
2020-02-06 14:50:47 +01:00
|
|
|
search --onlyvisible --name "startup done"
|
|
|
|
windowfocus --sync
|
|
|
|
windowactivate --sync
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
2021-01-24 20:35:29 +01:00
|
|
|
machine.send_key("ctrl-n")
|
|
|
|
# Wait until the new window appears:
|
|
|
|
machine.wait_until_succeeds(
|
2020-02-06 14:50:47 +01:00
|
|
|
ru(
|
2021-01-24 20:35:29 +01:00
|
|
|
"${xdo "create_new_win-wait_for_window" ''
|
|
|
|
search --onlyvisible --name "New Tab"
|
2020-02-06 14:50:47 +01:00
|
|
|
windowfocus --sync
|
|
|
|
windowactivate --sync
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2021-01-24 20:35:29 +01:00
|
|
|
def close_new_tab_win():
|
|
|
|
"""Closes the Chromium window with the title "New Tab"."""
|
|
|
|
machine.wait_until_succeeds(
|
|
|
|
ru(
|
|
|
|
"${xdo "close_new_tab_win-select_main_window" ''
|
|
|
|
search --onlyvisible --name "New Tab"
|
|
|
|
windowfocus --sync
|
|
|
|
windowactivate --sync
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
machine.send_key("ctrl-w")
|
|
|
|
# Wait until the closed window disappears:
|
|
|
|
machine.wait_until_fails(
|
|
|
|
ru(
|
|
|
|
"${xdo "close_new_tab_win-wait_for_close" ''
|
|
|
|
search --onlyvisible --name "New Tab"
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
2020-02-06 14:50:47 +01:00
|
|
|
|
|
|
|
|
|
|
|
@contextmanager
|
2021-07-10 10:25:38 +02:00
|
|
|
def test_new_win(description, url, window_name):
|
2021-01-24 20:35:29 +01:00
|
|
|
create_new_win()
|
2021-07-10 10:25:38 +02:00
|
|
|
machine.wait_for_window("New Tab")
|
|
|
|
machine.send_chars(f"{url}\n")
|
|
|
|
machine.wait_for_window(window_name)
|
|
|
|
machine.screenshot(description)
|
|
|
|
machine.succeed(
|
|
|
|
ru(
|
|
|
|
"${xdo "copy-all" ''
|
|
|
|
key --delay 1000 Ctrl+a Ctrl+c
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
clipboard = machine.succeed(
|
|
|
|
ru("${pkgs.xclip}/bin/xclip -o")
|
|
|
|
)
|
|
|
|
print(f"{description} window content:\n{clipboard}")
|
2020-02-06 14:50:47 +01:00
|
|
|
with machine.nested(description):
|
2021-07-10 10:25:38 +02:00
|
|
|
yield clipboard
|
2021-01-24 20:35:29 +01:00
|
|
|
# Close the newly created window:
|
|
|
|
machine.send_key("ctrl-w")
|
2020-02-06 14:50:47 +01:00
|
|
|
|
|
|
|
|
|
|
|
machine.wait_for_x()
|
|
|
|
|
2021-07-09 19:04:04 +02:00
|
|
|
launch_browser()
|
2021-01-18 15:16:27 +01:00
|
|
|
|
2020-02-06 14:50:47 +01:00
|
|
|
machine.wait_for_text("startup done")
|
|
|
|
machine.wait_until_succeeds(
|
|
|
|
ru(
|
|
|
|
"${xdo "check-startup" ''
|
|
|
|
search --sync --onlyvisible --name "startup done"
|
|
|
|
# close first start help popup
|
|
|
|
key -delay 1000 Escape
|
|
|
|
windowfocus --sync
|
|
|
|
windowactivate --sync
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2021-01-24 20:35:29 +01:00
|
|
|
create_new_win()
|
|
|
|
# Optional: Wait for the new tab page to fully load before taking the screenshot:
|
|
|
|
machine.wait_for_text("Web Store")
|
2020-02-06 14:50:47 +01:00
|
|
|
machine.screenshot("empty_windows")
|
2021-01-24 20:35:29 +01:00
|
|
|
close_new_tab_win()
|
2020-02-06 14:50:47 +01:00
|
|
|
|
|
|
|
machine.screenshot("startup_done")
|
|
|
|
|
2021-07-10 10:25:38 +02:00
|
|
|
with test_new_win("sandbox_info", "chrome://sandbox", "Sandbox Status") as clipboard:
|
2020-02-06 14:50:47 +01:00
|
|
|
filters = [
|
|
|
|
"layer 1 sandbox.*namespace",
|
|
|
|
"pid namespaces.*yes",
|
|
|
|
"network namespaces.*yes",
|
|
|
|
"seccomp.*sandbox.*yes",
|
|
|
|
"you are adequately sandboxed",
|
|
|
|
]
|
|
|
|
if not all(
|
|
|
|
re.search(filter, clipboard, flags=re.DOTALL | re.IGNORECASE)
|
|
|
|
for filter in filters
|
|
|
|
):
|
|
|
|
assert False, f"sandbox not working properly: {clipboard}"
|
|
|
|
|
|
|
|
machine.sleep(1)
|
|
|
|
machine.succeed(
|
|
|
|
ru(
|
|
|
|
"${xdo "find-window-after-copy" ''
|
2021-01-24 20:35:29 +01:00
|
|
|
search --onlyvisible --name "Sandbox Status"
|
2020-02-06 14:50:47 +01:00
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
clipboard = machine.succeed(
|
|
|
|
ru(
|
2021-11-06 13:05:34 +01:00
|
|
|
"echo void | ${pkgs.xclip}/bin/xclip -i >&2"
|
2020-02-06 14:50:47 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
machine.succeed(
|
|
|
|
ru(
|
|
|
|
"${xdo "copy-sandbox-info" ''
|
|
|
|
key --delay 1000 Ctrl+a Ctrl+c
|
|
|
|
''}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
clipboard = machine.succeed(
|
|
|
|
ru("${pkgs.xclip}/bin/xclip -o")
|
|
|
|
)
|
|
|
|
if not all(
|
|
|
|
re.search(filter, clipboard, flags=re.DOTALL | re.IGNORECASE)
|
|
|
|
for filter in filters
|
|
|
|
):
|
|
|
|
assert False, f"copying twice in a row does not work properly: {clipboard}"
|
|
|
|
|
|
|
|
machine.screenshot("after_copy_from_chromium")
|
|
|
|
|
2021-07-10 10:25:38 +02:00
|
|
|
|
|
|
|
with test_new_win("gpu_info", "chrome://gpu", "chrome://gpu"):
|
2021-07-23 10:03:14 +02:00
|
|
|
# To check the text rendering (catches regressions like #131074):
|
|
|
|
machine.wait_for_text("Graphics Feature Status")
|
2021-07-10 10:25:38 +02:00
|
|
|
|
|
|
|
|
2021-07-25 11:49:57 +02:00
|
|
|
with test_new_win("version_info", "chrome://version", "About Version") as clipboard:
|
|
|
|
filters = [
|
|
|
|
r"${chromiumPkg.version} \(Official Build",
|
|
|
|
]
|
|
|
|
if not all(
|
|
|
|
re.search(filter, clipboard) for filter in filters
|
|
|
|
):
|
|
|
|
assert False, "Version info not correct."
|
|
|
|
|
|
|
|
|
2020-02-06 14:50:47 +01:00
|
|
|
machine.shutdown()
|
2014-11-18 18:41:56 +01:00
|
|
|
'';
|
2016-03-20 22:20:39 +01:00
|
|
|
}) channelMap
|