gecko/dom/tests/mochitest/dom-level1-core/test_elementwrongdocumenterr.html

200 lines
5.8 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN""http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementwrongdocumenterr</title>
<link href="http://www.w3.org/StyleSheets/activity-home.css" rel="stylesheet" type="text/css">
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css">
<script type="text/javascript" src="/MochiKit/packed.js"></script><script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script><script type="text/javascript" src="DOMTestCase.js"></script><script type="text/javascript" src="exclusions.js"></script><script type="text/javascript">
// expose test function names
function exposeTestFunctionNames()
{
return ['elementwrongdocumenterr'];
}
var docsLoaded = -1000000;
var builder = null;
//
// This function is called by the testing framework before
// running the test suite.
//
// If there are no configuration exceptions, asynchronous
// document loading is started. Otherwise, the status
// is set to complete and the exception is immediately
// raised when entering the body of the test.
//
function setUpPage() {
setUpPageStatus = 'running';
try {
//
// creates test document builder, may throw exception
//
builder = createConfiguredBuilder();
docsLoaded = 0;
var doc1Ref = null;
if (typeof(this.doc1) != 'undefined') {
doc1Ref = this.doc1;
}
docsLoaded += preload(doc1Ref, "doc1", "staff");
var doc2Ref = null;
if (typeof(this.doc2) != 'undefined') {
doc2Ref = this.doc2;
}
docsLoaded += preload(doc2Ref, "doc2", "staff");
if (docsLoaded == 2) {
setUpPage = 'complete';
}
} catch(ex) {
catchInitializationError(builder, ex);
setUpPage = 'complete';
}
}
//
// This method is called on the completion of
// each asychronous load started in setUpTests.
//
// When every synchronous loaded document has completed,
// the page status is changed which allows the
// body of the test to be executed.
function loadComplete() {
if (++docsLoaded == 2) {
setUpPageStatus = 'complete';
runJSUnitTests();
markTodos();
SimpleTest.finish();
}
}
var docName = 'elementwrongdocumenterr';
window.doc = window;
SimpleTest.waitForExplicitFinish();
addLoadEvent(setUpPage);
function testFails (test) {
if (!test.result) {
test.todo = true;
return true;
}
return false;
}
function markTodos() {
if (todoTests[docName]) {
// mark the failures as todos
var failures = filter(testFails, SimpleTest._tests);
// shouldn't be 0 failures
todo(SimpleTest._tests != 0 && failures == 0, "test marked todo should fail somewhere");
}
}
function runJSUnitTests() {
builder = createConfiguredBuilder();
try {
forEach(exposeTestFunctionNames(),
function (testName) {
window[testName]();
}
);
} catch (ex) {
ok(false, "Test threw exception: " + ex);
}
}
/**
*
The "setAttributeNode(newAttr)" method raises an
"WRONG_DOCUMENT_ERR DOMException if the "newAttr"
was created from a different document than the one that
created this document.
Retrieve the last employee and attempt to set a new
attribute node for its "employee" element. The new
attribute was created from a document other than the
one that created this element, therefore a
WRONG_DOCUMENT_ERR DOMException should be raised.
This test uses the "createAttribute(newAttr)" method
from the Document interface.
* @author NIST
* @author Mary Brady
* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#xpointer(id('ID-258A00AF')/constant[@name='WRONG_DOCUMENT_ERR'])
* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-887236154
* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#xpointer(id('ID-887236154')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='WRONG_DOCUMENT_ERR'])
* @see http://www.w3.org/Bugs/Public/show_bug.cgi?id=249
*/
function elementwrongdocumenterr() {
var success;
if(checkInitialization(builder, "elementwrongdocumenterr") != null) return;
var doc1;
var doc2;
var newAttribute;
var addressElementList;
var testAddress;
var attrAddress;
var doc1Ref = null;
if (typeof(this.doc1) != 'undefined') {
doc1Ref = this.doc1;
}
doc1 = load(doc1Ref, "doc1", "staff");
var doc2Ref = null;
if (typeof(this.doc2) != 'undefined') {
doc2Ref = this.doc2;
}
doc2 = load(doc2Ref, "doc2", "staff");
newAttribute = doc2.createAttribute("newAttribute");
addressElementList = doc1.getElementsByTagName("address");
testAddress = addressElementList.item(4);
{
success = false;
try {
attrAddress = testAddress.setAttributeNode(newAttribute);
}
catch(ex) {
success = (typeof(ex.code) != 'undefined' && ex.code == 4);
}
assertTrue("throw_WRONG_DOCUMENT_ERR",success);
}
}
</script>
</head>
<body>
<h2>Test http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementwrongdocumenterr</h2>
<p></p>
<p>
Copyright (c) 2001-2004 World Wide Web Consortium,
(Massachusetts Institute of Technology, European Research Consortium
for Informatics and Mathematics, Keio University). All
Rights Reserved. This work is distributed under the <a href="http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231">W3C(r) Software License</a> in the
hope that it will be useful, but WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
</p>
</body>
</html>