Files
tubestation/dom/base/test/test_anonymousContent_api.html
Emilio Cobos Álvarez c8d2c23403 Bug 1824886 - Rewrite AnonymousContent to use a shadow tree. r=smaug,TYLin,sfoster,devtools-reviewers,nchevobbe
Subtle things:

 * We now have shadow trees in NAC, inception! Only a couple lines of
   code in the style system had to be changed to match :host rules and
   so properly.

 * Had to make highlighters.css contentaccessible, because otherwise we
   can't load it from the shadow tree. I don't think it's a big deal.

 * I removed some of the code from highlighters.css that claimed that
   stuff inherited from the html element. That's just no longer true.

 * Had to switch from `setAttribute("style", ...)` to `.style = ...;`.
   This is needed because CSSOM from chrome code bypasses CSP (as
   AnonymousContent did), but setAttribute() doesn't, see bug 1424474.

Differential Revision: https://phabricator.services.mozilla.com/D173998
2023-07-09 11:34:05 +00:00

31 lines
1.3 KiB
HTML

<!DOCTYPE HTML>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=1020244
-->
<meta charset="utf-8">
<title>Test for Bug 1020244 - Test the chrome-only AnonymousContent API</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1020244">Mozilla Bug 1020244</a>
<script>
// Testing the presence of the chrome-only API
ok(!document.insertAnonymousContent,
"Content document shouldn't have access to insertAnonymousContent");
ok(!document.removeAnonymousContent,
"Content document shouldn't have access to removeAnonymousContent");
let chromeDocument = SpecialPowers.wrap(document);
ok(chromeDocument.insertAnonymousContent,
"Chrome document should have access to insertAnonymousContent");
ok(chromeDocument.removeAnonymousContent,
"Chrome document should have access to removeAnonymousContent");
// Testing the API of the returned object
let anonymousContent = chromeDocument.insertAnonymousContent();
ok(anonymousContent, "AnonymousContent object returned");
let div = document.createElement("div");
div.textContent = "this is a test element";
anonymousContent.root.appendChild(div);
chromeDocument.removeAnonymousContent(anonymousContent);
</script>