Command-Line Arguments

The wpt command-line application offers a number of features for interacting with WPT. The functionality is organized into “sub-commands”, and each accepts a different set of command-line arguments.

This page documents all of the available sub-commands and associated arguments.

usage: wpt [-h]
           {build-docs,test-jobs,make-hosts-file,regen-certs,update-built,tc-download,tc-decision,tc-sink-task,docker-run,docker-push,lint,manifest,manifest-download,test-paths,spec,serve,serve-wave,run,create,update-expectations,files-changed,tests-affected,install,rev-list,install-android-emulator,start-android-emulator,web-features-manifest}
           ...

Sub-commands

build-docs

Build documentation

wpt build-docs [-h] [--type TYPE] [--docker] [--serve [SERVE]]

Named Arguments

--type

Output type (default: html)

Default: “html”

--docker

Run inside the docs docker image

Default: False

--serve

Run a server on the specified port (default: 8000)

test-jobs

List test jobs that should run for a set of commits

wpt test-jobs [-h] [--all] [--includes [INCLUDES ...]] [revish]

Positional Arguments

revish

Commits to consider. Defaults to the commits on the current branch

Named Arguments

--all

List all jobs unconditionally.

Default: False

--includes

Jobs to check for. Return code is 0 if all jobs are found, otherwise 1

make-hosts-file

Output a hosts file to stdout

wpt make-hosts-file [-h] [address]

Positional Arguments

address

Address that hosts should point at

Default: “127.0.0.1”

regen-certs

Regenerate the WPT certificates

wpt regen-certs [-h] [--checkend-seconds CHECKEND_SECONDS] [--force]

Named Arguments

--checkend-seconds

The number of seconds the certificates must be valid for

Default: 5184000

--force

Regenerate certificates even if not reaching expiry

Default: False

update-built

Update built tests

wpt update-built [-h] [--list]
                 [--include [{canvas,conformance-checkers,css-images,css-ui,css-writing-modes,fetch,html5lib,infrastructure,mimesniff,speculative-parsing} ...]]

Named Arguments

--list

List suites that can be updated and the related script files

Default: False

--include

Possible choices: canvas, conformance-checkers, css-images, css-ui, css-writing-modes, fetch, html5lib, infrastructure, mimesniff, speculative-parsing

Suites to update (default is to update everything)

tc-download

Download logs from taskcluster

wpt tc-download [-h] [--ref REF] [--artifact-name ARTIFACT_NAME]
                [--repo-name REPO_NAME] [--token-file TOKEN_FILE]
                [--out-dir OUT_DIR]

Named Arguments

--ref

Branch (in the GitHub repository) or commit to fetch logs for

Default: “master”

--artifact-name

Log type to fetch

Default: “wpt_report.json.gz”

--repo-name

GitHub repo name in the format owner/repo. This must be the repo from which the Taskcluster run was scheduled (for PRs this is the repo into which the PR would merge)

Default: “web-platform-tests/wpt”

--token-file

File containing GitHub token

--out-dir

Path to save the logfiles

Default: “.”

tc-decision

Run the decision task

wpt tc-decision [-h] [--event-path EVENT_PATH] [--dry-run]
                [--tasks-path TASKS_PATH]

Named Arguments

--event-path

Path to file containing serialized GitHub event

--dry-run

Don’t actually create the tasks, just output the tasks that would be created

Default: False

--tasks-path

Path to file in which to write payload for all scheduled tasks

tc-sink-task

Run the sink task

wpt tc-sink-task [-h] [--github-checks-text-file GITHUB_CHECKS_TEXT_FILE]
                 tasks [tasks ...]

Positional Arguments

tasks

A set of Taskcluster task ids to verify the state of.

Named Arguments

--github-checks-text-file

Path to GitHub checks output file for Taskcluster runs

docker-run

Run wpt docker image

wpt docker-run [-h] [--rebuild] [--checkout CHECKOUT] [--privileged]
               [--tag TAG]

Named Arguments

--rebuild

Force rebuild of image

Default: False

--checkout

Revision to checkout in the image. If this is not supplied we mount the wpt checkout on the host as /home/test/web-platform-tests/

--privileged

Run the image in priviledged mode (required for emulators)

Default: False

--tag

Docker image tag to use (default wpt:local)

Default: “wpt:local”

docker-push

Build and push wpt docker image

wpt docker-push [-h] [--tag TAG] [--force]

Named Arguments

--tag

Tag to use (default is taken from .taskcluster.yml)

--force

Ignore warnings and push anyway

Default: False

lint

Run the lint

wpt lint [-h] [--json] [--markdown] [--repo-root REPO_ROOT]
         [--ignore-glob IGNORE_GLOB] [--all]
         [--github-checks-text-file GITHUB_CHECKS_TEXT_FILE] [-j JOBS]
         [--paths-file PATHS_FILE]
         [paths ...]

Positional Arguments

paths

List of paths to lint

Named Arguments

--json

Output machine-readable JSON format

Default: False

--markdown

Output markdown

Default: False

--repo-root

