Skip to content

Latest commit

 

History

History
165 lines (119 loc) · 5.09 KB

web_tests_in_content_shell.md

File metadata and controls

165 lines (119 loc) · 5.09 KB

Running web tests using the content shell

Compiling

If you want to run web tests, build the target blink_tests; this includes all the other binaries required to run the tests.

Running

Using run_web_tests.py

You can run web tests using run_web_tests.py (in src/third_party/blink/tools).

python third_party/blink/tools/run_web_tests.py storage/indexeddb

To see a complete list of arguments supported, run with --help.

***promo You can add <path>/third_party/blink/tools into PATH so that you can run it from anywhere without the full path.


Run Web Tests Directly with Content Shell

In some cases (e.g. for debugging), you can run web tests directly with Content Shell executable, with the --run-web-tests flag:

out/Default/content_shell --run-web-tests <url>|<full_test_source_path>|<relative_test_path>

<relative_test_path> is relative to the web_tests directory, regardless of the current directory.

For example:

out/Default/content_shell --run-web-tests fast/forms/001.html

or

out/Default/content_shell --run-web-tests \
    /home/user/chrome/src/third_party/blink/web_tests/fast/forms/001.html

or

out/Default/content_shell --run-web-tests ~/test/temp-test.html

By default, it dumps the text result only (as the dump of pixels and audio binary data is not human readable). This can meet the requirement of most debugging requirements.

In rare cases, to run content_shell in the exact same way as run_web_tests.py runs it, you need to run it in the protocol mode.

*** note On the Mac, use Content Shell.app, not content_shell.

out/Default/Content\ Shell.app/Contents/MacOS/Content\ Shell ...

On Windows, use content_shell.exe.


Running HTTP Tests in Content Shell

HTTP tests reside under web_tests/http/tests. You need to start a web server first:

python third_party/blink/tools/run_blink_httpd.py

Then run the test with a localhost URL:

out/Default/content_shell --run-web-tests http://localhost:8000/<test>

Running WPT Tests in Content Shell

Similar to HTTP tests, many WPT (a.k.a. web-platform-tests under web_tests/external/wpt directory) tests require some setup before running in Content Shell:

python third_party/blink/tools/run_blink_wptserve.py

Then run the test:

out/Default/content_shell --run-web-tests http://localhost:8001/<test>

See the blink-dev discussion for more details.

As a simple browser

You can run the shell directly as a simple browser:

out/Default/content_shell

This allows you see how your changes look in Chromium. You can inspect the page by right clicking and selecting 'Inspect Element'.

You can also use --remote-debugging-port

out/Default/content_shell --remote-debugging-port=9222

and open http://localhost:9222 from another browser to inspect the page. This is useful when you don't want DevTools to run in the same Content Shell, e.g. when you are logging a lot and don't want the log from DevTools or when DevTools is unstable in the current revision due to some bugs.

Debugging

--single-process

The command line switch --single-process is useful for starting content_shell in gdb. In most cases, --single-process is good for debugging except when you want to debug the multiple process behavior or when we have some bug breaking --single-process in particular cases.

Web tests

See Run Web Tests Directly with Content Shell. In most cases you don't need --single-process because content_shell is in single process mode when running most web tests.

See DevTools frontend for the commands that are useful for debugging devtools web tests.

In The Default Multiple Process Mode

In rare cases, you need to debug Content Shell in multiple process mode. You can ask Content Shell to wait for you to attach a debugger once it spawns a renderer process by adding the --renderer-startup-dialog flag:

out/Default/content_shell --renderer-startup-dialog --no-sandbox

Debugging workers and other subprocesses is simpler with --wait-for-debugger-children, which can have one of two values: plugin or renderer.

Future Work

Reusing existing testing objects

To avoid writing (and maintaining!) yet another test controller, it is desirable to reuse an existing test controller. A possible solution would be to change DRT's test controller to not depend on DRT's implementation of the Blink objects, but rather on the Blink interfaces. In addition, we would need to extract an interface from the test shell object that can be implemented by content shell. This would allow for directly using DRT's test controller in content shell.