зеркало из https://github.com/mozilla/pjs.git
200 строки
5.8 KiB
HTML
200 строки
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>
|