The WPT directory. Use this option if the lint script exists outside the repository

--ignore-glob

Additional file glob to ignore (repeat to add more). Globs are matched against paths relative to REPO_ROOT using fnmatch, except that path separators are normalized.

--all

If no paths are passed, try to lint the whole working directory, not just files that changed

Default: False

--github-checks-text-file

Path to GitHub checks output file for Taskcluster runs

-j, --jobs

Level to parallelism to use (defaults to 0, which detects the number of CPUs)

Default: 0

--paths-file

File containing a list of files to lint, one per line

manifest

Update the MANIFEST.json file

wpt manifest [-h] [-v] [-p PATH] [--tests-root TESTS_ROOT] [-r]
             [--url-base URL_BASE] [--no-download] [--cache-root CACHE_ROOT]
             [--no-parallel]

Named Arguments

-v, --verbose

Turn on verbose logging

Default: False

-p, --path

Path to manifest file.

--tests-root

Path to root of tests.

Default: /home/runner/work/wpt/wpt

-r, --rebuild

Force a full rebuild of the manifest.

Default: False

--url-base

Base url to use as the mount point for tests in this manifest.

Default: “/”

--no-download

Never attempt to download the manifest.

Default: True

--cache-root

Path in which to store any caches (default <tests_root>/.wptcache/)

Default: “/home/runner/work/wpt/wpt/.wptcache”

--no-parallel

Do not parallelize building the manifest

Default: True

manifest-download

Download recent pregenerated MANIFEST.json file

wpt manifest-download [-h] [-p PATH] [--tests-root TESTS_ROOT] [--force]

Named Arguments

-p, --path

Path to manifest file.

--tests-root

Path to root of tests.

Default: /home/runner/work/wpt/wpt

--force

Always download, even if the existing manifest is recent

Default: False

test-paths

Print test paths given a set of test ids

wpt test-paths [-h] [-p PATH] [--src-root SRC_ROOT] [--tests-root TESTS_ROOT]
               [--no-update] [-r] [--url-base URL_BASE]
               [--cache-root CACHE_ROOT] [--json]
               test_ids [test_ids ...]

Positional Arguments

test_ids

Test ids for which to get paths

Named Arguments

-p, --path

Path to manifest file.

--src-root

Path to root of sourcetree.

--tests-root

Path to root of tests.

Default: /home/runner/work/wpt/wpt

--no-update

Don’t update manifest before continuing

Default: True

-r, --rebuild

Force a full rebuild of the manifest.

Default: False

--url-base

Base url to use as the mount point for tests in this manifest.

Default: “/”

--cache-root

Path in which to store any caches (default <tests_root>/.wptcache/)

Default: “/home/runner/work/wpt/wpt/.wptcache”

--json

Output as JSON

Default: False

spec

Update the SPEC_MANIFEST.json file

wpt spec [-h] [-v] [-p PATH] [--tests-root TESTS_ROOT] [--url-base URL_BASE]
         [--cache-root CACHE_ROOT] [--no-parallel]

Named Arguments

-v, --verbose

Turn on verbose logging

Default: False

-p, --path

Path to manifest file.

--tests-root

Path to root of tests.

Default: /home/runner/work/wpt/wpt

--url-base

Base url to use as the mount point for tests in this manifest.

Default: “/”

--cache-root

Path in which to store any caches (default <tests_root>/.wptcache/)

Default: “/home/runner/work/wpt/wpt/.wptcache”

--no-parallel

Do not parallelize building the manifest

Default: True

serve

Run wptserve server

wpt serve [-h] [--latency LATENCY] [--config CONFIG_PATH]
          [--doc_root DOC_ROOT] [--ws_doc_root WS_DOC_ROOT]
          [--inject-script INJECT_SCRIPT] [--alias_file ALIAS_FILE] [--no-h2]
          [--webtransport-h3] [--exit-after-start] [--verbose]

Named Arguments

--latency

Artificial latency to add before sending http responses, in ms

--config

Path to external config file

--doc_root

Path to document root. Overrides config.

--ws_doc_root

Path to WebSockets document root. Overrides config.

--inject-script

Path to script file to inject, useful for testing polyfills.

--alias_file

File with entries for aliases/multiple doc roots. In form of /ALIAS_NAME/, DOC_ROOTn

--no-h2

Disable the HTTP/2.0 server

--webtransport-h3

Enable WebTransport over HTTP/3 server

Default: False

--exit-after-start

Exit after starting servers

Default: False

--verbose

Enable verbose logging

Default: False

serve-wave

Run wptserve server for WAVE

wpt serve-wave [-h] [--latency LATENCY] [--config CONFIG_PATH]
               [--doc_root DOC_ROOT] [--ws_doc_root WS_DOC_ROOT]
               [--inject-script INJECT_SCRIPT] [--alias_file ALIAS_FILE]
               [--no-h2] [--webtransport-h3] [--exit-after-start] [--verbose]
               [--report]

Named Arguments

--latency

Artificial latency to add before sending http responses, in ms

--config

Path to external config file

