Update web-platform-tests to revision cb40575e1a57892476f3e326355674d492dedbd2

This commit is contained in:
WPT Sync Bot 2020-06-27 08:20:23 +00:00
parent 0afe412d63
commit fa6a725a86
170 changed files with 1958 additions and 664 deletions

View file

@ -0,0 +1,4 @@
[hit-test-floats-002.html]
[Hit test float]
expected: FAIL

View file

@ -0,0 +1,4 @@
[hit-test-floats-003.html]
[Miss float below something else]
expected: FAIL

View file

@ -0,0 +1,4 @@
[hit-test-floats-004.html]
[Miss float below something else]
expected: FAIL

View file

@ -0,0 +1,2 @@
[border-image-image-type-003.htm]
expected: FAIL

View file

@ -2,3 +2,6 @@
[Hit test intersecting scaled box] [Hit test intersecting scaled box]
expected: FAIL expected: FAIL
[Hit test within unscaled box]
expected: FAIL

View file

@ -1,4 +0,0 @@
[elementFromPoint-001.html]
[CSSOM View - 5 - extensions to the Document interface]
expected: FAIL

View file

@ -1,4 +0,0 @@
[elementsFromPoint-invalid-cases.html]
[The root element is the last element returned for otherwise empty queries within the viewport]
expected: FAIL

View file

@ -312,24 +312,24 @@
[Response: combined response Content-Type: text/html;" \\" text/plain ";charset=GBK] [Response: combined response Content-Type: text/html;" \\" text/plain ";charset=GBK]
expected: NOTRUN expected: NOTRUN
[<iframe>: separate response Content-Type: text/html */*;charset=gbk]
expected: FAIL
[<iframe>: separate response Content-Type: text/html;" \\" text/plain]
expected: FAIL
[<iframe>: combined response Content-Type: text/html;x=" text/plain]
expected: FAIL
[<iframe>: combined response Content-Type: text/html;charset=gbk text/plain text/html] [<iframe>: combined response Content-Type: text/html;charset=gbk text/plain text/html]
expected: FAIL expected: FAIL
[<iframe>: separate response Content-Type: text/html;" text/plain] [<iframe>: separate response Content-Type: text/html;" text/plain]
expected: FAIL expected: FAIL
[<iframe>: separate response Content-Type: text/html */*]
expected: FAIL
[<iframe>: separate response Content-Type: text/plain */*] [<iframe>: separate response Content-Type: text/plain */*]
expected: FAIL expected: FAIL
[<iframe>: combined response Content-Type: text/html */*;charset=gbk]
expected: FAIL
[<iframe>: separate response Content-Type: text/html;x=" text/plain]
expected: FAIL
[<iframe>: combined response Content-Type: text/html;" \\" text/plain]
expected: FAIL
[<iframe>: separate response Content-Type: text/plain */*;charset=gbk]
expected: FAIL

View file

@ -56,6 +56,6 @@
[separate text/javascript x/x] [separate text/javascript x/x]
expected: FAIL expected: FAIL
[separate text/javascript ] [separate text/javascript error]
expected: FAIL expected: FAIL

View file

@ -11,9 +11,6 @@
[X-Content-Type-Options%3A%20nosniff%2C%2C%40%23%24%23%25%25%26%5E%26%5E*()()11!] [X-Content-Type-Options%3A%20nosniff%2C%2C%40%23%24%23%25%25%26%5E%26%5E*()()11!]
expected: FAIL expected: FAIL
[X-Content-Type-Options%3A%20%22nosniFF%22] [X-Content-Type-Options%3A%20no%0D%0AX-Content-Type-Options%3A%20nosniff]
expected: FAIL
[X-Content-Type-Options%3A%0D%0AX-Content-Type-Options%3A%20nosniff]
expected: FAIL expected: FAIL

View file

@ -0,0 +1,4 @@
[traverse_the_history_1.html]
[Multiple history traversals from the same task]
expected: FAIL

View file

@ -0,0 +1,2 @@
[cross-origin-objects-on-new-window.html]
expected: TIMEOUT

View file

@ -1,5 +1,4 @@
[embedded-opener-remove-frame.html] [embedded-opener-remove-frame.html]
expected: CRASH
[opener of discarded nested browsing context] [opener of discarded nested browsing context]
expected: FAIL expected: FAIL

View file

@ -1,5 +1,5 @@
[iframe_sandbox_popups_escaping-2.html] [iframe_sandbox_popups_escaping-2.html]
expected: CRASH expected: TIMEOUT
[Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used] [Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used]
expected: TIMEOUT expected: TIMEOUT

View file

@ -1,4 +1,5 @@
[iframe_sandbox_popups_escaping-3.html] [iframe_sandbox_popups_escaping-3.html]
expected: TIMEOUT
[Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used] [Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used]
expected: FAIL expected: TIMEOUT

View file

@ -1,4 +1,5 @@
[iframe_sandbox_popups_nonescaping-1.html] [iframe_sandbox_popups_nonescaping-1.html]
expected: CRASH
[Check that popups from a sandboxed iframe do not escape the sandbox] [Check that popups from a sandboxed iframe do not escape the sandbox]
expected: FAIL expected: FAIL

View file

@ -0,0 +1,2 @@
[list-of-available-images-matching.https.html]
expected: ERROR

View file

