# Running Tests from the Local System The tests are designed to be run from your local computer. # Install WPT If you haven't already, clone the web-platform-tests repository: ```bash git clone https://github.com/web-platform-tests/wpt.git cd wpt ``` ## System Setup Running the tests requires `python` and `pip` as well as updating the system `hosts` file. WPT requires Python 3.8 or higher. The required setup is different depending on your operating system. ### Linux Setup If not already present, use the system package manager to install `python`, and `pip`. On Ubuntu: ```bash sudo apt-get install python3 python3-pip python3-venv ``` It is important to have a package that provides a `python` binary. On Fedora, for example, that means installing the `python-unversioned-command` package. On Ubuntu Focal and later, the package is called `python-is-python3`. ### macOS Setup The system-provided Python can be used, while `pip` can be installed for the user only: ```bash python -m ensurepip --user export PATH="$PATH:$( python3 -m site --user-base )/bin" ``` To make the `PATH` change persistent, add it to your `~/.bash_profile` file or wherever you currently set your PATH. See also [additional setup required to run Safari](safari.md). ### Windows Setup Download and install [Python 3](https://www.python.org/downloads). The installer includes `pip` by default. Add `C:\Python39` and `C:\Python39\Scripts` to your `%Path%` [environment variable](http://www.computerhope.com/issues/ch000549.htm). The standard Windows shell requires that all `wpt` commands are prefixed by the Python binary i.e. assuming `python` is on your path the server is started using: ```bash python wpt serve ``` #### Windows Subsystem for Linux Optionally on Windows you can use the [Windows Subsystem for Linux](https://docs.microsoft.com/en-us/windows/wsl/about) (WSL). If doing so, installation and usage are similar to the Linux instructions. Be aware that WSL may attempt to override `/etc/hosts` each time it is launched, which would then require you to re-run [`hosts` File Setup](#hosts-file-setup). This behavior [can be configured](https://docs.microsoft.com/en-us/windows/wsl/wsl-config#network). ### `hosts` File Setup To get the tests running, you need to set up the test domains in your [`hosts` file](http://en.wikipedia.org/wiki/Hosts_%28file%29%23Location_in_the_file_system). On Linux, macOS or other UNIX-like system: ```bash ./wpt make-hosts-file | sudo tee -a /etc/hosts ``` And on Windows (this must be run in a PowerShell session with Administrator privileges): ``` python wpt make-hosts-file | Out-File $env:SystemRoot\System32\drivers\etc\hosts -Encoding ascii -Append ``` If you are behind a proxy, you also need to make sure the domains above are excluded from your proxy lookups. ## Via the browser The test environment can then be started using ./wpt serve This will start HTTP servers on two ports and a websockets server on one port. By default the web servers start on ports 8000 and 8443 and the other ports are randomly-chosen free ports. Tests must be loaded from the *first* HTTP server in the output. To change the ports, create a `config.json` file in the wpt root directory, and add port definitions of your choice e.g.: ``` { "ports": { "http": [1234, "auto"], "https":[5678] } } ``` After your `hosts` file is configured, the servers will be locally accessible at: http://web-platform.test:8000/
https://web-platform.test:8443/ * To use the web-based runner point your browser to: http://web-platform.test:8000/tools/runner/index.html
https://web-platform.test:8443/tools/runner/index.html * This server has all the capabilities of the publicly-deployed version--see [Running the Tests from the Web](from-web.md). \**See [Trusting Root CA](../tools/certs/README.md)* ## Via the command line Many tests can be automatically executed in a new browser instance using ./wpt run [browsername] [tests] This will automatically load the tests in the chosen browser and extract the test results. For example to run the `dom/historical.html` tests in a local copy of Chrome: ./wpt run chrome dom/historical.html Or to run in a specified copy of Firefox: ./wpt run --binary ~/local/firefox/firefox firefox dom/historical.html For details on the supported products and a large number of other options for customising the test run: ./wpt run --help [A complete listing of the command-line arguments is available here](command-line-arguments.html#run). ```eval_rst .. toctree:: :hidden: command-line-arguments ``` ### Browser-specific instructions ```eval_rst .. toctree:: chrome chrome_android android_webview safari webkitgtk_minibrowser ``` ### Running in parallel To speed up the testing process, use the `--processes` option to run multiple browser instances in parallel. For example, to run the tests in dom/ with six Firefox instances in parallel: ./wpt run --processes=6 firefox dom/ But note that behaviour in this mode is necessarily less deterministic than with a single process (the default), so there may be more noise in the test results. ### Output formats By default, `./wpt run` outputs test results and a summary in a human readable format. For debugging, `--log-mach` can give more verbose output. (In particular, it will show the console output from the browser and driver; by default, those are not shown) For example: ./wpt run --log-mach=- --log-mach-level=info firefox dom/ A machine readable JSON report can be produced using `--log-wptreport`. This together with `--log-wptscreenshot` is what is used to produce results for [wpt.fyi](https://wpt.fyi). For example: ./wpt run --log-wptreport=report.json --log-wptscreenshot=screenshots.txt firefox css/css-grid/ (See [wpt.fyi documentation](https://github.com/web-platform-tests/wpt.fyi/blob/main/api/README.md#results-creation) for how results are uploaded.) ### Expectation data For use in continuous integration systems, and other scenarios where regression tracking is required, the command-line interface supports storing and loading the expected result of each test in a test run. See [Expectations Data](../../tools/wptrunner/docs/expectation) for more information on creating and maintaining these files. ## Testing polyfills Polyfill scripts can be tested using the `--inject-script` argument to either `wpt run` or `wpt serve`. See [Testing Polyfills](testing-polyfills) for details.