Source code

Revision control

Copy as Markdown

Other Tools

# 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/.
---
task-defaults:
worker-type: win11-64-2009-hw
fetches:
build:
- artifact: target.condprof.tests.tar.gz
- artifact: target.common.tests.tar.gz
- artifact: target.mochitest.tests.tar.gz
- artifact: target.perftests.tests.tar.gz
- artifact: target.zip
toolchain:
- win64-node
- win64-geckodriver
- browsertime
platform: windows11-64-shippable-qr/opt
require-build:
windows11-64-shippable-qr/opt: build-win64-shippable/opt
scopes:
- secrets:get:project/releng/gecko/build/level-{level}/conditioned-profiles
try-browsertime:
description: Run ./mach perftest on windows
treeherder:
symbol: perftest(win-bt)
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3.exe python/mozperftest/mozperftest/runner.py
--on-try
--browsertime-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor desktop-browser
--browsertime-geckodriver ${MOZ_FETCHES_DIR}/geckodriver.exe
--browsertime-node ${MOZ_FETCHES_DIR}/node/node.exe
--output $MOZ_FETCHES_DIR/../artifacts
# We'd like not to have to specify each test separately here. See bug 1865852.
service-worker:
description: Run service worker tests
treeherder:
symbol: perftest(win-sw)
tier: 2
attributes:
batch: false
cron: false
run-on-projects: [autoland, mozilla-central]
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3.exe python/mozperftest/mozperftest/runner.py
dom/serviceworkers/test/performance/test_caching.html
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts &&
python3.exe python/mozperftest/mozperftest/runner.py
dom/serviceworkers/test/performance/test_fetch.html
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts &&
python3.exe python/mozperftest/mozperftest/runner.py
dom/serviceworkers/test/performance/test_registration.html
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts &&
python3.exe python/mozperftest/mozperftest/runner.py
dom/serviceworkers/test/performance/test_registration.html
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts
domcount:
description: Run DOM test
treeherder:
symbol: perftest(win-dom)
attributes:
batch: false
cron: true
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3.exe python/mozperftest/mozperftest/runner.py
browser/base/content/test/perftest_browser_xhtml_dom.js
--browsertime-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor desktop-browser
--perfherder
--perfherder-metrics name:totalDOMCount,unit:count name:panelMenuCount,unit:count name:lightDOMCount,unit:count name:lightDOMDetails,unit:count
--browsertime-geckodriver ${MOZ_FETCHES_DIR}/geckodriver.exe
--browsertime-node ${MOZ_FETCHES_DIR}/node/node.exe
--output $MOZ_FETCHES_DIR/../artifacts
livesites:
description: Live site performance testing
variants: [http3]
treeherder:
symbol: perftest({symbol})
attributes:
batch: false
cron: true
perftest:
- [cloudflare, netwerk/test/perf/perftest_http3_cloudflareblog.js]
# broken: bug 1678588
# - [fb-scroll, netwerk/test/perf/perftest_http3_facebook_scroll.js]
# broken: bug 1879851
# - [g-image, netwerk/test/perf/perftest_http3_google_image.js]
# broken: bug 1799655
# - [g-search, netwerk/test/perf/perftest_http3_google_search.js]
# broken: bug 1926567
# - [lq-fetch, netwerk/test/perf/perftest_http3_lucasquicfetch.js]
# broken: bug 1695871
# - [ytw, netwerk/test/perf/perftest_http3_youtube_watch.js]
# - [ytw-scroll, netwerk/test/perf/perftest_http3_youtube_watch_scroll.js]
perftest-metrics:
by-perftest:
cloudflare:
# Example of how the specify settings for each metric
resources:
extraOptions: []
firstPaint: {}
navigationTiming: {}
pageTimings: {}
timeToContentfulPaint: {}
# broken: bug 1678588
# fb-scroll: [navigationTiming, pageTimings, resources, firstPaint, timeToContentfulPaint, requestsPerSecond]
# broken: bug 1879851
# g-image: [navigationTiming, pageTimings, resources, firstPaint, timeToContentfulPaint, imagesPerSecond, imageLoadTime]
# g-search: [navigationTiming, pageTimings, resources, firstPaint, timeToContentfulPaint]
# broken: bug 1926567
# lq-fetch: [navigationTiming, pageTimings, resources, timeToContentfulPaint, resourceLoadTime, imagesLoaded, imagesMissed]
# broken: bug 1695871
# ytw: [navigationTiming, pageTimings, resources, firstPaint, timeToContentfulPaint, droppedFrames, decodedFrames]
# ytw-scroll: [navigationTiming, pageTimings, resources, firstPaint, timeToContentfulPaint, droppedFrames, decodedFrames]
default: [navigationTiming, pageTimings, resources, firstPaint, timeToContentfulPaint]
# Leave this here so people know this exists when looking
# for examples
perftest-perfherder-global:
extraOptions: []
perftest-extra-options:
by-perftest:
cloudflare:
- --perfherder-split-by browserScripts.pageinfo.url
# g-search:
# - --perfherder-split-by browserScripts.pageinfo.url
# broken: bug 1926567
# lq-fetch:
# - --perfherder-split-by browserScripts.pageinfo.url
default: []
perftest-btime-variants:
by-perftest:
cloudflare:
- ["10s", browsertime.waitTime=10000]
- ["25s", browsertime.waitTime=25000]
- ["35s", browsertime.waitTime=35000]
- ["60s", browsertime.waitTime=60000]
# broken: bug 1678588
# fb-scroll:
# - ["10s", browsertime.waitTime=10000]
# - ["25s", browsertime.waitTime=25000]
# - ["35s", browsertime.waitTime=35000]
# - ["60s", browsertime.waitTime=60000]
# g-search:
# - ["10s", browsertime.waitTime=10000]
# - ["25s", browsertime.waitTime=25000]
# - ["35s", browsertime.waitTime=35000]
# - ["60s", browsertime.waitTime=60000]
# broken: bug 1926567
# lq-fetch:
# - [null, "browsertime.waitTime=1000,browsertime.cycles=5"]
# broken: bug 1695871
# ytw:
# - [null, browsertime.waitTime=20000]
# ytw-scroll:
# - [null, browsertime.waitTime=20000]
default:
- [null, browsertime.waitTime=1000]
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3.exe python/mozperftest/mozperftest/runner.py
{perftest_testname}
--browsertime-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--browsertime-iterations 10
--flavor desktop-browser
--perfherder
--perfherder-metrics {perftest_metrics}
--perfherder-simplify-names
--browsertime-geckodriver ${MOZ_FETCHES_DIR}/geckodriver.exe
--browsertime-node ${MOZ_FETCHES_DIR}/node/node.exe
--output $MOZ_FETCHES_DIR/../artifacts
controlled:
description: Controlled performance testing
treeherder:
symbol: perftest(controlled)
worker:
max-run-time: 14400
attributes:
batch: false
cron: false
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3.exe python/mozperftest/mozperftest/runner.py
netwerk/test/perf/perftest_http3_controlled.js
--browsertime-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--browsertime-iterations 1
--browsertime-cycles 96
--hooks netwerk/test/perf/hooks_throttling.py
--flavor desktop-browser
--perfherder
--perfherder-metrics name:navigationTiming,unit:ms name:pageTimings,unit:ms name:resources,unit:ms name:firstPaint,unit:ms name:timeToContentfulPaint,unit:ms
--perfherder-simplify-names
--browsertime-geckodriver ${MOZ_FETCHES_DIR}/geckodriver.exe
--browsertime-node ${MOZ_FETCHES_DIR}/node/node.exe
--output $MOZ_FETCHES_DIR/../artifacts
perfstats:
description: Run PerfStats pageload test
treeherder:
symbol: perftest(win-perfstats)
attributes:
batch: false
cron: false
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3.exe python/mozperftest/mozperftest/runner.py
--browsertime-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor desktop-browser
--browsertime-geckodriver ${MOZ_FETCHES_DIR}/geckodriver.exe
--browsertime-node ${MOZ_FETCHES_DIR}/node/node.exe
--output $MOZ_FETCHES_DIR/../artifacts
--perfherder
--perfherder-metrics name:HttpChannelCompletion,unit:ms name:HttpChannelCompletion_Cache,unit:ms name:HttpChannelCompletion_Network,unit:ms name:DisplayListBuilding,unit:ms name:Reflowing,unit:ms name:Styling,unit:ms
--browsertime-iterations 10
--hooks testing/performance/hooks_perfstats.py
testing/performance/perftest_perfstats.js
record-websites:
description: Run mozperftest to record desktop websites
treeherder:
symbol: perftest(rec)
attributes:
cron: false
run-on-projects: []
scopes:
- secrets:get:project/releng/gecko/build/level-{level}/conditioned-profiles
- secrets:get:project/perftest/gecko/level-{level}/perftest-login
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3 python/mozperftest/mozperftest/runner.py
--flavor desktop-browser
--verbose
--browsertime-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--browsertime-geckodriver ${MOZ_FETCHES_DIR}/geckodriver.exe
--proxy
--output $MOZ_FETCHES_DIR/../artifacts
--hooks testing/performance/hooks_recording.py
testing/performance/perftest_record.js
ml-perf:
fetches:
fetch:
- ort.wasm
- ort.jsep.wasm
- ort-training.wasm
- xenova-all-minilm-l6-v2
description: Run ML Models Perf Tests
treeherder:
symbol: perftest(win-ml-perf)
tier: 2
attributes:
batch: false
cron: false
run-on-projects: [autoland, mozilla-central]
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3 python/mozperftest/mozperftest/runner.py
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts
toolkit/components/ml/tests/browser/browser_ml_engine_perf.js
ml-multi-perf:
fetches:
fetch:
- ort.wasm
- ort.jsep.wasm
- ort-training.wasm
- xenova-all-minilm-l6-v2
- mozilla-ner
- mozilla-intent
description: Run ML Models Perf Tests
treeherder:
symbol: perftest(windows-ml-multi-perf)
tier: 2
attributes:
batch: false
cron: false
run-on-projects: [autoland, mozilla-central]
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3 python/mozperftest/mozperftest/runner.py
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts
toolkit/components/ml/tests/browser/browser_ml_engine_multi_perf.js
ml-perf-suggest-inf:
fetches:
fetch:
- ort.wasm
- ort.jsep.wasm
- ort-training.wasm
- mozilla-ner
- mozilla-intent
description: Run ML Suggest Inference Model
treeherder:
symbol: perftest(win-ml-perf-suggest-inf)
tier: 2
attributes:
batch: false
cron: false
run-on-projects: []
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3 python/mozperftest/mozperftest/runner.py
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts
toolkit/components/ml/tests/browser/browser_ml_suggest_inference.js
ml-perf-suggest-int:
fetches:
fetch:
- ort.wasm
- ort.jsep.wasm
- ort-training.wasm
- mozilla-intent
description: Run ML Suggest Intent Model
treeherder:
symbol: perftest(win-ml-perf-suggest-int)
tier: 2
attributes:
batch: false
cron: false
run-on-projects: []
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3 python/mozperftest/mozperftest/runner.py
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts
toolkit/components/ml/tests/browser/browser_ml_suggest_intent_perf.js
ml-perf-suggest-ner:
fetches:
fetch:
- ort.wasm
- ort.jsep.wasm
- ort-training.wasm
- mozilla-ner
description: Run ML Suggest NER Model
treeherder:
symbol: perftest(win-ml-perf-suggest-ner)
tier: 2
attributes:
batch: false
cron: false
run-on-projects: []
run:
command: >-
mkdir -p $MOZ_FETCHES_DIR/../artifacts &&
cd $MOZ_FETCHES_DIR &&
python3 python/mozperftest/mozperftest/runner.py
--mochitest-binary ${MOZ_FETCHES_DIR}/firefox/firefox.exe
--flavor mochitest
--output $MOZ_FETCHES_DIR/../artifacts
toolkit/components/ml/tests/browser/browser_ml_suggest_ner_perf.js