summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/trusted-types/HTMLElement-generic.tentative.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/trusted-types/HTMLElement-generic.tentative.html')
-rw-r--r--testing/web-platform/tests/trusted-types/HTMLElement-generic.tentative.html82
1 files changed, 82 insertions, 0 deletions
diff --git a/testing/web-platform/tests/trusted-types/HTMLElement-generic.tentative.html b/testing/web-platform/tests/trusted-types/HTMLElement-generic.tentative.html
new file mode 100644
index 0000000000..8e54fa9c57
--- /dev/null
+++ b/testing/web-platform/tests/trusted-types/HTMLElement-generic.tentative.html
@@ -0,0 +1,82 @@
+<!DOCTYPE html>
+<head>
+ <script src="/resources/testharness.js"></script>
+ <script src="/resources/testharnessreport.js"></script>
+ <script src="support/helper.sub.js"></script>
+</head>
+<body>
+<script>
+const policy = trustedTypes.createPolicy("testpolicy", {
+ createScript: s => s,
+ createHTML: s => s,
+ createScriptURL: s => s,
+});
+
+function getTrusted(element, attr) {
+ const type = trustedTypes.getPropertyType(element, attr);
+ if (type == "TrustedScript") {
+ return policy.createScript("2+2");
+ } else if (type == "TrustedScriptURL") {
+ return policy.createScript("https://example.test/");
+ } else if (type == "TrustedHTML") {
+ return policy.createHTML("<b>hello</b>");
+ } else {
+ return "a simple string";
+ }
+}
+
+// This test will run a simple, TT-relevant assignment, in a number of
+// circumstances. We've had issues where subtle difference in DOM behaviour -
+// for example a connected element or a non-connected element - produce
+// different results, and no test catching it because the tests were written
+// to do it one particular way. So this test does one thing, but in all the
+// different ways we can think of.
+//
+// - With TT disabled or enabled,
+// - with any of the trusted types,
+// - with a string or a TT value,
+// - with a element that's connected to the DOM (or not).
+//
+// Run the set of tests, assuming that is_tt_enabled reflects whether Trusted
+// Types is currently enabled (& enforced) or not.
+function runTests(is_tt_enabled) {
+ for (const [element, attr] of [
+ [ 'embed', 'src' ],
+ [ 'script', 'src' ],
+ [ 'div', 'innerHTML' ],
+ [ 'iframe', 'srcdoc' ],
+ [ 'script', 'text' ],
+ [ 'script', 'innerText' ],
+ [ 'script', 'textContent' ],
+ ]) {
+ const trusted = getTrusted(element, attr);
+ for (const value of [trusted, trusted.toString()]) {
+ for (const connected of [true, false]) {
+
+ const expect_exception = is_tt_enabled &&
+ value.constructor.name != trustedTypes.getPropertyType(element, attr);
+ test(t => {
+ const elem = document.createElement(element);
+ if (connected) document.body.appendChild(elem);
+ if (expect_exception) {
+ assert_throws_js(TypeError, _ => { elem[attr] = value; });
+ } else {
+ elem[attr] = value;
+ }
+ }, `${is_tt_enabled ? "TT enabled" : "TT disabled"}: ${element}.${attr} = ${value.constructor.name} on a ${connected ? "connected" : "non-connected"} element.`);
+ }
+ }
+ }
+}
+
+// Run the tests without TT first.
+runTests(false);
+
+// Now run the tests a second time, with TT enabled. To accomplish this, insert
+// a suitable <meta> element.
+const meta = document.createElement("meta");
+meta.setAttribute("http-equiv", "Content-Security-Policy");
+meta.setAttribute("content", "require-trusted-types-for 'script';");
+document.head.appendChild(meta);
+runTests(true);
+</script>