--doc_root

Path to document root. Overrides config.

--ws_doc_root

Path to WebSockets document root. Overrides config.

--inject-script

Path to script file to inject, useful for testing polyfills.

--alias_file

File with entries for aliases/multiple doc roots. In form of /ALIAS_NAME/, DOC_ROOTn

--no-h2

Disable the HTTP/2.0 server

--webtransport-h3

Enable WebTransport over HTTP/3 server

Default: False

--exit-after-start

Exit after starting servers

Default: False

--verbose

Enable verbose logging

Default: False

--report

Flag for enabling the WPTReporting server

Default: False

run

Run tests in a browser

wpt run
        [--channel {stable,release,beta,dev,canary,nightly,preview,experimental}]
        [--affected AFFECTED] [--yes] [--install-browser]
        [--install-webdriver] [--logcat-dir LOGCAT_DIR] [-h]
        [--manifest-update] [--no-manifest-update] [--manifest-download]
        [--no-manifest-download] [--timeout-multiplier TIMEOUT_MULTIPLIER]
        [--run-by-dir [RUN_BY_DIR]] [-f] [--processes PROCESSES]
        [--max-restarts MAX_RESTARTS] [--no-capture-stdio]
        [--no-fail-on-unexpected] [--no-fail-on-unexpected-pass]
        [--no-restart-on-new-group] [--list-test-groups] [--list-disabled]
        [--list-tests] [--verify] [--verify-log-full]
        [--verify-repeat-loop VERIFY_REPEAT_LOOP]
        [--verify-repeat-restart VERIFY_REPEAT_RESTART]
        [--verify-no-chaos-mode | --verify-chaos-mode]
        [--verify-max-time VERIFY_MAX_TIME]
        [--repeat-max-time REPEAT_MAX_TIME]
        [--verify-no-output-results | --verify-output-results]
        [--test-types [{reftest,wdspec,testharness,crashtest,print-reftest} ...]]
        [--subsuite-file SUBSUITE_FILE] [--subsuite SUBSUITES]
        [--include INCLUDE] [--include-file INCLUDE_FILE] [--exclude EXCLUDE]
        [--include-manifest INCLUDE_MANIFEST] [--test-groups TEST_GROUPS_FILE]
        [--skip-timeout] [--skip-crash]
        [--skip-implementation-status {not-implementing,backlog,implementing}]
        [--enable-webtransport-h3] [--no-enable-webtransport-h3] [--tag TAGS]
        [--exclude-tag EXCLUDE_TAGS] [--default-exclude]
        [--debugger [DEBUGGER]] [--debugger-args DEBUGGER_ARGS]
        [--rerun RERUN] [--repeat REPEAT] [--repeat-until-unexpected]
        [--retry-unexpected RETRY_UNEXPECTED] [--pause-after-test]
        [--no-pause-after-test] [--debug-test] [--pause-on-unexpected]
        [--no-restart-on-unexpected] [--symbols-path SYMBOLS_PATH]
        [--stackwalk-binary STACKWALK_BINARY] [--pdb] [--leak-check]
        [--no-leak-check] [--adb-binary ADB_BINARY]
        [--package-name PACKAGE_NAME] [--keep-app-data-directory]
        [--device-serial DEVICE_SERIAL] [--binary BINARY]
        [--binary-arg BINARY_ARGS] [--webdriver-binary BINARY]
        [--webdriver-arg WEBDRIVER_ARGS] [--metadata METADATA_ROOT]
        [--tests TESTS_ROOT] [--manifest MANIFEST_PATH] [--run-info RUN_INFO]
        [--product {android_webview,chrome,chrome_android,chrome_ios,chromium,edge,firefox,firefox_android,headless_shell,safari,sauce,servo,servodriver,opera,webkit,webkitgtk_minibrowser,wktr,epiphany,ladybird}]
        [--browser-version BROWSER_VERSION]
        [--browser-channel BROWSER_CHANNEL] [--config CONFIG]
        [--install-fonts] [--no-install-fonts] [--font-dir FONT_DIR]
        [--inject-script INJECT_SCRIPT] [--headless] [--no-headless]
        [--instrument-to-file INSTRUMENT_TO_FILE]
        [--suppress-handler-traceback] [--no-suppress-handler-traceback]
        [--debug-build | --release-build] [--total-chunks TOTAL_CHUNKS]
        [--this-chunk THIS_CHUNK] [--chunk-type {none,hash,id_hash,dir_hash}]
        [--ssl-type {openssl,pregenerated,none}]
        [--openssl-binary OPENSSL_BINARY] [--certutil-binary CERTUTIL_BINARY]
        [--ca-cert-path CA_CERT_PATH] [--host-key-path HOST_KEY_PATH]
        [--host-cert-path HOST_CERT_PATH] [--prefs-root PREFS_ROOT]
        [--preload-browser] [--no-preload-browser] [--disable-e10s]
        [--disable-fission] [--stackfix-dir STACKFIX_DIR]
        [--specialpowers-path SPECIALPOWERS_PATH] [--setpref PREF=VALUE]
        [--reftest-internal] [--reftest-external]
        [--reftest-screenshot {always,fail,unexpected}]
        [--chaos [CHAOS_MODE_FLAGS]] [--setenv ENV]
        [--user-stylesheet USER_STYLESHEETS] [--enable-mojojs]
        [--mojojs-path MOJOJS_PATH] [--enable-swiftshader]
        [--enable-experimental] [--no-enable-experimental]
        [--enable-sanitizer] [--reuse-window] [--sauce-browser SAUCE_BROWSER]
        [--sauce-platform SAUCE_PLATFORM] [--sauce-version SAUCE_VERSION]
        [--sauce-build SAUCE_BUILD] [--sauce-tags [SAUCE_TAGS ...]]
        [--sauce-tunnel-id SAUCE_TUNNEL_ID] [--sauce-user SAUCE_USER]
        [--sauce-key SAUCE_KEY] [--sauce-connect-binary SAUCE_CONNECT_BINARY]
        [--sauce-init-timeout SAUCE_INIT_TIMEOUT]
        [--sauce-connect-arg SAUCE_CONNECT_ARGS]
        [--github-checks-text-file GITHUB_CHECKS_TEXT_FILE]
        [--webkit-port WEBKIT_PORT] [--kill-safari] [--log-raw LOG_RAW]
        [--log-unittest LOG_UNITTEST] [--log-xunit LOG_XUNIT]
        [--log-html LOG_HTML] [--log-mach LOG_MACH] [--log-tbpl LOG_TBPL]
        [--log-grouped LOG_GROUPED] [--log-chromium LOG_CHROMIUM]
        [--log-wptreport LOG_WPTREPORT]
        [--log-wptscreenshot LOG_WPTSCREENSHOT]
        [--log-raw-level LOG_RAW_LEVEL] [--log-mach-verbose]
        [--log-mach-level LOG_MACH_LEVEL] [--log-mach-buffer LOG_MACH_BUFFER]
        [--log-mach-screenshot] [--log-mach-no-screenshot]
        [--log-tbpl-compact] [--log-tbpl-level LOG_TBPL_LEVEL]
        [--log-tbpl-buffer LOG_TBPL_BUFFER]
        [--log-wptscreenshot-api LOG_WPTSCREENSHOT_API]
        product [test_list ...]

