| # Safari |
| |
| To run Safari on macOS, some manual setup is required. Some steps are different |
| for Safari and Safari Technology Preview. |
| |
| * Allow Safari to be controlled by SafariDriver: |
| * `safaridriver --enable` or |
| * `"/Applications/Safari Technology Preview.app/Contents/MacOS/safaridriver" --enable` |
| |
| * Allow pop-up windows: |
| * `defaults write com.apple.Safari WebKitJavaScriptCanOpenWindowsAutomatically 1` or |
| * `defaults write com.apple.SafariTechnologyPreview WebKitJavaScriptCanOpenWindowsAutomatically 1` |
| |
| * Turn on additional experimental features Safari Technology Preview: |
| * `defaults write com.apple.SafariTechnologyPreview ExperimentalServerTimingEnabled 1` |
| |
| * Trust the certificate: |
| * `security add-trusted-cert -k "$(security default-keychain | cut -d\" -f2)" tools/certs/cacert.pem` |
| |
| * Set `no_proxy='*'` in your environment. This is a |
| workaround for a known |
| [macOS High Sierra issue](https://github.com/web-platform-tests/wpt/issues/9007). |
| |
| Now, run the tests using the `safari` product: |
| ``` |
| ./wpt run safari [test_list] |
| ``` |
| |
| This will use the `safaridriver` found on the path, which will be stable Safari. |
| To run Safari Technology Preview instead, use the `--channel=preview` argument: |
| ``` |
| ./wpt run --channel=preview safari [test_list] |
| ``` |
| |
| ## Debugging |
| |
| To debug problems with `safaridriver`, add the `--webdriver-arg=--diagnose` |
| argument: |
| ``` |
| ./wpt run --channel=preview --webdriver-arg=--diagnose safari [test_list] |
| ``` |
| |
| The logs will be in `~/Library/Logs/com.apple.WebDriver/`. |
| See `man safaridriver` for more information. |
| |
| To enable safaridriver diagnostics in Azure Pipelines, set |
| `safaridriver_diagnose` to `true` in `.azure-pipelines.yml`. |