<html xmlns="http://www.w3.org/1999/xhtml"> <!-- https://bugzilla.mozilla.org/show_bug.cgi?id=613662 --> <head> <title>Test for Bug 613662</title> <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/> </head> <body> <a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=613662">Mozilla Bug 613662</a> <p id="display"></p><div id="content" style="display: none"></div><div id="content2" style="display: none"></div><pre id="test"> <script type="application/javascript"><![CDATA[ SimpleTest.expectAssertions(1); /** Test for Bug 613662 **/ function testPositions(node) { node.insertAdjacentHTML("beforeBegin", "\u003Cscript>ok(false, 'script should not have run');\u003C/script><i></i>"); is(node.previousSibling.localName, "i", "Should have had <i> as previous sibling"); node.insertAdjacentHTML("Afterbegin", "<b></b>\u003Cscript>ok(false, 'script should not have run');\u003C/script>"); is(node.firstChild.localName, "b", "Should have had <b> as first child"); node.insertAdjacentHTML("BeforeEnd", "\u003Cscript>ok(false, 'script should not have run');\u003C/script><u></u>"); is(node.lastChild.localName, "u", "Should have had <u> as last child"); node.insertAdjacentHTML("afterend", "<a></a>\u003Cscript>ok(false, 'script should not have run');\u003C/script>"); is(node.nextSibling.localName, "a", "Should have had <a> as next sibling"); } var content = document.getElementById("content"); testPositions(content); // without next sibling testPositions(content); // test again when there's next sibling try { content.insertAdjacentHTML("bar", "foo"); ok(false, "insertAdjacentHTML should have thrown"); } catch (e) { is(e.name, "SyntaxError", "insertAdjacentHTML should throw SyntaxError"); is(e.code, 12, "insertAdjacentHTML should throw SYNTAX_ERR"); } var parent = document.createElementNS("http://www.w3.org/1999/xhtml", "div"); var child = document.createElementNS("http://www.w3.org/1999/xhtml", "div"); try { child.insertAdjacentHTML("Beforebegin", "foo"); ok(false, "insertAdjacentHTML should have thrown"); } catch (e) { is(e.name, "NoModificationAllowedError", "insertAdjacentHTML should throw NoModificationAllowedError"); is(e.code, 7, "insertAdjacentHTML should throw NO_MODIFICATION_ALLOWED_ERR"); } try { child.insertAdjacentHTML("AfterEnd", "foo"); ok(false, "insertAdjacentHTML should have thrown"); } catch (e) { is(e.name, "NoModificationAllowedError", "insertAdjacentHTML should throw NoModificationAllowedError"); is(e.code, 7, "insertAdjacentHTML should throw NO_MODIFICATION_ALLOWED_ERR"); } child.insertAdjacentHTML("afterBegin", "foo"); // mustn't throw child.insertAdjacentHTML("beforeend", "foo"); // mustn't throw parent.appendChild(child); testPositions(child); // node not in tree but has parent content.appendChild(parent); // must not run scripts try { document.documentElement.insertAdjacentHTML("afterend", "<div></div>"); ok(false, "insertAdjacentHTML should have thrown"); } catch (e) { is(e.name, "NoModificationAllowedError", "insertAdjacentHTML should throw NoModificationAllowedError"); is(e.code, 7, "insertAdjacentHTML should throw NO_MODIFICATION_ALLOWED_ERR"); } var content2 = document.getElementById("content2"); var events = [ [ "DOMNodeInserted", document.body ], [ "DOMNodeInserted", document.body ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", content2 ], [ "DOMNodeInserted", content2 ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", content2 ], [ "DOMNodeInserted", content2 ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", document.body ], [ "DOMNodeInserted", document.body ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", document.body ], [ "DOMNodeInserted", document.body ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", content2 ], [ "DOMNodeInserted", content2 ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", content2 ], [ "DOMNodeInserted", content2 ], [ "DOMSubtreeModified", null ], [ "DOMNodeInserted", document.body ], [ "DOMNodeInserted", document.body ], [ "DOMSubtreeModified", null ] ]; function mutationEventListener(evt) { var expected = events.shift(); is(evt.type, expected[0], "Unexpected mutation type"); is(evt.relatedNode, expected[1], "Unexpected related node"); } document.addEventListener("DOMSubtreeModified", mutationEventListener, false); document.addEventListener("DOMNodeInserted", mutationEventListener, false); document.addEventListener("DOMNodeRemoved", mutationEventListener, false); document.addEventListener("DOMNodeRemovedFromDocument", mutationEventListener, false); document.addEventListener("DOMNodeInsertedIntoDocument", mutationEventListener, false); document.addEventListener("DOMAttrModified", mutationEventListener, false); document.addEventListener("DOMCharacterDataModified", mutationEventListener, false); testPositions(content2); // without next sibling testPositions(content2); // test again when there's next sibling is(events.length, 0, "Not all expected events fired."); // XML-only: try { content.insertAdjacentHTML("beforeend", "<p>"); ok(false, "insertAdjacentHTML should have thrown"); } catch (e) { is(e.name, "SyntaxError", "insertAdjacentHTML should throw SyntaxError"); is(e.code, 12, "insertAdjacentHTML should throw SYNTAX_ERR"); } ]]></script> </pre> </body> </html>