From 40a355a42d4a9444dc753c04c6608dade2f06a23 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 03:13:27 +0200 Subject: Adding upstream version 125.0.1. Signed-off-by: Daniel Baumann --- testing/performance/hooks_android_startup.py | 8 +++- testing/performance/hooks_recording.py | 6 +++ testing/performance/pageload_sites.json | 14 +++---- .../performance-infrastructure/perfdocs/config.yml | 8 ++++ .../performance-infrastructure/perfdocs/index.rst | 43 ++++++++++++++++++++++ testing/performance/perftest_android_startup.js | 2 +- 6 files changed, 69 insertions(+), 12 deletions(-) create mode 100644 testing/performance/performance-infrastructure/perfdocs/config.yml create mode 100644 testing/performance/performance-infrastructure/perfdocs/index.rst (limited to 'testing/performance') diff --git a/testing/performance/hooks_android_startup.py b/testing/performance/hooks_android_startup.py index 863df74447..706dff1c0a 100644 --- a/testing/performance/hooks_android_startup.py +++ b/testing/performance/hooks_android_startup.py @@ -16,6 +16,7 @@ from mozperftest.system.android_startup import ( KEY_NAME, KEY_PRODUCT, ) +from mozversioncontrol import get_repository_object HTTP_200_OKAY = 200 @@ -25,8 +26,11 @@ def before_iterations(kw): architecture = "arm64-v8a" if product == "geckoview_example": architecture = "aarch64" - commit_info = subprocess.getoutput("hg log -l 1") - commit_date = re.search(r"date:\s+([:\s\w]+)\s+", str(commit_info)).group(1) + if get_repository_object("").name == "git": + commit_info = subprocess.getoutput("git log --max-count 1") + else: + commit_info = subprocess.getoutput("hg log -l 1") + commit_date = re.search(r"[Dd]ate:\s+([:\s\w]+)\s+", str(commit_info)).group(1) download_date = ( datetime.strptime(commit_date, "%a %b %d %H:%M:%S %Y") - timedelta(days=1) ).strftime(DATETIME_FORMAT) diff --git a/testing/performance/hooks_recording.py b/testing/performance/hooks_recording.py index e35f5f4d94..072cbfb727 100644 --- a/testing/performance/hooks_recording.py +++ b/testing/performance/hooks_recording.py @@ -144,6 +144,12 @@ def before_runs(env): for pref, val in prefs.items(): add_option(env, "firefox.preference", f"{pref}:{val}") + # Add prefs that will attempt to remove cookie banners + add_option( + env, "firefox.preference", "cookiebanners.bannerClicking.enabled:true" + ) + add_option(env, "firefox.preference", "cookiebanners.service.mode:2") + second_url = test_site.get("secondary_url", None) if second_url: add_option(env, "browsertime.secondary_url", second_url) diff --git a/testing/performance/pageload_sites.json b/testing/performance/pageload_sites.json index 8037797f88..a6d735c37a 100644 --- a/testing/performance/pageload_sites.json +++ b/testing/performance/pageload_sites.json @@ -18,6 +18,11 @@ "name": "amazon-search", "test_url": "https://www.amazon.com/s/ref=nb_sb_noss_2/139-6317191-5622045?url=search-alias%3Daps&field-keywords=mobile+phone" }, + { + "login": false, + "name": "bild-de", + "test_url": "https://www.bild.de/sport/american-football/nfl/super-bowl-rekordquote-fuer-die-nfl-87139668.bild.html" + }, { "login": false, "name": "bing", @@ -146,15 +151,6 @@ "name": "stackoverflow", "test_url": "https://stackoverflow.com/" }, - { - "login": false, - "name": "web-de", - "test_url": "https://web.de/magazine/politik/politologe-glaubt-grossen-koalition-herbst-knallen-33563566", - "dismiss_cookie_prompt": [ - ["click.byXpathAndWait", "//*[@id='edit-purpose-settings']"], - ["click.byXpathAndWait", "//*[@id='save-purpose-settings']"] - ] - }, { "login": false, "name": "wikipedia", diff --git a/testing/performance/performance-infrastructure/perfdocs/config.yml b/testing/performance/performance-infrastructure/perfdocs/config.yml new file mode 100644 index 0000000000..1276050e41 --- /dev/null +++ b/testing/performance/performance-infrastructure/perfdocs/config.yml @@ -0,0 +1,8 @@ +# This Source Code Form is subject to the terms of the Mozilla Public +# License, v. 2.0. If a copy of the MPL was not distributed with this +# file, You can obtain one at http://mozilla.org/MPL/2.0/. +--- +name: performance-infrastructure +manifest: None +static-only: True +suites: {} diff --git a/testing/performance/performance-infrastructure/perfdocs/index.rst b/testing/performance/performance-infrastructure/perfdocs/index.rst new file mode 100644 index 0000000000..b8f52dfe60 --- /dev/null +++ b/testing/performance/performance-infrastructure/perfdocs/index.rst @@ -0,0 +1,43 @@ +========================== +Performance Infrastructure +========================== + +.. contents:: + :depth: 3 + + +Performance tests all run on bare matel, or real hardware devices instead of virtual machines. This gives us more realistic performance metrics, and helps with decreasing the variability of our data. See below for information on what hardware is used for each of the platforms we test on, try run wait times, as well as guidelines for requesting new devices. + + +Platforms, and Hardware Used +---------------------------- + +At the moment, these are listed in the Mozilla Wiki which is `found here `_ (see `bug 1883400 `__ for progress on this). + + +Try Runs, and Wait Times +------------------------ + +Given that our tests run on hardware, there's a limited amount of devices that can be used to run them. This means that it's very likely that a try run (e.g. tests scheduled by :ref:`Mach Try Perf`) will be delayed waiting for capacity to free up. This limited capacity is also why there is a limit of 600 tasks that can be scheduled with ``mach try perf``. + +Something to keep in mind is that try runs have a low priority, and our production branches (e.g. autoland/mozilla-central) have a higher priority. On days when there are more pushes to those branches, try runs will hit more delays. The platforms also have different capacities available to them which will change how long you have to wait for tests to start on them. **To find out how many tasks are currently pending, or running across all platforms** `see this redash query `_ **or consult the graph below.** + +.. raw:: html + + + +`See this dashboard for average wait times across all the platforms `_. + +In some cases, the tasks may hit a "task timeout" where they expire before they can run. This can be expected if there are a lot of other higher priority tasks being scheduled, so it's good to check the query mentioned above to see what the load looks like on the platform being targeted. However, there are situations where the test pools go offline or other issues occur. In general, for these task timeouts, reach out in `#perftest on Matrix `__ to notify us about the issue as we might not be aware of it. + + +Requesting New Devices for Testing +---------------------------------- + +At times, it can be useful to test changes on a different device to due a lack of configuration coverage with our existing set of devices. It's simple to request/expense a device for local testing if you need one. However, for testing in continuous integration (CI) and/or in try runs, it can be quite expensive, and time-consuming to get a device ready for it. In general it takes a **few months** to get the device(s) running, and given contractual limitations, it may also reduce the availability of other devices. The work spans multiple teams as well so the time it takes depends on the current/future tasks that those teams have at the moment. + +If a device is only required for a single issue, then it's recommended to order the device for local testing. If it's a long term project with multiple developers/teams that needs continuous monitoring, then it could be useful to have the devices in CI so they can be run on mozilla-central/autoland. This can also help ensure that your changes don't regress over time. Note that this should be planned ahead of time so that there's time to setup the devices before work on the project starts. + +For long term projects, it's also good to determine how long these devices would be needed for, and if the device setup in CI needs to be adjusted to encompass these additional configurations. If the devices are no longer needed after the long term project completes, it might not be useful to have these devices running in CI, and using local devices would be quicker, and cheaper to get. + +If you need to get a device for local testing, reach out to your manager to ask about expensing it. If you believe that you need to start testing on a new device in CI, please reach out to us in `#perftest on Matrix `__. Alternatively, you can `file a bug here `_ for support on this. diff --git a/testing/performance/perftest_android_startup.js b/testing/performance/perftest_android_startup.js index 4dfcd32af0..55f17dca6e 100644 --- a/testing/performance/perftest_android_startup.js +++ b/testing/performance/perftest_android_startup.js @@ -4,7 +4,7 @@ /* eslint-env node */ "use strict"; -async function test(context, commands) {} +async function test() {} module.exports = { test, -- cgit v1.2.3