Positional Arguments

product

Browser to run tests in

test_list

List of URLs for tests to run, or paths including tests to run. (equivalent to –include)

Named Arguments

--channel

Possible choices: stable, release, beta, dev, canary, nightly, preview, experimental

Name of browser release channel (default: nightly). “stable” and “release” are synonyms for the latest browser stable release; “beta” is the beta release; “dev” is only meaningful for Chrome (i.e. Chrome Dev); “nightly”, “experimental”, and “preview” are all synonyms for the latest available development or trunk release. (For WebDriver installs, we attempt to select an appropriate, compatible version for the latest browser release on the selected channel.) This flag overrides –browser-channel.

Default: “nightly”

--affected

Run affected tests since revish

--yes, -y

Don’t prompt before installing components

Default: True

--install-browser

Install the browser from the release channel specified by –channel (or the nightly channel by default).

Default: False

--install-webdriver

Install WebDriver from the release channel specified by –channel (or the nightly channel by default).

Default: False

--logcat-dir

Directory to write Android logcat files to

--manifest-update

Regenerate the test manifest.

--no-manifest-update

Prevent regeneration of the test manifest.

Default: True

--manifest-download

Attempt to download a preexisting manifest when updating.

--no-manifest-download

Prevent download of the test manifest.

Default: True

--timeout-multiplier

Multiplier relative to standard test timeout to use

--run-by-dir

Split run into groups by directories. With a parameter,limit the depth of splits e.g. –run-by-dir=1 to split by top-leveldirectory

Default: False

-f, --fully-parallel

Run every test in a separate group for fully parallelism.

Default: False

--processes

Number of simultaneous processes to use

--max-restarts

Maximum number of browser restart retries

Default: 5

--no-capture-stdio

Don’t capture stdio and write to logging

Default: False

--no-fail-on-unexpected

Exit with status code 0 when test expectations are violated

Default: True

--no-fail-on-unexpected-pass

Exit with status code 0 when all unexpected results are PASS

Default: True

--no-restart-on-new-group

Don’t restart test runner when start a new test group

Default: True

--verify

Run a stability check on the selected tests

Default: False

--verify-no-chaos-mode

Disable chaos mode when running on Firefox

Default: True

--verify-chaos-mode

Enable chaos mode when running on Firefox

Default: True

--verify-no-output-results

Prints individuals test results and messages

Default: True

--verify-output-results

Disable printing individuals test results and messages

Default: True

--debug-build

Build is a debug build (overrides any mozinfo file)

--release-build

Build is a release (overrides any mozinfo file)

Mode

--list-test-groups

List the top level directories containing tests that will run.

Default: False

--list-disabled

List the tests that are disabled on the current platform

Default: False