@ -3,6 +3,3 @@
[The incumbent settings object while executing the compiled callback via Web IDL's invoke must be that of the node document] [The incumbent settings object while executing the compiled callback via Web IDL's invoke must be that of the node document]
expected: TIMEOUT expected: TIMEOUT
[The entry settings object while executing the compiled callback via Web IDL's invoke must be that of the node document]
expected: FAIL

View file

@ -0,0 +1,4 @@
[audioworkletprocessor-process-zero-outputs.https.html]
[Executing "check-zero-outputs"]
expected: FAIL

View file

@ -1,5 +1,4 @@
[003.html] [003.html]
expected: ERROR
[shared] [shared]
expected: FAIL expected: FAIL

View file

@ -1,7 +1,8 @@
[shared-worker-in-data-url-context.window.html] [shared-worker-in-data-url-context.window.html]
expected: TIMEOUT
[Create a shared worker in a data url frame] [Create a shared worker in a data url frame]
expected: FAIL expected: FAIL
[Create a data url shared worker in a data url frame] [Create a data url shared worker in a data url frame]
expected: FAIL expected: TIMEOUT

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,4 @@
[hit-test-floats-002.html]
[Hit test float]
expected: FAIL

View file

@ -0,0 +1,4 @@
[hit-test-floats-003.html]
[Miss float below something else]
expected: FAIL

View file

@ -0,0 +1,4 @@
[hit-test-floats-004.html]
[Miss float below something else]
expected: FAIL

View file

@ -0,0 +1,2 @@
[border-image-image-type-003.htm]
expected: FAIL

View file

@ -2,3 +2,6 @@
[Hit test intersecting scaled box] [Hit test intersecting scaled box]
expected: FAIL expected: FAIL
[Hit test within unscaled box]
expected: FAIL

View file

@ -1,4 +0,0 @@
[elementFromPoint-001.html]
[CSSOM View - 5 - extensions to the Document interface]
expected: FAIL

View file

@ -1,4 +0,0 @@
[elementsFromPoint-invalid-cases.html]
[The root element is the last element returned for otherwise empty queries within the viewport]
expected: FAIL

View file

@ -312,24 +312,24 @@
[fetch(): separate response Content-Type: text/plain ] [fetch(): separate response Content-Type: text/plain ]
expected: NOTRUN expected: NOTRUN
[<iframe>: separate response Content-Type: text/html */*;charset=gbk]
expected: FAIL
[<iframe>: separate response Content-Type: text/html;" \\" text/plain]
expected: FAIL
[<iframe>: combined response Content-Type: text/html;x=" text/plain]
expected: FAIL
[<iframe>: combined response Content-Type: text/html;charset=gbk text/plain text/html] [<iframe>: combined response Content-Type: text/html;charset=gbk text/plain text/html]
expected: FAIL expected: FAIL
[<iframe>: separate response Content-Type: text/html;" text/plain] [<iframe>: separate response Content-Type: text/html;" text/plain]
expected: FAIL expected: FAIL
[<iframe>: separate response Content-Type: text/html */*]
expected: FAIL
[<iframe>: separate response Content-Type: text/plain */*] [<iframe>: separate response Content-Type: text/plain */*]
expected: FAIL expected: FAIL
[<iframe>: combined response Content-Type: text/html */*;charset=gbk]
expected: FAIL
[<iframe>: separate response Content-Type: text/html;x=" text/plain]
expected: FAIL
[<iframe>: combined response Content-Type: text/html;" \\" text/plain]
expected: FAIL
[<iframe>: separate response Content-Type: text/plain */*;charset=gbk]
expected: FAIL

View file

@ -56,6 +56,6 @@
[separate text/javascript x/x] [separate text/javascript x/x]
expected: FAIL expected: FAIL
[separate text/javascript ] [separate text/javascript error]
expected: FAIL expected: FAIL

View file

@ -11,9 +11,6 @@
[X-Content-Type-Options%3A%20nosniff%2C%2C%40%23%24%23%25%25%26%5E%26%5E*()()11!] [X-Content-Type-Options%3A%20nosniff%2C%2C%40%23%24%23%25%25%26%5E%26%5E*()()11!]
expected: FAIL expected: FAIL
[X-Content-Type-Options%3A%20%22nosniFF%22] [X-Content-Type-Options%3A%20no%0D%0AX-Content-Type-Options%3A%20nosniff]
expected: FAIL
[X-Content-Type-Options%3A%0D%0AX-Content-Type-Options%3A%20nosniff]
expected: FAIL expected: FAIL

View file

@ -0,0 +1,4 @@
[traverse_the_history_1.html]
[Multiple history traversals from the same task]
expected: FAIL

View file

@ -0,0 +1,2 @@
[cross-origin-objects-on-new-window.html]
expected: TIMEOUT

View file

@ -1,5 +1,4 @@
[embedded-opener-remove-frame.html] [embedded-opener-remove-frame.html]
expected: CRASH
[opener and "removed" embedded documents] [opener and "removed" embedded documents]
expected: FAIL expected: FAIL

View file

@ -1,5 +1,5 @@
[iframe_sandbox_popups_escaping-2.html] [iframe_sandbox_popups_escaping-2.html]
expected: CRASH expected: TIMEOUT
[Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used] [Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used]
expected: TIMEOUT expected: TIMEOUT

View file

@ -1,5 +1,6 @@
[iframe_sandbox_popups_escaping-3.html] [iframe_sandbox_popups_escaping-3.html]
type: testharness type: testharness
expected: TIMEOUT
[Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used] [Check that popups from a sandboxed iframe escape the sandbox if\n allow-popups-to-escape-sandbox is used]
expected: FAIL expected: TIMEOUT

View file

@ -1,5 +1,6 @@
[iframe_sandbox_popups_nonescaping-1.html] [iframe_sandbox_popups_nonescaping-1.html]
type: testharness type: testharness
expected: CRASH
[Check that popups from a sandboxed iframe do not escape the sandbox] [Check that popups from a sandboxed iframe do not escape the sandbox]
expected: FAIL expected: FAIL

View file

@ -0,0 +1,2 @@
[list-of-available-images-matching.https.html]
expected: ERROR

View file

@ -4,6 +4,3 @@
[The incumbent settings object while executing the compiled callback via Web IDL's invoke must be that of the node document] [The incumbent settings object while executing the compiled callback via Web IDL's invoke must be that of the node document]
expected: TIMEOUT expected: TIMEOUT
[The entry settings object while executing the compiled callback via Web IDL's invoke must be that of the node document]
expected: FAIL

View file

@ -0,0 +1,4 @@
[audioworkletprocessor-process-zero-outputs.https.html]
[Executing "check-zero-outputs"]
expected: FAIL

View file

@ -1,6 +1,5 @@
[003.html] [003.html]
type: testharness type: testharness
expected: ERROR
[shared] [shared]
expected: FAIL expected: FAIL

View file

@ -1,7 +1,8 @@
[shared-worker-in-data-url-context.window.html] [shared-worker-in-data-url-context.window.html]
expected: TIMEOUT
[Create a shared worker in a data url frame] [Create a shared worker in a data url frame]
expected: FAIL expected: FAIL
[Create a data url shared worker in a data url frame] [Create a data url shared worker in a data url frame]
expected: FAIL expected: TIMEOUT

View file

@ -1,3 +1,3 @@
# Simply returns the request body to check if the upload succeeded. # Simply returns the request body to check if the upload succeeded.
def main(request, response): def main(request, response):
return 200, [("Content-Type", request.headers['content-type'])], request.body return 200, [(b"Content-Type", request.headers[b'content-type'])], request.body

View file

@ -1,24 +1,26 @@
from wptserve.utils import isomorphic_decode
def main(request, response): def main(request, response):
""" """
Simple handler that sets a response header based on which client hint Simple handler that sets a response header based on which client hint
request headers were received. request headers were received.
""" """
response.headers.append("Access-Control-Allow-Origin", "*") response.headers.append(b"Access-Control-Allow-Origin", b"*")
values = request.GET values = request.GET
name = values.first('name') name = values.first(b'name')
type = values.first('mimeType') type = values.first(b'mimeType')
dpr = values.first('dpr') dpr = values.first(b'dpr')
double = None double = None
if 'double' in values: if b'double' in values:
double = values.first('double') double = values.first(b'double')
image_path = request.doc_root + "/".join(request.url_parts[2].split("/")[:-1]) + "/" + name image_path = request.doc_root + u"/".join(request.url_parts[2].split(u"/")[:-1]) + u"/" + isomorphic_decode(name)
f = open(image_path, "rb") f = open(image_path, "rb")
buff = f.read() buff = f.read()
f.close() f.close()
response.headers.set("Content-Type", type) response.headers.set(b"Content-Type", type)
response.headers.set("Content-DPR", dpr) response.headers.set(b"Content-DPR", dpr)
if double: if double:
response.headers.append("Content-DPR", double) response.headers.append(b"Content-DPR", double)
response.headers.set("Content-Length", len(buff)) response.headers.set(b"Content-Length", len(buff))
response.content = buff response.content = buff

View file

@ -1,6 +1,8 @@
from os import path from os import path
from os import listdir from os import listdir
from wptserve.utils import isomorphic_decode
""" """
The main purpose of this script is to set cookies based on files in this folder: The main purpose of this script is to set cookies based on files in this folder:
cookies/http-state/resources cookies/http-state/resources
@ -13,18 +15,18 @@ If you want to run a test in isolation, append "?debug=" and the test id to the
URL above. URL above.
""" """
SETUP_FILE_TEMPLATE = "{}-test" SETUP_FILE_TEMPLATE = u"{}-test"
EXPECTATION_FILE_TEMPLATE = "{}-expected" EXPECTATION_FILE_TEMPLATE = u"{}-expected"
EXPECTATION_HTML_SCAFFOLD = "iframe-expectation-doc.html.py-str" EXPECTATION_HTML_SCAFFOLD = u"iframe-expectation-doc.html.py-str"
DEBUGGING_HTML_SCAFFOLD = "debugging-single-test.html.py-str" DEBUGGING_HTML_SCAFFOLD = u"debugging-single-test.html.py-str"
DEFAULT_RESOURCE_DIR = path.join("cookies", "http-state", "resources") DEFAULT_RESOURCE_DIR = path.join(u"cookies", u"http-state", u"resources")
DEFAULT_TEST_DIR = "test-files" DEFAULT_TEST_DIR = u"test-files"
ALL_TESTS = "all-tests.html.py-str" ALL_TESTS = u"all-tests.html.py-str"
def dump_file(directory, filename): def dump_file(directory, filename):
"""Reads a file into a string.""" """Reads a file into a string."""
return open(path.join(directory, filename), "r").read() return open(path.join(directory, filename), u"r").read()
class CookieTestResponse(object): class CookieTestResponse(object):
@ -46,17 +48,17 @@ class CookieTestResponse(object):
"""Returns a full HTML document which contains the expectation.""" """Returns a full HTML document which contains the expectation."""
html_frame = dump_file(self.__resources_dir, EXPECTATION_HTML_SCAFFOLD) html_frame = dump_file(self.__resources_dir, EXPECTATION_HTML_SCAFFOLD)
expected_data = dump_file(self.__test_files_dir, self.__expectation_file) expected_data = dump_file(self.__test_files_dir, self.__expectation_file)
return html_frame.format(**{'data' : expected_data}) return html_frame.format(**{u'data' : expected_data})
def find_all_test_files(root): def find_all_test_files(root):
"""Retrieves all files from the test-files/ folder and returns them as """Retrieves all files from the test-files/ folder and returns them as
string pair as used in the JavaScript object. Sorted by filename.""" string pair as used in the JavaScript object. Sorted by filename."""
all_files = [] all_files = []
line_template = '{{file: "{filename}", name: "{filename}"}},' line_template = u'{{file: "{filename}", name: "{filename}"}},'
for file in listdir(path.join(root, DEFAULT_RESOURCE_DIR, DEFAULT_TEST_DIR)): for file in listdir(path.join(root, DEFAULT_RESOURCE_DIR, DEFAULT_TEST_DIR)):
if file.endswith('-test'): if file.endswith(u'-test'):
name = file.replace('-test', '') name = file.replace(u'-test', u'')
all_files.append(line_template.format(**{'filename' : name})) all_files.append(line_template.format(**{u'filename' : name}))
all_files.sort() all_files.sort()
return all_files return all_files
@ -64,29 +66,29 @@ def generate_for_all_tests(root):
"""Returns an HTML document which loads and executes all tests in the """Returns an HTML document which loads and executes all tests in the
test-files/ directory.""" test-files/ directory."""
html_frame = dump_file(path.join(root, DEFAULT_RESOURCE_DIR), ALL_TESTS) html_frame = dump_file(path.join(root, DEFAULT_RESOURCE_DIR), ALL_TESTS)
return html_frame % '\n'.join(find_all_test_files(root)) return html_frame % u'\n'.join(find_all_test_files(root))
def main(request, response): def main(request, response):
if "debug" in request.GET: if b"debug" in request.GET:
"""If '?debug=' is set, return the document for a single test.""" """If '?debug=' is set, return the document for a single test."""
response.writer.write_status(200) response.writer.write_status(200)
response.writer.end_headers() response.writer.end_headers()
html_frame = dump_file(path.join(request.doc_root, DEFAULT_RESOURCE_DIR), html_frame = dump_file(path.join(request.doc_root, DEFAULT_RESOURCE_DIR),
DEBUGGING_HTML_SCAFFOLD) DEBUGGING_HTML_SCAFFOLD)
test_file = html_frame % (request.GET['debug']) test_file = html_frame % (isomorphic_decode(request.GET[b'debug']))
response.writer.write_content(test_file) response.writer.write_content(test_file)
return; return
if "file" in request.GET: if b"file" in request.GET:
"""If '?file=' is set, send a cookie and a document which contains the """If '?file=' is set, send a cookie and a document which contains the
expectation of which cookies should be set by the browser in response.""" expectation of which cookies should be set by the browser in response."""
cookie_response = CookieTestResponse(request.GET['file'], request.doc_root) cookie_response = CookieTestResponse(isomorphic_decode(request.GET[b'file']), request.doc_root)
response.writer.write_status(200) response.writer.write_status(200)
response.writer.write(cookie_response.cookie_setting_header()) response.writer.write(cookie_response.cookie_setting_header())
response.writer.end_headers() response.writer.end_headers()
response.writer.write_content(cookie_response.body_with_expectation()) response.writer.write_content(cookie_response.body_with_expectation())
return; return
"""Without any arguments, return documentation and run all available tests.""" """Without any arguments, return documentation and run all available tests."""
response.writer.write_status(200) response.writer.write_status(200)

View file

@ -5,11 +5,10 @@ def main(request, response):
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
try: try:
# Expire the named cookie, and return a JSON-encoded success code. # Expire the named cookie, and return a JSON-encoded success code.
name = readParameter(request, paramName="name", requireValue=True) name = readParameter(request, paramName=u"name", requireValue=True)
scheme = request.url_parts.scheme scheme = request.url_parts.scheme
headers.append(makeDropCookie(name, "https" == scheme)) headers.append(makeDropCookie(name, u"https" == scheme))
return headers, '{"success": true}' return headers, b'{"success": true}'
except: except:
return 500, headers, '{"error" : "Empty or missing name parameter."}' return 500, headers, b'{"error" : "Empty or missing name parameter."}'

View file

@ -6,8 +6,8 @@ def main(request, response):
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
# Expire the cookies, and return a JSON-encoded success code. # Expire the cookies, and return a JSON-encoded success code.
headers.append(makeDropCookie("samesite_strict", False)) headers.append(makeDropCookie(b"samesite_strict", False))
headers.append(makeDropCookie("samesite_lax", False)) headers.append(makeDropCookie(b"samesite_lax", False))
headers.append(makeDropCookie("samesite_none", False)) headers.append(makeDropCookie(b"samesite_none", False))
headers.append(makeDropCookie("samesite_unspecified", False)) headers.append(makeDropCookie(b"samesite_unspecified", False))
return headers, '{"success": true}' return headers, b'{"success": true}'

View file

@ -6,6 +6,6 @@ def main(request, response):
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
# Expire the cookies, and return a JSON-encoded success code. # Expire the cookies, and return a JSON-encoded success code.
headers.append(makeDropCookie("samesite_none_insecure", False)) headers.append(makeDropCookie(b"samesite_none_insecure", False))
headers.append(makeDropCookie("samesite_none_secure", True)) headers.append(makeDropCookie(b"samesite_none_secure", True))
return headers, '{"success": true}' return headers, b'{"success": true}'

View file

@ -1,4 +1,4 @@
from helpers import makeDropCookie, readParameter, setNoCacheAndCORSHeaders from helpers import makeDropCookie, setNoCacheAndCORSHeaders
def main(request, response): def main(request, response):
"""Respond to `/cookie/drop/secure` by dropping the two cookie set by """Respond to `/cookie/drop/secure` by dropping the two cookie set by
@ -6,6 +6,6 @@ def main(request, response):
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
# Expire the cookies, and return a JSON-encoded success code. # Expire the cookies, and return a JSON-encoded success code.
headers.append(makeDropCookie("alone_secure", False)) headers.append(makeDropCookie(b"alone_secure", False))
headers.append(makeDropCookie("alone_insecure", False)) headers.append(makeDropCookie(b"alone_insecure", False))
return headers, '{"success": true}' return headers, b'{"success": true}'

View file

@ -1,15 +1,15 @@
import json from wptserve.utils import isomorphic_decode
def main(request, response): def main(request, response):
headers = [("Content-Type", "application/json"), headers = [(b"Content-Type", b"application/json"),
("Access-Control-Allow-Credentials", "true")] (b"Access-Control-Allow-Credentials", b"true")]
if "origin" in request.headers: if b"origin" in request.headers:
headers.append(("Access-Control-Allow-Origin", request.headers["origin"])) headers.append((b"Access-Control-Allow-Origin", request.headers[b"origin"]))
values = [] values = []
for key in request.cookies: for key in request.cookies:
for value in request.cookies.get_list(key): for value in request.cookies.get_list(key):
values.append("\"%s\": \"%s\"" % (key, value)) values.append(u"\"%s\": \"%s\"" % (isomorphic_decode(key), value))
body = "{ %s }" % ",".join(values) body = u"{ %s }" % u",".join(values)
return headers, body return headers, body

View file

@ -1,47 +1,54 @@
import urlparse from six import integer_types
from six.moves.urllib.parse import parse_qs
from wptserve.utils import isomorphic_encode
def setNoCacheAndCORSHeaders(request, response): def setNoCacheAndCORSHeaders(request, response):
"""Set Cache-Control, CORS and Content-Type headers appropriate for the cookie tests.""" """Set Cache-Control, CORS and Content-Type headers appropriate for the cookie tests."""
headers = [("Content-Type", "application/json"), headers = [(b"Content-Type", b"application/json"),
("Access-Control-Allow-Credentials", "true")] (b"Access-Control-Allow-Credentials", b"true")]
origin = "*" origin = b"*"
if "origin" in request.headers: if b"origin" in request.headers:
origin = request.headers["origin"] origin = request.headers[b"origin"]
headers.append(("Access-Control-Allow-Origin", origin)) headers.append((b"Access-Control-Allow-Origin", origin))
#headers.append(("Access-Control-Allow-Credentials", "true")) #headers.append(("Access-Control-Allow-Credentials", "true"))
headers.append(("Cache-Control", "no-cache")) headers.append((b"Cache-Control", b"no-cache"))
headers.append(("Expires", "Fri, 01 Jan 1990 00:00:00 GMT")) headers.append((b"Expires", b"Fri, 01 Jan 1990 00:00:00 GMT"))
return headers return headers
def makeCookieHeader(name, value, otherAttrs): def makeCookieHeader(name, value, otherAttrs):
"""Make a Set-Cookie header for a cookie with the name, value and attributes provided.""" """Make a Set-Cookie header for a cookie with the name, value and attributes provided."""
def makeAV(a, v): def makeAV(a, v):
if None == v or "" == v: if None == v or b"" == v:
return a return a
return "%s=%s" % (a, v) if isinstance(v, integer_types):
return b"%s=%i" % (a, v)
else:
return b"%s=%s" % (a, v)
# ensure cookie name is always first # ensure cookie name is always first
attrs = ["%s=%s" % (name, value)] attrs = [b"%s=%s" % (name, value)]
attrs.extend(makeAV(a, v) for (a,v) in otherAttrs.iteritems()) attrs.extend(makeAV(a, v) for (a, v) in otherAttrs.items())
return ("Set-Cookie", "; ".join(attrs)) return (b"Set-Cookie", b"; ".join((attrs)))
def makeDropCookie(name, secure): def makeDropCookie(name, secure):
attrs = {"MaxAge": 0, "path": "/"} attrs = {b"MaxAge": 0, b"path": b"/"}
if secure: if secure:
attrs["secure"] = "" attrs[b"secure"] = b""
return makeCookieHeader(name, "", attrs) return makeCookieHeader(name, b"", attrs)
def readParameter(request, paramName, requireValue): def readParameter(request, paramName, requireValue):
"""Read a parameter from the request. Raise if requireValue is set and the """Read a parameter from the request. Raise if requireValue is set and the
parameter has an empty value or is not present.""" parameter has an empty value or is not present."""
params = urlparse.parse_qs(request.url_parts.query) params = parse_qs(request.url_parts.query)
param = params[paramName][0].strip() param = params[paramName][0].strip()
if len(param) == 0: if len(param) == 0:
raise Exception("Empty or missing name parameter.") raise Exception(u"Empty or missing name parameter.")
return param return isomorphic_encode(param)
def readCookies(request): def readCookies(request):
"""Read the cookies from the client present in the request.""" """Read the cookies from the client present in the request."""
@ -52,4 +59,3 @@ def readCookies(request):
# need to modify the test to take cookie names and value lists? # need to modify the test to take cookie names and value lists?
cookies[key] = cookie.value cookies[key] = cookie.value
return cookies return cookies

View file

@ -4,13 +4,13 @@ def main(request, response):
"""Respond to `/cookie/imgIfMatch?name={name}&value={value}` with a 404 if """Respond to `/cookie/imgIfMatch?name={name}&value={value}` with a 404 if
the cookie isn't present, and a transparent GIF otherwise.""" the cookie isn't present, and a transparent GIF otherwise."""
headers = helpers.setNoCacheAndCORSHeaders(request, response) headers = helpers.setNoCacheAndCORSHeaders(request, response)
name = helpers.readParameter(request, paramName="name", requireValue=True) name = helpers.readParameter(request, paramName=u"name", requireValue=True)
value = helpers.readParameter(request, paramName="value", requireValue=True) value = helpers.readParameter(request, paramName=u"value", requireValue=True)
cookiesWithMatchingNames = request.cookies.get_list(name) cookiesWithMatchingNames = request.cookies.get_list(name)
for cookie in cookiesWithMatchingNames: for cookie in cookiesWithMatchingNames:
if cookie.value == value: if cookie.value == value:
# From https://github.com/mathiasbynens/small/blob/master/gif-transparent.gif # From https://github.com/mathiasbynens/small/blob/master/gif-transparent.gif
headers.append(("Content-Type","image/gif")) headers.append((b"Content-Type", b"image/gif"))
gif = "\x47\x49\x46\x38\x39\x61\x01\x00\x01\x00\x80\x00\x00\xFF\xFF\xFF\x00\x00\x00\x21\xF9\x04\x01\x00\x00\x00\x00\x2C\x00\x00\x00\x00\x01\x00\x01\x00\x00\x02\x02\x44\x01\x00\x3B" gif = b"\x47\x49\x46\x38\x39\x61\x01\x00\x01\x00\x80\x00\x00\xFF\xFF\xFF\x00\x00\x00\x21\xF9\x04\x01\x00\x00\x00\x00\x2C\x00\x00\x00\x00\x01\x00\x01\x00\x00\x02\x02\x44\x01\x00\x3B"
return headers, gif return headers, gif
return 500, headers, '{"error": {"message": "The cookie\'s value did not match the given value."}}' return 500, headers, b'{"error": {"message": "The cookie\'s value did not match the given value."}}'

View file

@ -1,7 +1,10 @@
import json import json
import helpers import helpers
from wptserve.utils import isomorphic_decode
def main(request, response): def main(request, response):
headers = helpers.setNoCacheAndCORSHeaders(request, response) headers = helpers.setNoCacheAndCORSHeaders(request, response)
cookies = helpers.readCookies(request) cookies = helpers.readCookies(request)
return headers, json.dumps(cookies) decoded_cookies = {isomorphic_decode(key): isomorphic_decode(val) for key, val in cookies.items()}
return headers, json.dumps(decoded_cookies)

View file

@ -1,12 +1,14 @@
import json import json
import helpers import helpers
from wptserve.utils import isomorphic_decode
def main(request, response): def main(request, response):
headers = helpers.setNoCacheAndCORSHeaders(request, response) headers = helpers.setNoCacheAndCORSHeaders(request, response)
cookies = helpers.readCookies(request) cookies = helpers.readCookies(request)
headers.append(("Content-Type", "text/html; charset=utf-8")) headers.append((b"Content-Type", b"text/html; charset=utf-8"))
tmpl = """ tmpl = u"""
<!DOCTYPE html> <!DOCTYPE html>
<script> <script>
var data = %s; var data = %s;
@ -33,4 +35,5 @@ def main(request, response):
}); });
</script> </script>
""" """
return headers, tmpl % json.dumps(cookies) decoded_cookies = {isomorphic_decode(key): isomorphic_decode(val) for key, val in cookies.items()}
return headers, tmpl % json.dumps(decoded_cookies)

View file

@ -8,15 +8,15 @@ def main(request, response):
location - The resource to redirect to. location - The resource to redirect to.
""" """
status = 302 status = 302
if "status" in request.GET: if b"status" in request.GET:
try: try:
status = int(request.GET.first("status")) status = int(request.GET.first(b"status"))
except ValueError: except ValueError:
pass pass
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
location = request.GET.first("location") location = request.GET.first(b"location")
headers.append(("Location", location)) headers.append((b"Location", location))
return status, headers, "" return status, headers, b""

View file

@ -1,5 +1,7 @@
import helpers import helpers
import urllib from six.moves.urllib.parse import unquote
from wptserve.utils import isomorphic_encode
def main(request, response): def main(request, response):
"""Respond to `/cookie/set?{cookie}` by echoing `{cookie}` as a `Set-Cookie` header.""" """Respond to `/cookie/set?{cookie}` by echoing `{cookie}` as a `Set-Cookie` header."""
@ -7,7 +9,7 @@ def main(request, response):
# Cookies may require whitespace (e.g. in the `Expires` attribute), so the # Cookies may require whitespace (e.g. in the `Expires` attribute), so the
# query string should be decoded. # query string should be decoded.
cookie = urllib.unquote(request.url_parts.query) cookie = unquote(request.url_parts.query)
headers.append(("Set-Cookie", cookie)) headers.append((b"Set-Cookie", isomorphic_encode(cookie)))
return headers, '{"success": true}' return headers, b'{"success": true}'

View file

@ -1,5 +1,7 @@
from helpers import makeCookieHeader, setNoCacheAndCORSHeaders from helpers import makeCookieHeader, setNoCacheAndCORSHeaders
from wptserve.utils import isomorphic_encode
def main(request, response): def main(request, response):
"""Respond to `/cookie/set/samesite?{value}` by setting four cookies: """Respond to `/cookie/set/samesite?{value}` by setting four cookies:
1. `samesite_strict={value};SameSite=Strict;path=/` 1. `samesite_strict={value};SameSite=Strict;path=/`
@ -8,16 +10,16 @@ def main(request, response):
4. `samesite_unspecified={value};path=/` 4. `samesite_unspecified={value};path=/`
Then navigate to a page that will post a message back to the opener with the set cookies""" Then navigate to a page that will post a message back to the opener with the set cookies"""
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
value = request.url_parts.query value = isomorphic_encode(request.url_parts.query)
headers.append(("Content-Type", "text/html; charset=utf-8")) headers.append((b"Content-Type", b"text/html; charset=utf-8"))
headers.append(makeCookieHeader("samesite_strict", value, {"SameSite":"Strict","path":"/"})) headers.append(makeCookieHeader(b"samesite_strict", value, {b"SameSite":b"Strict", b"path":b"/"}))
headers.append(makeCookieHeader("samesite_lax", value, {"SameSite":"Lax","path":"/"})) headers.append(makeCookieHeader(b"samesite_lax", value, {b"SameSite":b"Lax", b"path":b"/"}))
# SameSite=None cookies must be Secure. # SameSite=None cookies must be Secure.
headers.append(makeCookieHeader("samesite_none", value, {"SameSite":"None", "path":"/", "Secure": ""})) headers.append(makeCookieHeader(b"samesite_none", value, {b"SameSite":b"None", b"path":b"/", b"Secure": b""}))
headers.append(makeCookieHeader("samesite_unspecified", value, {"path":"/"})) headers.append(makeCookieHeader(b"samesite_unspecified", value, {b"path":b"/"}))
document = """ document = b"""
<!DOCTYPE html> <!DOCTYPE html>
<script> <script>
// A same-site navigation, which should attach all cookies including SameSite ones. // A same-site navigation, which should attach all cookies including SameSite ones.

View file

@ -1,14 +1,16 @@
from helpers import makeCookieHeader, setNoCacheAndCORSHeaders from helpers import makeCookieHeader, setNoCacheAndCORSHeaders
from wptserve.utils import isomorphic_encode
def main(request, response): def main(request, response):
"""Respond to `/cookies/resources/setSameSiteNone.py?{value}` by setting two cookies: """Respond to `/cookies/resources/setSameSiteNone.py?{value}` by setting two cookies:
1. `samesite_none_insecure={value};SameSite=None;path=/` 1. `samesite_none_insecure={value};SameSite=None;path=/`
2. `samesite_none_secure={value};SameSite=None;Secure;path=/` 2. `samesite_none_secure={value};SameSite=None;Secure;path=/`
""" """
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
value = request.url_parts.query value = isomorphic_encode(request.url_parts.query)
headers.append(makeCookieHeader("samesite_none_insecure", value, {"SameSite":"None", "path":"/"})) headers.append(makeCookieHeader(b"samesite_none_insecure", value, {b"SameSite":b"None", b"path":b"/"}))
headers.append(makeCookieHeader("samesite_none_secure", value, {"SameSite":"None", "Secure":"", "path":"/"})) headers.append(makeCookieHeader(b"samesite_none_secure", value, {b"SameSite":b"None", b"Secure":b"", b"path":b"/"}))
return headers, '{"success": true}' return headers, b'{"success": true}'

View file

@ -1,12 +1,14 @@
from helpers import makeCookieHeader, readParameter, setNoCacheAndCORSHeaders from helpers import makeCookieHeader, readParameter, setNoCacheAndCORSHeaders
from wptserve.utils import isomorphic_encode
def main(request, response): def main(request, response):
"""Respond to `/cookie/set/secure?{value}` by setting two cookies: """Respond to `/cookie/set/secure?{value}` by setting two cookies:
alone_secure={value};secure;path=/` alone_secure={value};secure;path=/`
alone_insecure={value};path=/""" alone_insecure={value};path=/"""
headers = setNoCacheAndCORSHeaders(request, response) headers = setNoCacheAndCORSHeaders(request, response)
value = request.url_parts.query value = isomorphic_encode(request.url_parts.query)
headers.append(makeCookieHeader("alone_secure", value, {"secure": "","path": "/"})) headers.append(makeCookieHeader(b"alone_secure", value, {b"secure": b"", b"path": b"/"}))
headers.append(makeCookieHeader("alone_insecure", value, {"path": "/"})) headers.append(makeCookieHeader(b"alone_insecure", value, {b"path": b"/"}))
return headers, '{"success": true}' return headers, b'{"success": true}'

View file

@ -0,0 +1,31 @@
<!DOCTYPE html>
<meta charset="UTF-8">
<title>CSS Reference Test</title>
<link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/">
<style>
div#outer
{
background-image: linear-gradient(to top, blue, orange);
height: 140px;
margin: 10px;
width: 140px;
}
div#inner
{
background-color: white;
height: 80px;
left: 30px;
position: relative;
top: 30px;
width: 80px;
}
</style>
<p>Test passes if there is no red visible on the page.
<div id="outer"><div id="inner"></div></div>

View file

@ -0,0 +1,15 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#possible-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<meta name="assert" content="We should break between the two lines (class B breakpoint), rather than between the last line and the container padding">
<style>
.child { display:inline-block; vertical-align:top; width:100%; height:50px; line-height:50px; }
</style>
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:2; column-fill:auto; column-gap:0; width:100px; height:100px; orphans:1; widows:1; background:red;">
<div style="padding-bottom:50px; background:green;">
<div class="child"></div>
<div class="child"></div>
</div>
</div>

View file

@ -0,0 +1,16 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#possible-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<meta name="assert" content="We should break between the last two lines (class B breakpoint), rather than inside the container padding">
<style>
.child { display:inline-block; vertical-align:top; width:100%; height:30px; line-height:30px; }
</style>
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:2; column-fill:auto; column-gap:0; width:100px; height:100px; orphans:1; widows:1; background:red;">
<div style="padding-bottom:70px; background:green;">
<div class="child"></div>
<div class="child"></div>
<div class="child"></div>
</div>
</div>

View file

@ -0,0 +1,16 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#possible-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<meta name="assert" content="We should break between the first two lines (class B breakpoint, also honoring widows), rather than inside the container padding">
<style>
.child { display:inline-block; vertical-align:top; width:100%; height:30px; line-height:30px; }
</style>
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:2; column-fill:auto; column-gap:0; width:100px; height:100px; orphans:1; widows:2; background:red;">
<div style="padding-bottom:40px; background:green;">
<div class="child"></div>
<div class="child"></div>
<div class="child"></div>
</div>
</div>

View file

@ -0,0 +1,16 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#possible-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<meta name="assert" content="The block with padding should be pushed to the second column, so that we won't have to break between the line and the padding edge">
<style>
.child { display:inline-block; vertical-align:top; width:100%; height:90px; line-height:90px; }
</style>
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:2; column-fill:auto; column-gap:0; width:100px; height:100px; orphans:1; widows:1; background:red;">
<div style="float:left; width:100%; height:100px; background:green;"></div>
<div style="height:10px;"></div>
<div style="padding-bottom:10px; background:green;">
<div class="child"></div>
</div>
</div>

View file

@ -0,0 +1,19 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#possible-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<meta name="assert" content="The last line could fit in the third column, but will be pushed to the fourth, so that we won't have to break between the last line and the container padding">
<style>
.child { display:inline-block; vertical-align:top; width:100%; height:40px; line-height:40px; }
</style>
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:4; column-fill:auto; column-gap:0; width:100px; height:100px; orphans:1; widows:1; background:red;">
<div style="height:40px; background:green;"></div>
<div style="padding-bottom:60px; background:green;">
<div class="child"></div>
<div class="child"></div>
<div class="child"></div>
<div class="child"></div>
<div class="child"></div>
</div>
</div>

View file

@ -0,0 +1,18 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#unforced-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:3; column-fill:auto; column-gap:0; width:300px; height:50px;">
<div style="width:200px; height:0;">
<div style="height:20px; background:red;"></div>
</div>
<!-- No valid breakpoint here, since the preceding sibling takes up no space
(and its overflowing child ends up in a parallel flow). -->
<div style="height:120px;">
<!-- Can't break inside lines. Let it overflow the (shorter) fragmentainer,
but not its container. Consume 100px from it. -->
<div style="display:inline-block; vertical-align:top; width:100px; height:100px; background:green;"></div>
</div>
<div style="margin-top:-20px; height:20px; background:white;"></div>
</div>

View file

@ -0,0 +1,15 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#unforced-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:2; column-fill:auto; column-gap:0; width:100px; height:50px; background:red;">
<div>
<div style="display:inline-block; vertical-align:top; width:50px; height:100px; background:green;"></div>
</div>
<!-- We're at the very beginning of the second column here, so inserting a
forced break will have no effect. -->
<div style="break-before:column;">
<div style="display:inline-block; vertical-align:top; width:50px; height:100px; background:green;"></div>
</div>
</div>

View file

@ -0,0 +1,13 @@
<!DOCTYPE html>
<link rel="author" title="Morten Stenshorne" href="mailto:mstensho@chromium.org">
<link rel="help" href="https://www.w3.org/TR/css-break-3/#unforced-breaks">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<p>Test passes if there is a filled green square and <strong>no red</strong>.</p>
<div style="columns:2; column-fill:auto; column-gap:0; width:100px; height:50px; background:red;">
<div style="width:50px; height:100px; line-height:200px; background:green;">
<br>
</div>
<div style="break-before:column; width:50px; line-height:100px; background:green;">
<br>
</div>
</div>

View file

@ -0,0 +1,35 @@
<!DOCTYPE html>
<html>
<meta charset="utf-8">
<title>CSS Multi-column Layout Test Reference: Test fragmentation for a nested multi-column container with column-span in paginated context</title>
<link rel="author" title="Ting-Yu Lin" href="tlin@mozilla.com">
<link rel="author" title="Mozilla" href="https://www.mozilla.org/">
<style>
.inner {
column-count: 2;
column-rule: 3px solid green;
background-color: lightgreen;
}
.block1 {
background-color: yellow;
height: 3in;
}
.spanner {
height: 2in;
background-color: lightblue;
}
.block2 {
background-color: pink;
height: 3in;
}
</style>
<article class="inner">
<div class="block1">block1</div>
</article>
<div class="spanner">spanner</div>
<article class="inner">
<div class="block2">block2</div>
</article>
</html>

View file

@ -0,0 +1,43 @@
<!DOCTYPE html>
<html>
<meta charset="utf-8">
<title>CSS Multi-column Layout Test: Test fragmentation for a nested multi-column container with column-span in paginated context</title>
<link rel="match" href="column-balancing-paged-001-print-ref.html">
<link rel="author" title="Ting-Yu Lin" href="tlin@mozilla.com">
<link rel="author" title="Mozilla" href="http://www.mozilla.org/">
<link rel="help" href="https://drafts.csswg.org/css-multicol-1/#column-span">
<link rel="help" href="https://drafts.csswg.org/css-break/#breaking-rules">
<style>
.outer {
column-count: 1;
column-rule: 6px solid black;
}
.inner {
column-count: 2;
column-rule: 3px solid green;
background-color: lightgreen;
}
.block1 {
background-color: yellow;
height: 3in;
}
.spanner {
column-span: all;
height: 2in;
background-color: lightblue;
}
.block2 {
background-color: pink;
height: 3in
}
</style>
<article class="outer">
<article class="inner">
<div class="block1">block1</div>
<div class="spanner">spanner</div>
<div class="block2">block2</div>
</article>
</article>
</html>

View file

@ -0,0 +1,12 @@
<!DOCTYPE html>
<link rel="help" href="https://crbug.com/1098840">
<title>Verifies changing 'display' nested positions is not problematic</title>
<div style="position:absolute; display:table;">
<div style="position:fixed;"></div>
</div>
<span></span>
<div id="boom" style="display:none;"></div>
<script>
document.body.offsetTop;
boom.style.display = "block";
</script>

View file

@ -0,0 +1,36 @@
<!DOCTYPE html>
<meta charset="utf-8">
<title>CSS Reference: ::marker supports 'text-combine-upright'</title>
<style>
body {
writing-mode: vertical-lr;
}
ol, ul {
display: flow-root;
list-style-type: none;
}
.symbol {
list-style-type: disc;
}
ul {
list-style-position: inside;
}
ol span {
display: inline-block;
margin-top: -50px;
height: 50px;
text-align: end;
}
span {
text-combine-upright: all;
}
</style>
<ol><li><span>1. </span>outside decimal</li></ol>
<ol><li><span>2. </span>outside string</li></ol>
<ol><li><span>3. </span>outside content</li></ol>
<ol class="symbol"><li>outside symbol</li></ol>
<ul><li><span>1. </span>inside decimal</li></ul>
<ul><li><span>2. </span>inside string</li></ul>
<ul><li><span>3. </span>inside content</li></ul>
<ul class="symbol"><li>inside symbol</li></ul>

View file

@ -0,0 +1,43 @@
<!DOCTYPE html>
<meta charset="utf-8">
<title>CSS Test: ::marker supports 'text-combine-upright'</title>
<link rel="author" title="Oriol Brufau" href="mailto:obrufau@igalia.com">
<link rel="match" href="marker-text-combine-upright-ref.html">
<link rel="help" href="https://drafts.csswg.org/css-pseudo-4/#marker-pseudo">
<link rel="help" href="https://drafts.csswg.org/css-writing-modes-4/#propdef-text-combine-upright">
<meta name="assert" content="Checks that 'text-combine-upright' works well in ::marker, and doesn't crash.">
<style>
body {
writing-mode: vertical-lr;
}
ol, ul {
display: flow-root;
}
ul {
list-style-position: inside;
}
.decimal {
list-style-type: decimal;
}
.string {
list-style-type: "2. ";
}
.content ::marker {
content: "3. ";
}
.symbol {
list-style-type: disc;
}
::marker {
text-combine-upright: all;
}
</style>
<ol class="decimal"><li>outside decimal</li></ol>
<ol class="string"><li>outside string</li></ol>
<ol class="content"><li>outside content</li></ol>
<ol class="symbol"><li>outside symbol</li></ol>
<ul class="decimal"><li>inside decimal</li></ul>
<ul class="string"><li>inside string</li></ul>
<ul class="content"><li>inside content</li></ul>
<ul class="symbol"><li>inside symbol</li></ul>

View file

@ -6,7 +6,18 @@
<link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/"> <link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/">
<link rel="help" href="https://www.w3.org/TR/css-text-3/#hyphenation"> <link rel="help" href="https://www.w3.org/TR/css-text-3/#hyphenation">
<link rel="match" href="reference/hyphens-auto-010-ref.html"> <link rel="match" href="reference/hyphens-auto-010M-ref.html">
<link rel="match" href="reference/hyphens-auto-010H-ref.html">
<!--
User agents may use U+2010 HYPHEN <https://codepoints.net/U+2010>
when the font has the glyph, or
may use U+002D HYPHEN-MINUS <https://codepoints.net/U+002d>
otherwise. Some fonts will display slightly different glyphs for
these code points. Therefore these 2 reference files.
The M-ref.html reference file means the hyphen-Minus character U+002D.
The H-ref.html reference file means the Hyphen character U+2010.
-->
<meta content="" name="flags"> <meta content="" name="flags">
<meta content="When 'hyphens' is set to 'auto' and when 'lang' attribute is also set to a valid value, then words may be broken at hyphenation opportunities determined automatically by an hyphenation resource appropriate to the language of the text involved."> <meta content="When 'hyphens' is set to 'auto' and when 'lang' attribute is also set to a valid value, then words may be broken at hyphenation opportunities determined automatically by an hyphenation resource appropriate to the language of the text involved.">
@ -17,25 +28,11 @@
border: black solid 2px; border: black solid 2px;
font-family: monospace; font-family: monospace;
font-size: 32px; font-size: 32px;
margin-bottom: 0.25em;
width: 6ch;
}
div#test
{
hyphens: auto; hyphens: auto;
} width: 6ch;
div#reference
{
hyphens: none;
} }
</style> </style>
<body lang="en"> <body lang="en">
<p>Test passes if each black-bordered rectangles have identical inside content. <div>regulation implementation</div>
<div id="test">regulation implementation</div>
<div id="reference">regu-lation imple-menta-tion</div>

View file

@ -6,7 +6,7 @@
<link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/"> <link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/">
<link rel="help" href="https://www.w3.org/TR/css-text-3/#hyphenation"> <link rel="help" href="https://www.w3.org/TR/css-text-3/#hyphenation">
<link rel="match" href="reference/hyphens-auto-010-ref.html"> <link rel="match" href="reference/hyphens-auto-010M-ref.html">
<meta content="" name="flags"> <meta content="" name="flags">
<meta content="This test checks that 'hyphens: none' does not suppress line wrapping after encountering an actual hyphen-minus character (U+002D)."> <meta content="This test checks that 'hyphens: none' does not suppress line wrapping after encountering an actual hyphen-minus character (U+002D).">
@ -17,28 +17,18 @@
border: black solid 2px; border: black solid 2px;
font-family: monospace; font-family: monospace;
font-size: 32px; font-size: 32px;
margin-bottom: 0.25em;
width: 6ch;
}
div#test
{
hyphens: none; hyphens: none;
width: 6ch;
} }
</style> </style>
<body> <div>regu&#x002D;lation imple&#x002D;menta&#x002D;tion</div>
<p>Test passes if each black-bordered rectangles have identical inside content.
<div id="test">regu-lation imple-menta-tion</div>
<div id="reference">regu&#x002D;<br>lation<br>imple&#x002D;<br>menta&#x002D;<br>tion</div>
<!-- <!--
Expected result:
Hyphen-minus == &#x002D; == &#0045; regu-
lation
Hyphen == &#x2010; == &#8208; imple-
menta-
tion
--> -->

View file

@ -6,7 +6,7 @@
<link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/"> <link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/">
<link rel="help" href="https://www.w3.org/TR/css-text-3/#hyphenation"> <link rel="help" href="https://www.w3.org/TR/css-text-3/#hyphenation">
<link rel="match" href="reference/hyphens-auto-010-ref.html"> <link rel="match" href="reference/hyphens-auto-010H-ref.html">
<meta content="" name="flags"> <meta content="" name="flags">
<meta content="This test checks that 'hyphens: none' does not suppress line wrapping after encountering an actual hyphen character (U+2010)."> <meta content="This test checks that 'hyphens: none' does not suppress line wrapping after encountering an actual hyphen character (U+2010).">
@ -17,28 +17,18 @@
border: black solid 2px; border: black solid 2px;
font-family: monospace; font-family: monospace;
font-size: 32px; font-size: 32px;
margin-bottom: 0.25em;
width: 6ch;
}
div#test
{
hyphens: none; hyphens: none;
width: 6ch;
} }
</style> </style>
<body> <div>regu&#x2010;lation imple&#x2010;menta&#x2010;tion</div>
<p>Test passes if each black-bordered rectangles have identical inside content.
<div id="test">regu-lation imple-menta-tion</div>
<div id="reference">regu&#x2010;<br>lation<br>imple&#x2010;<br>menta&#x2010;<br>tion</div>
<!-- <!--
Expected result:
Hyphen-minus == &#x002D; == &#0045; regu-
lation
Hyphen == &#x2010; == &#8208; imple-
menta-
tion
--> -->

View file

@ -12,16 +12,18 @@
border: black solid 2px; border: black solid 2px;
font-family: monospace; font-family: monospace;
font-size: 32px; font-size: 32px;
hyphens: none;
margin-bottom: 0.25em;
width: 6ch; width: 6ch;
} }
</style> </style>
<body lang="en"> <body lang="en">
<p>Test passes if each black-bordered rectangles have identical inside content. <div>regu&#x2010;<br>lation<br>imple&#x2010;<br>menta&#x2010;<br>tion</div>
<div>regu-lation imple-menta-tion</div> <!--
<div>regu-lation imple-menta-tion</div> Hyphen-minus == &#x002D; == &#0045;
Hyphen == &#x2010; == &#8208;
-->

View file

@ -0,0 +1,29 @@
<!DOCTYPE html>
<meta charset="UTF-8">
<title>CSS Reference Test</title>
<link rel="author" title="Gérard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/">
<style>
div
{
border: black solid 2px;
font-family: monospace;
font-size: 32px;
width: 6ch;
}
</style>
<body lang="en">
<div>regu&#x002D;<br>lation<br>imple&#x002D;<br>menta&#x002D;<br>tion</div>
<!--
Hyphen-minus == &#x002D; == &#0045;
Hyphen == &#x2010; == &#8208;
-->

View file

@ -3,5 +3,5 @@ import time
def main(request, response): def main(request, response):
# Sleep for 500ms to delay onload. # Sleep for 500ms to delay onload.
time.sleep(0.5) time.sleep(0.5)
response.headers.set("Cache-Control", "no-cache, must-revalidate"); response.headers.set(b"Cache-Control", b"no-cache, must-revalidate");
response.headers.set("Location", "%3D"); response.headers.set(b"Location", b"%3D");

View file

@ -2,68 +2,70 @@ import time
from six.moves.urllib.parse import urlencode, urlparse from six.moves.urllib.parse import urlencode, urlparse
from wptserve.utils import isomorphic_decode, isomorphic_encode
def main(request, response): def main(request, response):
stashed_data = {'count': 0, 'preflight': "0"} stashed_data = {b'count': 0, b'preflight': b"0"}
status = 302 status = 302
headers = [("Content-Type", "text/plain"), headers = [(b"Content-Type", b"text/plain"),
("Cache-Control", "no-cache"), (b"Cache-Control", b"no-cache"),
("Pragma", "no-cache")] (b"Pragma", b"no-cache")]
if "Origin" in request.headers: if b"Origin" in request.headers:
headers.append(("Access-Control-Allow-Origin", request.headers.get("Origin", ""))) headers.append((b"Access-Control-Allow-Origin", request.headers.get(b"Origin", b"")))
headers.append(("Access-Control-Allow-Credentials", "true")) headers.append((b"Access-Control-Allow-Credentials", b"true"))
else: else:
headers.append(("Access-Control-Allow-Origin", "*")) headers.append((b"Access-Control-Allow-Origin", b"*"))
token = None token = None
if "token" in request.GET: if b"token" in request.GET:
token = request.GET.first("token") token = request.GET.first(b"token")
data = request.server.stash.take(token) data = request.server.stash.take(token)
if data: if data:
stashed_data = data stashed_data = data
if request.method == "OPTIONS": if request.method == u"OPTIONS":
if "allow_headers" in request.GET: if b"allow_headers" in request.GET:
headers.append(("Access-Control-Allow-Headers", request.GET['allow_headers'])) headers.append((b"Access-Control-Allow-Headers", request.GET[b'allow_headers']))
stashed_data['preflight'] = "1" stashed_data[b'preflight'] = b"1"
#Preflight is not redirected: return 200 #Preflight is not redirected: return 200
if not "redirect_preflight" in request.GET: if not b"redirect_preflight" in request.GET:
if token: if token:
request.server.stash.put(request.GET.first("token"), stashed_data) request.server.stash.put(request.GET.first(b"token"), stashed_data)
return 200, headers, "" return 200, headers, u""
if "redirect_status" in request.GET: if b"redirect_status" in request.GET:
status = int(request.GET['redirect_status']) status = int(request.GET[b'redirect_status'])
stashed_data['count'] += 1 stashed_data[b'count'] += 1
if "location" in request.GET: if b"location" in request.GET:
url = request.GET['location'] url = isomorphic_decode(request.GET[b'location'])
if "simple" not in request.GET: if b"simple" not in request.GET:
scheme = urlparse(url).scheme scheme = urlparse(url).scheme
if scheme == "" or scheme == "http" or scheme == "https": if scheme == u"" or scheme == u"http" or scheme == u"https":
url += "&" if '?' in url else "?" url += u"&" if u'?' in url else u"?"
#keep url parameters in location #keep url parameters in location
url_parameters = {} url_parameters = {}
for item in request.GET.items(): for item in request.GET.items():
url_parameters[item[0]] = item[1][0] url_parameters[isomorphic_decode(item[0])] = isomorphic_decode(item[1][0])
url += urlencode(url_parameters) url += urlencode(url_parameters)
#make sure location changes during redirection loop #make sure location changes during redirection loop
url += "&count=" + str(stashed_data['count']) url += u"&count=" + str(stashed_data[b'count'])
headers.append(("Location", url)) headers.append((b"Location", isomorphic_encode(url)))
if "redirect_referrerpolicy" in request.GET: if b"redirect_referrerpolicy" in request.GET:
headers.append(("Referrer-Policy", request.GET['redirect_referrerpolicy'])) headers.append((b"Referrer-Policy", request.GET[b'redirect_referrerpolicy']))
if "delay" in request.GET: if b"delay" in request.GET:
time.sleep(float(request.GET.first("delay", 0)) / 1E3) time.sleep(float(request.GET.first(b"delay", 0)) / 1E3)
if token: if token:
request.server.stash.put(request.GET.first("token"), stashed_data) request.server.stash.put(request.GET.first(b"token"), stashed_data)
if "max_count" in request.GET: if b"max_count" in request.GET:
max_count = int(request.GET['max_count']) max_count = int(request.GET[b'max_count'])
#stop redirecting and return count #stop redirecting and return count
if stashed_data['count'] > max_count: if stashed_data[b'count'] > max_count:
# -1 because the last is not a redirection # -1 because the last is not a redirection
return str(stashed_data['count'] - 1) return str(stashed_data[b'count'] - 1)
return status, headers, "" return status, headers, u""

View file

@ -0,0 +1,20 @@
<!DOCTYPE html>
<title>Element#requestFullscreen({ screen }) tentative support</title>
<!-- TODO: update link to W3C whenever specifications are ready -->
<link rel="help" href="https://github.com/webscreens/window-placement"/>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
promise_test(async t => {
// Grant window-placement permissions for testdriver.
await test_driver.set_permission({name: "window-placement"}, "granted");
let invoked = false;
let options = { get screen() { invoked = true; return undefined; } };
return document.body.requestFullscreen(options).then(
() => { assert_unreached("promise unexpectedly fulfilled"); },
() => { assert_true(invoked, "screen getter not invoked"); });
}, "fullscreenOptions.screen getter is invoked on requestFullscreen");
</script>

View file

@ -69,8 +69,8 @@ async function observeReports(global) {
}); });
observer.observe(); observer.observe();
// Wait 3000ms for reports to settle. // Wait 5000ms for reports to settle.
await new Promise(r => step_timeout(r, 3000)); await new Promise(r => step_timeout(r, 5000));
return reports; return reports;
} }

View file

@ -0,0 +1,20 @@
<!DOCTYPE html>
<!-- Any copyright is dedicated to the Public Domain.
- http://creativecommons.org/publicdomain/zero/1.0/ -->
<html>
<link rel="match" href="details-two-pages-print-ref.html">
<link rel="help" href="https://html.spec.whatwg.org/multipage/rendering.html#the-details-and-summary-elements">
<style>
summary {
/* Hide the triangle for comparing with div in reftest. */
list-style-type: none;
}
</style>
<body>
<details open>
<summary style="page-break-after: always;">Summary</summary>
<p>This is the details.</p>
</details>
</body>
</html>

View file

@ -0,0 +1,20 @@
<!DOCTYPE html>
<!-- Any copyright is dedicated to the Public Domain.
- http://creativecommons.org/publicdomain/zero/1.0/ -->
<html>
<link rel="match" href="details-two-pages-print-ref.html">
<link rel="help" href="https://html.spec.whatwg.org/multipage/rendering.html#the-details-and-summary-elements">
<style>
summary {
/* Hide the triangle for comparing with div in reftest. */
list-style-type: none;
}
</style>
<body>
<details open>
<summary>Summary<div style="page-break-before: always;"></div></summary>
<p>This is the details.</p>
</details>
</body>
</html>

View file

@ -0,0 +1,20 @@
<!DOCTYPE html>
<!-- Any copyright is dedicated to the Public Domain.
- http://creativecommons.org/publicdomain/zero/1.0/ -->
<html>
<link rel="match" href="details-two-pages-print-ref.html">
<link rel="help" href="https://html.spec.whatwg.org/multipage/rendering.html#the-details-and-summary-elements">
<style>
summary {
/* Hide the triangle for comparing with div in reftest. */
list-style-type: none;
}
</style>
<body>
<details open>
<summary>Summary</summary>
<p style="page-break-before: always;">This is the details.</p>
</details>
</body>
</html>

View file

@ -0,0 +1,20 @@
<!DOCTYPE html>
<!-- Any copyright is dedicated to the Public Domain.
- http://creativecommons.org/publicdomain/zero/1.0/ -->
<html>
<link rel="match" href="details-two-pages-print-ref.html">
<link rel="help" href="https://html.spec.whatwg.org/multipage/rendering.html#the-details-and-summary-elements">
<style>
summary {
/* Hide the triangle for comparing with div in reftest. */
list-style-type: none;
}
</style>
<body>
<details open>
<summary>Summary<div style="page-break-before: always;"></div></summary>
<p>This is the details.</p>
</details>
</body>
</html>

View file

@ -0,0 +1,12 @@
<!DOCTYPE html>
<!-- Any copyright is dedicated to the Public Domain.
- http://creativecommons.org/publicdomain/zero/1.0/ -->
<html>
<body>
<div>
<div style="page-break-after: always;">Summary</div>
<p>This is the details.</p>
</div>
</body>
</html>

View file

@ -0,0 +1,68 @@
<!doctype html>
<html>
<title>List of available images tuple-matching logic</title>
<link rel="author" title="Dom Farolino" href="mailto:dom@chromium.org">
<link rel="help" href="https://html.spec.whatwg.org/multipage/#the-list-of-available-images">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/service-workers/service-worker/resources/test-helpers.sub.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script>
const path = location.origin + '/html/semantics/embedded-content/the-img-element/';
const image_url = path + 'image-1.jpg';
function syncWait(ms) {
const start = Date.now();
while (Date.now() - start < ms);
}
let sawNoCorsRequest = false;
navigator.serviceWorker.onmessage = ({data}) => {
if (data.url === image_url && data.mode === 'no-cors') {
sawNoCorsRequest = true;
}
};
promise_test(t => {
return service_worker_unregister_and_register(t, 'resources/sw.js', path)
.then(r => {
return wait_for_state(t, r.installing, 'activated');
});
}, 'registering service worker');
promise_test(async t => {
const img = new Image();
function load_img_promise() {
return new Promise((resolve, reject) => {
img.onload = resolve;
img.onerror = e => { reject("The img should not fail to load") };
img.src = image_url;
// If there is not a matching image in the list of available images, the
// actual fetch operation is queued as a microtask, so we will see a
// request with mode 'cors' due to setting the crossorigin attribute
// below.
syncWait(500);
img.crossOrigin = 'anonymous';
});
};
await load_img_promise();
assert_false(sawNoCorsRequest, "The image is not fetched with mode: no-cors");
await new Promise(resolve => {
img.onload = img.onerror = resolve;
img.src = '';
img.crossOrigin = null;
});
await load_img_promise();
assert_false(sawNoCorsRequest, "The image is not fetched with mode: no-cors");
}, 'list of available images tuple-matching logic');
promise_test(t => {
return service_worker_unregister(t, path);
}, 'unregistering service worker');
</script>

View file

@ -0,0 +1,20 @@
addEventListener('install', (event) => {
skipWaiting();
});
addEventListener('activate', (event) => {
event.waitUntil(clients.claim());
});
async function broadcast(msg) {
const allClients = await clients.matchAll();
for (const client of allClients) {
client.postMessage(msg);
}
}
addEventListener('fetch', (event) => {
event.waitUntil(
broadcast({ url: event.request.url, mode: event.request.mode })
)
});

View file

@ -0,0 +1 @@
Service-Worker-Allowed: /html/semantics/embedded-content/the-img-element/

View file

@ -1,4 +1,4 @@
def main(request, response): def main(request, response):
headers = [("Content-Type", "text/javascript"), ("Cache-control", "public, max-age=100")] headers = [(b"Content-Type", b"text/javascript"), (b"Cache-control", b"public, max-age=100")]
body = "throw('fox');" body = u"throw('fox');"
return 200, headers, body return 200, headers, body

View file

@ -1,13 +1,13 @@
import time import time
def main(request, response): def main(request, response):
response.headers.append("Content-Type", "text/javascript") response.headers.append(b"Content-Type", b"text/javascript")
try: try:
script_id = int(request.GET.first("id")) script_id = int(request.GET.first(b"id"))
delay = int(request.GET.first("sec")) delay = int(request.GET.first(b"sec"))
except: except:
response.set_error(400, "Invalid parameter") response.set_error(400, u"Invalid parameter")
time.sleep(int(delay)) time.sleep(int(delay))
return "log('%s')" % script_id return u"log('%s')" % script_id

View file

@ -1,7 +1,7 @@
import time import time
def main(request, response): def main(request, response):
delay = float(request.GET.first("ms", 500)) delay = float(request.GET.first(b"ms", 500))
time.sleep(delay / 1E3); time.sleep(delay / 1E3)
return [("Content-type", "text/javascript")], "export let delayedLoaded = true;" return [(b"Content-type", b"text/javascript")], u"export let delayedLoaded = true;"

View file

@ -1,22 +1,25 @@
import random import random
import time import time
from wptserve.utils import isomorphic_decode
""" """
This script serves This script serves
""" """
def main(request, response): def main(request, response):
inlineOrExternal = request.GET.first("inlineOrExternal", "null") inlineOrExternal = request.GET.first(b"inlineOrExternal", b"null")
hasBlockingStylesheet = request.GET.first("hasBlockingStylesheet", "true") == "true" hasBlockingStylesheet = request.GET.first(b"hasBlockingStylesheet", b"true") == b"true"
result = request.GET.first("result", "success") result = request.GET.first(b"result", b"success")
type = "text/javascript" if request.GET.first("type", "classic") == "classic" else "module" type = u"text/javascript" if request.GET.first(b"type", b"classic") == b"classic" else u"module"
response.headers.set("Content-Type", "text/html; charset=utf-8") response.headers.set(b"Content-Type", b"text/html; charset=utf-8")
response.headers.set("Transfer-Encoding", "chunked") response.headers.set(b"Transfer-Encoding", b"chunked")
response.write_status_headers() response.write_status_headers()
# Step 1: Start parsing. # Step 1: Start parsing.
body = """<!DOCTYPE html> body = u"""<!DOCTYPE html>
<head> <head>
<script> <script>
parent.postMessage("fox", "*"); parent.postMessage("fox", "*");
@ -24,33 +27,33 @@ def main(request, response):
""" """
if hasBlockingStylesheet: if hasBlockingStylesheet:
body += """ body += u"""
<link rel="stylesheet" href="slow-flag-setter.py?result=css&cache=%f"> <link rel="stylesheet" href="slow-flag-setter.py?result=css&cache=%f">
""" % random.random() """ % random.random()
body += """ body += u"""
</head> </head>
<body> <body>
""" """
if inlineOrExternal == "inline" or inlineOrExternal == "external" or inlineOrExternal == "empty-src": if inlineOrExternal == b"inline" or inlineOrExternal == b"external" or inlineOrExternal == b"empty-src":
body += """ body += u"""
<streaming-element> <streaming-element>
""" """
# Trigger DOM processing # Trigger DOM processing
body += "A" * 100000 body += u"A" * 100000
response.writer.write("%x\r\n" % len(body)) response.writer.write(u"%x\r\n" % len(body))
response.writer.write(body) response.writer.write(body)
response.writer.write("\r\n") response.writer.write(u"\r\n")
response.writer.flush() response.writer.flush()
body = "" body = u""
if inlineOrExternal == "inline": if inlineOrExternal == b"inline":
time.sleep(1) time.sleep(1)
body += """ body += u"""
<script id="s1" type="%s" <script id="s1" type="%s"
onload="scriptOnLoad()" onload="scriptOnLoad()"
onerror="scriptOnError(event)"> onerror="scriptOnError(event)">
@ -59,26 +62,26 @@ def main(request, response):
} else { } else {
window.didExecute = "executed"; window.didExecute = "executed";
} }
""" % (type) """ % type
if result == "parse-error": if result == b"parse-error":
body += "1=2 parse error\n" body += u"1=2 parse error\n"
body += """ body += u"""
</script> </script>
</streaming-element> </streaming-element>
""" """
elif inlineOrExternal == "external": elif inlineOrExternal == b"external":
time.sleep(1) time.sleep(1)
body += """ body += u"""
<script id="s1" type="%s" <script id="s1" type="%s"
src="slow-flag-setter.py?result=%s&cache=%s" src="slow-flag-setter.py?result=%s&cache=%s"
onload="scriptOnLoad()" onload="scriptOnLoad()"
onerror="scriptOnError(event)"></script> onerror="scriptOnError(event)"></script>
</streaming-element> </streaming-element>
""" % (type, result, random.random()) """ % (type, isomorphic_decode(result), random.random())
elif inlineOrExternal == "empty-src": elif inlineOrExternal == b"empty-src":
time.sleep(1) time.sleep(1)
body += """ body += u"""
<script id="s1" type="%s" <script id="s1" type="%s"
src="" src=""
onload="scriptOnLoad()" onload="scriptOnLoad()"
@ -90,12 +93,12 @@ def main(request, response):
# // wasn't blocked by stylesheets as expected. # // wasn't blocked by stylesheets as expected.
# Trigger DOM processing # Trigger DOM processing
body += "B" * 100000 body += u"B" * 100000
response.writer.write("%x\r\n" % len(body)) response.writer.write(u"%x\r\n" % len(body))
response.writer.write(body) response.writer.write(body)
response.writer.write("\r\n") response.writer.write(u"\r\n")
response.writer.write("0\r\n") response.writer.write(u"0\r\n")
response.writer.write("\r\n") response.writer.write(u"\r\n")
response.writer.flush() response.writer.flush()

View file

@ -2,17 +2,17 @@
import time import time
def main(request, response): def main(request, response):
headers = [("Content-Type", "text/javascript")] headers = [(b"Content-Type", b"text/javascript")]
result = request.GET.first("result", "success") result = request.GET.first(b"result", b"success")
if result == "css": if result == b"css":
time.sleep(3) time.sleep(3)
headers = [("Content-Type", "text/css")] headers = [(b"Content-Type", b"text/css")]
body = "" body = u""
else: else:
time.sleep(2) time.sleep(2)
body = """ body = u"""
fetch('exec'); fetch('exec');
console.log('exec'); console.log('exec');
if (!window.readyToEvaluate) { if (!window.readyToEvaluate) {
@ -21,9 +21,9 @@ def main(request, response):
window.didExecute = "executed"; window.didExecute = "executed";
} }
""" """
if result == "parse-error": if result == b"parse-error":
body = "1=2 parse error;" body = u"1=2 parse error;"
if result == "fetch-error": if result == b"fetch-error":
return 404, [('Content-Type', 'text/plain')], """window.didExecute = "fetch error";""" return 404, [(b'Content-Type', b'text/plain')], u"""window.didExecute = "fetch error";"""
return headers, body return headers, body

View file

@ -1,20 +1,20 @@
def main(request, response): def main(request, response):
origin = request.headers.get("origin") origin = request.headers.get(b"origin")
if origin is not None: if origin is not None:
response.headers.set("Access-Control-Allow-Origin", origin) response.headers.set(b"Access-Control-Allow-Origin", origin)
response.headers.set("Access-Control-Allow-Methods", "GET") response.headers.set(b"Access-Control-Allow-Methods", b"GET")
response.headers.set("Access-Control-Allow-Credentials", "true") response.headers.set(b"Access-Control-Allow-Credentials", b"true")
if request.method == "OPTIONS": if request.method == u"OPTIONS":
return "" return u""
headers = [("Content-Type", "text/javascript")] headers = [(b"Content-Type", b"text/javascript")]
milk = request.cookies.first("milk", None) milk = request.cookies.first(b"milk", None)
if milk is None: if milk is None:
return headers, "var included = false;" return headers, u"var included = false;"
elif milk.value == "yes": elif milk.value == b"yes":
return headers, "var included = true;" return headers, u"var included = true;"
return headers, "var included = false;" return headers, u"var included = false;"

Some files were not shown because too many files have changed in this diff Show more