tree: 8643bc0fc2f03b78a6a25309d7ec2d95d4aae9ea [path history] [tgz]
  1. resources/
  2. tools/
  3. a-element-origin-xhtml.xhtml
  4. a-element-origin.html
  5. a-element-xhtml.xhtml
  6. a-element.html
  7. data-uri-fragment.html
  8. failure.html
  9. historical.any.js
  10. idlharness-shadowrealm.window.js
  11. idlharness.any.js
  12. IdnaTestV2.window.js
  13. META.yml
  14. percent-encoding.window.js
  15. README.md
  16. toascii.window.js
  17. url-constructor.any.js
  18. url-origin.any.js
  19. url-searchparams.any.js
  20. url-setters-a-area.window.js
  21. url-setters-stripping.any.js
  22. url-setters.any.js
  23. url-tojson.any.js
  24. urlencoded-parser.any.js
  25. urlsearchparams-append.any.js
  26. urlsearchparams-constructor.any.js
  27. urlsearchparams-delete.any.js
  28. urlsearchparams-foreach.any.js
  29. urlsearchparams-get.any.js
  30. urlsearchparams-getall.any.js
  31. urlsearchparams-has.any.js
  32. urlsearchparams-set.any.js
  33. urlsearchparams-sort.any.js
  34. urlsearchparams-stringifier.any.js
url/README.md

urltestdata.json

These tests are for browsers, but the data for a-element.html, url-constructor.html, a-element-xhtml.xhtml, and failure.html is in resources/urltestdata.json and can be re-used by non-browser implementations. This file contains a JSON array of comments as strings and test cases as objects. The keys for each test case are:

  • base: an absolute URL as a string whose parsing without a base of its own must succeed. This key is always present, and may have a value like "about:blank" when input is an absolute URL.
  • input: an URL as a string to be parsed with base as its base URL.
  • Either:
    • failure with the value true, indicating that parsing input should return failure,

    • or href, origin, protocol, username, password, host, hostname, port, pathname, search, and hash with string values; indicating that parsing input should return an URL record and that the getters of each corresponding attribute in that URL’s API should return the corresponding value.

      The origin key may be missing. In that case, the API’s origin attribute is not tested.

In addition to testing that parsing input against base gives the result, a test harness for the URL constructor (or similar APIs) should additionally test the following pattern: if failure is true, parsing about:blank against input must give failure. This tests that the logic for converting base URLs into strings properly fails the whole parsing algorithm if the base URL cannot be parsed.

setters_tests.json

resources/setters_tests.json is self-documented.

toascii.json

resources/toascii.json is a JSON resource containing an array where each item is an object consisting of an optional comment field and mandatory input and output fields. input is the domain to be parsed according to the rules of UTS #46 (as stipulated by the URL Standard). output gives the expected output of the parser after serialization. An output of null means parsing is expected to fail.

URL parser's encoding argument

Tests in /encoding and /html/infrastructure/urls/resolving-urls/query-encoding/ cover the encoding argument to the URL parser.

There's also limited coverage in resources/percent-encoding.json for percent-encode after encoding with percentEncodeSet set to special-query percent-encode set and spaceAsPlus set to false. (Improvements to expand coverage here are welcome.)

Specification

The tests in this directory assert conformance with the URL Standard.