--list-tests

List all tests that will run

Default: False

--verify-log-full

Output per-iteration test results when running verify

Default: False

--verify-repeat-loop

Number of iterations for a run that reloads each test without restart.

Default: 10

--verify-repeat-restart

Number of iterations, for a run that restarts the runner between each iteration

Default: 5

--verify-max-time

The maximum number of minutes for the job to run

--repeat-max-time

The maximum number of minutes for the test suite to attempt repeat runs

Default: 100

Test Selection

--test-types

Possible choices: reftest, wdspec, testharness, crashtest, print-reftest

Test types to run

Default: {‘reftest’, ‘wdspec’, ‘testharness’, ‘crashtest’, ‘print-reftest’}

--subsuite-file

Path to JSON file containing subsuite configuration

--subsuite

Subsuite names to run. Runs all subsuites when omitted.

--include

URL prefix to include

--include-file

A file listing URL prefix for tests

--exclude

URL prefix to exclude

--include-manifest

Path to manifest listing tests to include

--test-groups

Path to json file containing a mapping {group_name: [test_ids]}

--skip-timeout

Skip tests that are expected to time out

Default: False

--skip-crash

Skip tests that are expected to crash

Default: False

--skip-implementation-status

Possible choices: not-implementing, backlog, implementing

Skip tests that have the given implementation status

--enable-webtransport-h3

Enable tests that require WebTransport over HTTP/3 server (default: false)

--no-enable-webtransport-h3

Do not enable WebTransport tests on experimental channels

Default: True

--tag

Labels applied to tests to include in the run. Labels starting dir: are equivalent to top-level directories.

--exclude-tag

Labels applied to tests to exclude in the run. Takes precedence over –tag. Labels starting dir: are equivalent to top-level directories.

--default-exclude

Only run the tests explicitly given in arguments. No tests will run if the list is empty, and the program will exit with status code 0.

Default: False

Debugging

--debugger

run under a debugger, e.g. gdb or valgrind

--debugger-args

arguments to the debugger

--rerun

Number of times to re run each test without restarts

Default: 1

--repeat

Number of times to run the tests, restarting between each run

Default: 1

--repeat-until-unexpected

Run tests in a loop until one returns an unexpected result

--retry-unexpected

Maximum number of times to retry unexpected tests. A test is retried until it gets one of the expected status, or until it exhausts the maximum number of retries.

Default: 0

--pause-after-test

Halt the test runner after each test (this happens by default if only a single test is run)

--no-pause-after-test

Don’t halt the test runner irrespective of the number of tests run

Default: True

--debug-test

Run tests with additional debugging features enabled

Default: False

--pause-on-unexpected

Halt the test runner when an unexpected result is encountered

Default: False

--no-restart-on-unexpected

Don’t restart on an unexpected result

Default: True

--symbols-path

Path or url to symbols file used to analyse crash minidumps.

--stackwalk-binary

Path to stackwalker program used to analyse minidumps.

--pdb

Drop into pdb on python exception

Default: False

--leak-check

Enable leak checking for supported browsers (Gecko: enabled by default for debug builds, silently ignored for opt, mobile)

--no-leak-check

Disable leak checking

Android specific arguments

--adb-binary

Path to adb binary to use

--package-name

Android package name to run tests against

--keep-app-data-directory

Don’t delete the app data directory

Default: False

--device-serial

Running Android instances to connect to, if not emulator-5554

Default: []

Configuration

--binary

Desktop binary to run tests against

--binary-arg

Extra argument for the binary

Default: []

--webdriver-binary

WebDriver server binary to use

--webdriver-arg

Extra argument for the WebDriver binary

Default: []

--metadata

Path to root directory containing test metadata

--tests

Path to root directory containing test files

--manifest

Path to test manifest (default is ${metadata_root}/MANIFEST.json)

--run-info

Path to directory containing extra json files to add to run info

--product

Possible choices: android_webview, chrome, chrome_android, chrome_ios, chromium, edge, firefox, firefox_android, headless_shell, safari, sauce, servo, servodriver, opera, webkit, webkitgtk_minibrowser, wktr, epiphany, ladybird

Browser against which to run tests

--browser-version

Informative string detailing the browser release version. This is included in the run_info data.

--browser-channel

Informative string detailing the browser release channel. This is included in the run_info data.

--config

Path to config file

--install-fonts

Install additional system fonts on your system

--no-install-fonts

Do not install additional system fonts on your system

Default: True

--font-dir

Path to local font installation directory

--inject-script

Path to script file to inject, useful for testing polyfills.

--headless

Run browser in headless mode

--no-headless

Don’t run browser in headless mode

Default: True

--instrument-to-file

Path to write instrumentation logs to

--suppress-handler-traceback

Don’t write the stacktrace for exceptions in server handlers

--no-suppress-handler-traceback

Write the stacktrace for exceptions in server handlers

Default: True

Test Chunking

--total-chunks

Total number of chunks to use

Default: 1

--this-chunk

Chunk number to run

Default: 1

--chunk-type

