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

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/dom/tests/mochitest/dom-level1-core/test_elementwrongdocumenterr.html	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,174 @@
     1.4 +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN""http://www.w3.org/TR/html4/strict.dtd">
     1.5 +<html>
     1.6 +<head>
     1.7 +<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
     1.8 +<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
     1.9 +<title>http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementwrongdocumenterr</title>
    1.10 +<link href="activity-home.css" rel="stylesheet" type="text/css">
    1.11 +<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css">
    1.12 +<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
    1.13 +<script type="text/javascript" src="DOMTestCase.js"></script>
    1.14 +<script type="text/javascript" src="exclusions.js"></script>
    1.15 +<script type="text/javascript">
    1.16 +// expose test function names
    1.17 +function exposeTestFunctionNames()
    1.18 +{
    1.19 +return ['elementwrongdocumenterr'];
    1.20 +}
    1.21 +
    1.22 +var docsLoaded = -1000000;
    1.23 +var builder = null;
    1.24 +
    1.25 +//
    1.26 +//   This function is called by the testing framework before
    1.27 +//      running the test suite.
    1.28 +//
    1.29 +//   If there are no configuration exceptions, asynchronous
    1.30 +//        document loading is started.  Otherwise, the status
    1.31 +//        is set to complete and the exception is immediately
    1.32 +//        raised when entering the body of the test.
    1.33 +//
    1.34 +function setUpPage() {
    1.35 +   setUpPageStatus = 'running';
    1.36 +   try {
    1.37 +     //
    1.38 +     //   creates test document builder, may throw exception
    1.39 +     //
    1.40 +     builder = createConfiguredBuilder();
    1.41 +
    1.42 +      docsLoaded = 0;
    1.43 +      
    1.44 +      var doc1Ref = null;
    1.45 +      if (typeof(this.doc1) != 'undefined') {
    1.46 +        doc1Ref = this.doc1;
    1.47 +      }
    1.48 +      docsLoaded += preload(doc1Ref, "doc1", "staff");
    1.49 +        
    1.50 +      var doc2Ref = null;
    1.51 +      if (typeof(this.doc2) != 'undefined') {
    1.52 +        doc2Ref = this.doc2;
    1.53 +      }
    1.54 +      docsLoaded += preload(doc2Ref, "doc2", "staff");
    1.55 +        
    1.56 +       if (docsLoaded == 2) {
    1.57 +          setUpPage = 'complete';
    1.58 +       }
    1.59 +    } catch(ex) {
    1.60 +    	catchInitializationError(builder, ex);
    1.61 +        setUpPage = 'complete';
    1.62 +    }
    1.63 +}
    1.64 +
    1.65 +//
    1.66 +//   This method is called on the completion of 
    1.67 +//      each asychronous load started in setUpTests.
    1.68 +//
    1.69 +//   When every synchronous loaded document has completed,
    1.70 +//      the page status is changed which allows the
    1.71 +//      body of the test to be executed.
    1.72 +function loadComplete() {
    1.73 +  if (++docsLoaded == 2) {
    1.74 +    setUpPageStatus = 'complete';
    1.75 +    runJSUnitTests();
    1.76 +    markTodos();
    1.77 +    SimpleTest.finish();
    1.78 +  }
    1.79 +}
    1.80 +
    1.81 +var docName = 'elementwrongdocumenterr';
    1.82 +
    1.83 +
    1.84 +
    1.85 +window.doc = window;  
    1.86 +SimpleTest.waitForExplicitFinish();
    1.87 +addLoadEvent(setUpPage);
    1.88 +
    1.89 +
    1.90 +/**
    1.91 +* 
    1.92 +
    1.93 +    The "setAttributeNode(newAttr)" method raises an 
    1.94 +
    1.95 +   "WRONG_DOCUMENT_ERR DOMException if the "newAttr" 
    1.96 +
    1.97 +   was created from a different document than the one that
    1.98 +
    1.99 +   created this document.
   1.100 +
   1.101 +   
   1.102 +
   1.103 +   Retrieve the last employee and attempt to set a new
   1.104 +
   1.105 +   attribute node for its "employee" element.  The new
   1.106 +
   1.107 +   attribute was created from a document other than the
   1.108 +
   1.109 +   one that created this element, therefore a
   1.110 +
   1.111 +   WRONG_DOCUMENT_ERR DOMException should be raised.
   1.112 +
   1.113 +   This test uses the "createAttribute(newAttr)" method
   1.114 +
   1.115 +   from the Document interface.
   1.116 +
   1.117 +
   1.118 +* @author NIST
   1.119 +* @author Mary Brady
   1.120 +* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#xpointer(id('ID-258A00AF')/constant[@name='WRONG_DOCUMENT_ERR'])
   1.121 +* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-887236154
   1.122 +* @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'])
   1.123 +* @see http://www.w3.org/Bugs/Public/show_bug.cgi?id=249
   1.124 +*/
   1.125 +function elementwrongdocumenterr() {
   1.126 +   var success;
   1.127 +    if(checkInitialization(builder, "elementwrongdocumenterr") != null) return;
   1.128 +    var doc1;
   1.129 +      var doc2;
   1.130 +      var newAttribute;
   1.131 +      var addressElementList;
   1.132 +      var testAddress;
   1.133 +      var attrAddress;
   1.134 +      
   1.135 +      var doc1Ref = null;
   1.136 +      if (typeof(this.doc1) != 'undefined') {
   1.137 +        doc1Ref = this.doc1;
   1.138 +      }
   1.139 +      doc1 = load(doc1Ref, "doc1", "staff");
   1.140 +      
   1.141 +      var doc2Ref = null;
   1.142 +      if (typeof(this.doc2) != 'undefined') {
   1.143 +        doc2Ref = this.doc2;
   1.144 +      }
   1.145 +      doc2 = load(doc2Ref, "doc2", "staff");
   1.146 +      newAttribute = doc2.createAttribute("newAttribute");
   1.147 +      addressElementList = doc1.getElementsByTagName("address");
   1.148 +      testAddress = addressElementList.item(4);
   1.149 +      
   1.150 +	{
   1.151 +		success = false;
   1.152 +		try {
   1.153 +            attrAddress = testAddress.setAttributeNode(newAttribute);
   1.154 +        }
   1.155 +		catch(ex) {
   1.156 +      success = (typeof(ex.code) != 'undefined' && ex.code == 4);
   1.157 +		}
   1.158 +		assertTrue("throw_WRONG_DOCUMENT_ERR",success);
   1.159 +	}
   1.160 +
   1.161 +}
   1.162 +
   1.163 +</script>
   1.164 +</head>
   1.165 +<body>
   1.166 +<h2>Test http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementwrongdocumenterr</h2>
   1.167 +<p></p>
   1.168 +<p>
   1.169 +Copyright (c) 2001-2004 World Wide Web Consortium, 
   1.170 +(Massachusetts Institute of Technology, European Research Consortium 
   1.171 +for Informatics and Mathematics, Keio University). All 
   1.172 +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 
   1.173 +hope that it will be useful, but WITHOUT ANY WARRANTY; without even 
   1.174 +the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
   1.175 +</p>
   1.176 +</body>
   1.177 +</html>

mercurial