From ff2fcb22027c36f71122179189800392ac906d12 Mon Sep 17 00:00:00 2001 From: Sam Sneddon Date: Tue, 11 Apr 2023 14:49:44 +0100 Subject: [PATCH] Fix html5lib test serialization with #document-fragment: template When innerHTML is applied to a template, it uses the template's template contents as its context object, which means we need to serialize that and not the element itself. See also https://github.com/html5lib/html5lib-tests/pull/165 --- html/syntax/parsing/test.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/html/syntax/parsing/test.js b/html/syntax/parsing/test.js index 6dc6e19f3ec0a9..e725107b80d899 100644 --- a/html/syntax/parsing/test.js +++ b/html/syntax/parsing/test.js @@ -211,7 +211,12 @@ function test_fragment(iframe, t, test_id, uri_encoded_input, escaped_expected, container_elem = document.createElement(container); } container_elem.innerHTML = input_string; - var serialized_dom = test_serializer(container_elem); + var serialized_dom; + if (container_elem.namespaceURI === namespaces["html"] && container_elem.localName === "template") { + serialized_dom = test_serializer(container_elem.content); + } else { + serialized_dom = test_serializer(container_elem); + } current_tests[iframe.id].actual = serialized_dom; serialized_dom = convert_innerHTML(serialized_dom); assert_equals(serialized_dom, expected); @@ -220,6 +225,7 @@ function test_fragment(iframe, t, test_id, uri_encoded_input, escaped_expected, function convert_innerHTML(serialized_dom) { var lines = serialized_dom.split("\n"); + assert_not_equals(lines[0], "