Possible choices: none, hash, id_hash, dir_hash

Chunking type to use

SSL/TLS

--ssl-type

Possible choices: openssl, pregenerated, none

Type of ssl support to enable (running without ssl may lead to spurious errors)

--openssl-binary

Path to openssl binary

Default: “openssl”

--certutil-binary

Path to certutil binary for use with Firefox + ssl

--ca-cert-path

Path to ca certificate when using pregenerated ssl certificates

--host-key-path

Path to host private key when using pregenerated ssl certificates

--host-cert-path

Path to host certificate when using pregenerated ssl certificates

Gecko-specific

--prefs-root

Path to the folder containing browser prefs

--preload-browser

Preload a gecko instance for faster restarts

--no-preload-browser

Don’t preload a gecko instance for faster restarts

--disable-e10s

Run tests without electrolysis preferences

Default: True

--disable-fission

Disable fission in Gecko.

Default: False

--stackfix-dir

Path to directory containing assertion stack fixing scripts

--specialpowers-path

Path to specialPowers extension xpi file

--setpref

Defines an extra user preference (overrides those in prefs_root)

Default: []

--reftest-internal

Enable reftest runner implemented inside Marionette

--reftest-external

Disable reftest runner implemented inside Marionette

Default: True

--reftest-screenshot

Possible choices: always, fail, unexpected

With –reftest-internal, when to take a screenshot

--chaos

Enable chaos mode with the specified feature flag (see http://searchfox.org/mozilla-central/source/mfbt/ChaosMode.h for details). If no value is supplied, all features are activated

GeckoView-specific

--setenv

Set target environment variable, like FOO=BAR

Default: []

Servo-specific

--user-stylesheet

Inject a user CSS stylesheet into every test.

Default: []

Chrome-specific

--enable-mojojs

Enable MojoJS for testing. Note that this flag is usally enabled automatically by wpt run, if it succeeds in downloading the right version of mojojs.zip or if –mojojs-path is specified.

Default: False

--mojojs-path

Path to mojojs gen/ directory. If it is not specified, wpt run will download and extract mojojs.zip into _venv2/mojojs/gen.

--enable-swiftshader

Enable SwiftShader for CPU-based 3D graphics. This can be used in environments with no hardware GPU available.

Default: False

--enable-experimental

Enable –enable-experimental-web-platform-features flag

--no-enable-experimental

Do not enable –enable-experimental-web-platform-features flag on experimental channels

Default: True

--enable-sanitizer

Only alert on sanitizer-related errors and crashes.

Default: False

--reuse-window

Reuse a window across testharness.js tests where possible, which can speed up testing. Also useful for ensuring that the renderer process has a stable PID for a debugger to attach to.

Default: False

Sauce Labs-specific

--sauce-browser

Sauce Labs browser name

--sauce-platform

Sauce Labs OS platform

--sauce-version

Sauce Labs browser version

--sauce-build

Sauce Labs build identifier

--sauce-tags

Sauce Labs identifying tag

Default: []

--sauce-tunnel-id

Sauce Connect tunnel identifier

--sauce-user

Sauce Labs user name

--sauce-key

Sauce Labs access key

--sauce-connect-binary

Path to Sauce Connect binary

--sauce-init-timeout

Number of seconds to wait for Sauce Connect tunnel to be available before aborting

Default: 30

--sauce-connect-arg

Command-line argument to forward to the Sauce Connect binary (repeatable)

Default: []

Taskcluster-specific

--github-checks-text-file

Path to GitHub checks output file

WebKit-specific

--webkit-port

WebKit port

Safari-specific

--kill-safari

Kill Safari when stopping the browser

Default: False

Output Logging

Each option represents a possible logging format and takes a filename to write that format to, or ‘-’ to write to stdout. Some options are provided by the mozlog utility; see https://firefox-source-docs.mozilla.org/mozbase/mozlog.html for extended documentation.

--log-raw

Raw structured log messages (provided by mozlog)

--log-unittest

Unittest style output (provided by mozlog)

--log-xunit

xUnit compatible XML (provided by mozlog)

--log-html

HTML report (provided by mozlog)

--log-mach

Human-readable output (provided by mozlog)

--log-tbpl

TBPL style log format (provided by mozlog)

--log-grouped

Grouped summary of test results (provided by mozlog)

--log-chromium

Chromium Layout Tests format

--log-wptreport

wptreport format

--log-wptscreenshot

wpt.fyi screenshots

--log-raw-level

A least log level to subscribe to for the given formatter (debug, info, error, etc.)

--log-mach-verbose

Enables verbose mode for the given formatter.

--log-mach-level

A least log level to subscribe to for the given formatter (debug, info, error, etc.)

--log-mach-buffer

If specified, enables message buffering at the given buffer size limit.

--log-mach-screenshot

Enable logging reftest-analyzer compatible screenshot data.

--log-mach-no-screenshot

Disable logging reftest-analyzer compatible screenshot data.

--log-tbpl-compact

Enables compact mode for the given formatter.

--log-tbpl-level

A least log level to subscribe to for the given formatter (debug, info, error, etc.)

--log-tbpl-buffer

If specified, enables message buffering at the given buffer size limit.

--log-wptscreenshot-api

Cache API (default: https://wpt.fyi/api/screenshots/hashes)

create

Create a new wpt test

wpt create [-h] [--no-editor] [-e EDITOR] [--long-timeout] [--overwrite] [-r]
           [-m REF] [--mismatch] [--wait] [--tests-root TESTS_ROOT]
           path

Positional Arguments

path

Path to the test file

Named Arguments

--no-editor

Don’t try to open the test in an editor

Default: False

-e, --editor

Editor to use

--long-timeout

Test should be given a long timeout (typically 60s rather than 10s, but varies depending on environment)

Default: False

--overwrite

Allow overwriting an existing test file

Default: False

-r, --reftest

Create a reftest rather than a testharness (js) test

Default: False

-m, --reference

Path to the reference file

--mismatch

Create a mismatch reftest

Default: False

--wait

Create a reftest that waits until takeScreenshot() is called

Default: False

--tests-root

Path to the root of the wpt directory

Default: “/home/runner/work/wpt/wpt/tools/wpt/../..”

update-expectations

Update expectations files from raw logs.

wpt update-expectations [-h] [--config CONFIG] [--metadata METADATA_ROOT]
                        [--tests TESTS_ROOT] [--manifest MANIFEST_PATH]
                        [--full]
                        [--disable-intermittent [DISABLE_INTERMITTENT]]
                        [--update-intermittent] [--remove-intermittent]
                        [--no-remove-obsolete]
                        [--properties-file PROPERTIES_FILE]
                        [--no-properties-file]
                        [--extra-property EXTRA_PROPERTY] [--log-raw LOG_RAW]
                        [--log-unittest LOG_UNITTEST] [--log-xunit LOG_XUNIT]
                        [--log-html LOG_HTML] [--log-mach LOG_MACH]
                        [--log-tbpl LOG_TBPL] [--log-grouped LOG_GROUPED]
                        [--log-chromium LOG_CHROMIUM]
                        [--log-wptreport LOG_WPTREPORT]
                        [--log-wptscreenshot LOG_WPTSCREENSHOT]
                        [--log-raw-level LOG_RAW_LEVEL] [--log-mach-verbose]
                        [--log-mach-level LOG_MACH_LEVEL]
                        [--log-mach-buffer LOG_MACH_BUFFER]
                        [--log-mach-screenshot] [--log-mach-no-screenshot]
                        [--log-tbpl-compact] [--log-tbpl-level LOG_TBPL_LEVEL]
                        [--log-tbpl-buffer LOG_TBPL_BUFFER]
                        [--log-wptscreenshot-api LOG_WPTSCREENSHOT_API]
                        [run_log ...]

Positional Arguments

run_log

Log file from run of tests

Named Arguments

--config

Path to config file

--metadata

Path to the folder containing test metadata

--tests

Path to web-platform-tests

--manifest

Path to test manifest (default is ${metadata_root}/MANIFEST.json)

--full

For all tests that are updated, remove any existing conditions and missing subtests

Default: False

--disable-intermittent

Reason for disabling tests. When updating test results, disable tests that have inconsistent results across many runs with the given reason.

--update-intermittent

Update test metadata with expected intermittent statuses.

Default: False

--remove-intermittent

Remove obsolete intermittent statuses from expected statuses.

Default: False

--no-remove-obsolete

Don’t remove metadata files that no longer correspond to a test file

Default: True

--properties-file
Path to a JSON file containing run_info properties to use in update. This must be of the form

{“properties”: [<name>], “dependents”: {<property name>: [<name>]}}

--no-properties-file

Don’t use the default properties file at ${metadata_root}/update_properties.json, even if it exists.

Default: False

--extra-property

Extra property from run_info.json to use in metadata update.

Default: []

Output Logging

Each option represents a possible logging format and takes a filename to write that format to, or ‘-’ to write to stdout. Some options are provided by the mozlog utility; see https://firefox-source-docs.mozilla.org/mozbase/mozlog.html for extended documentation.

--log-raw

Raw structured log messages (provided by mozlog)

--log-unittest

Unittest style output (provided by mozlog)

--log-xunit

xUnit compatible XML (provided by mozlog)

--log-html

HTML report (provided by mozlog)

--log-mach

Human-readable output (provided by mozlog)

--log-tbpl

TBPL style log format (provided by mozlog)

--log-grouped

Grouped summary of test results (provided by mozlog)

--log-chromium

Chromium Layout Tests format

--log-wptreport

wptreport format

--log-wptscreenshot

wpt.fyi screenshots

--log-raw-level

A least log level to subscribe to for the given formatter (debug, info, error, etc.)

--log-mach-verbose

Enables verbose mode for the given formatter.

--log-mach-level

A least log level to subscribe to for the given formatter (debug, info, error, etc.)

--log-mach-buffer

If specified, enables message buffering at the given buffer size limit.

--log-mach-screenshot

Enable logging reftest-analyzer compatible screenshot data.

--log-mach-no-screenshot

Disable logging reftest-analyzer compatible screenshot data.

--log-tbpl-compact

Enables compact mode for the given formatter.

--log-tbpl-level

A least log level to subscribe to for the given formatter (debug, info, error, etc.)

--log-tbpl-buffer

If specified, enables message buffering at the given buffer size limit.

--log-wptscreenshot-api

Cache API (default: https://wpt.fyi/api/screenshots/hashes)

files-changed

Get a list of files that have changed

wpt files-changed [-h] [--ignore-rule IGNORE_RULE] [--modified] [--new]
                  [--show-type] [--null]
                  [revish]

Positional Arguments

revish

Commits to consider. Defaults to the commits on the current branch

Named Arguments

--ignore-rule

Override the rules for paths to exclude from lists of changes. Rules are paths relative to the test root, with * before a separator or the end matching anything other than a path separator and ** in that position matching anything. This flag can be used multiple times for multiple rules. Specifying this flag overrides the default: resources/testharness*, resources/testdriver*

--modified

Include files under version control that have been modified or staged

Default: False

--new

Include files in the worktree that are not in version control

Default: False

--show-type

Print the test type along with each affected test

Default: False

--null

Separate items with a null byte

Default: False

tests-affected

Get a list of tests affected by changes

wpt tests-affected [-h] [--ignore-rule IGNORE_RULE] [--modified] [--new]
                   [--show-type] [--null] [--metadata METADATA_ROOT]
                   [revish]

Positional Arguments

revish

Commits to consider. Defaults to the commits on the current branch

Named Arguments

--ignore-rule

Override the rules for paths to exclude from lists of changes. Rules are paths relative to the test root, with * before a separator or the end matching anything other than a path separator and ** in that position matching anything. This flag can be used multiple times for multiple rules. Specifying this flag overrides the default: resources/testharness*, resources/testdriver*

--modified

Include files under version control that have been modified or staged

Default: False

--new

Include files in the worktree that are not in version control

Default: False

--show-type

Print the test type along with each affected test

Default: False

--null

Separate items with a null byte

Default: False

--metadata

Directory that will contain MANIFEST.json

Default: “/home/runner/work/wpt/wpt”

install

Install browser components

wpt install [-h]
            [--channel {stable,release,beta,dev,canary,nightly,preview,experimental}]
            [--download-only] [--rename RENAME] [-d DESTINATION]
            [--revision REVISION]
            {firefox,chrome,chromium,servo,safari,wktr} {browser,webdriver}

Positional Arguments

browser

Possible choices: firefox, chrome, chromium, servo, safari, wktr

name of web browser product

component

Possible choices: browser, webdriver

name of component

Named Arguments

--channel

Possible choices: stable, release, beta, dev, canary, nightly, preview, experimental

Name of browser release channel (default: nightly). “stable” and “release” are synonyms for the latest browser stable release; “beta” is the beta release; “dev” is only meaningful for Chrome (i.e. Chrome Dev); “nightly”, “experimental”, and “preview” are all synonyms for the latest available development or trunk release. (For WebDriver installs, we attempt to select an appropriate, compatible version for the latest browser release on the selected channel.) This flag overrides –browser-channel.

Default: “nightly”

--download-only

Download the selected component but don’t install it

Default: False

--rename

Filename, excluding extension for downloaded archive (only with –download-only)

-d, --destination

filesystem directory to place the component

--revision

Chromium revision to install from snapshots

rev-list

List tagged revisions at regular intervals

wpt rev-list [-h] [--epoch EPOCH] [--max-count MAX_COUNT]

Named Arguments

--epoch

regular interval of time selected to get the tagged revisions. Valid values are digits followed by h/d/w (e.x. 9h, 9d, 9w …) where the mimimun selectable interval is one hour (1h)

Default: 1d

--max-count

maximum number of revisions to be returned by the command

Default: 1

install-android-emulator

Setup the x86 android emulator

wpt install-android-emulator [-h] [--path DEST] [--reinstall] [--prompt]
                             [--no-prompt]

Named Arguments

--path

Root path to use for emulator tooling

--reinstall

Force reinstall even if the emulator already exists

Default: False

--prompt

Enable confirmation prompts

Default: False

--no-prompt

Skip confirmation prompts

Default: True

start-android-emulator

Start the x86 android emulator

wpt start-android-emulator [-h] [--path DEST] [--reinstall] [--prompt]
                           [--no-prompt] [--device-serial DEVICE_SERIAL]

Named Arguments

--path

Root path to use for emulator tooling

--reinstall

Force reinstall even if the emulator already exists

Default: False

--prompt

Enable confirmation prompts

Default: False

--no-prompt

Skip confirmation prompts

Default: True

--device-serial

Device serial number for Android emulator, if not emulator-5554

web-features-manifest

Create the WEB_FEATURES_MANIFEST.json

wpt web-features-manifest [-h] [-p PATH]

Named Arguments

-p, --path

Path to manifest file.