• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1
2/*
3Copyright © 2001-2004 World Wide Web Consortium,
4(Massachusetts Institute of Technology, European Research Consortium
5for Informatics and Mathematics, Keio University). All
6Rights Reserved. This work is distributed under the W3C® Software License [1] in the
7hope that it will be useful, but WITHOUT ANY WARRANTY; without even
8the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
9
10[1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
11*/
12
13
14
15   /**
16    *  Gets URI that identifies the test.
17    *  @return uri identifier of test
18    */
19function getTargetURI() {
20      return "http://www.w3.org/2001/DOM-Test-Suite/level3/core/nodereplacechild40";
21   }
22
23var docsLoaded = -1000000;
24var builder = null;
25
26//
27//   This function is called by the testing framework before
28//      running the test suite.
29//
30//   If there are no configuration exceptions, asynchronous
31//        document loading is started.  Otherwise, the status
32//        is set to complete and the exception is immediately
33//        raised when entering the body of the test.
34//
35function setUpPage() {
36   setUpPageStatus = 'running';
37   try {
38     //
39     //   creates test document builder, may throw exception
40     //
41     builder = createConfiguredBuilder();
42
43      docsLoaded = 0;
44
45      var docRef = null;
46      if (typeof(this.doc) != 'undefined') {
47        docRef = this.doc;
48      }
49      docsLoaded += preload(docRef, "doc", "barfoo");
50
51       if (docsLoaded == 1) {
52          setUpPageStatus = 'complete';
53       }
54    } catch(ex) {
55    	catchInitializationError(builder, ex);
56        setUpPageStatus = 'complete';
57    }
58}
59
60
61
62//
63//   This method is called on the completion of
64//      each asychronous load started in setUpTests.
65//
66//   When every synchronous loaded document has completed,
67//      the page status is changed which allows the
68//      body of the test to be executed.
69function loadComplete() {
70    if (++docsLoaded == 1) {
71        setUpPageStatus = 'complete';
72    }
73}
74
75
76/**
77*
78Attempt to add a second document element by a comment.  The attempt should result
79in a HIERARCHY_REQUEST_ERR or NOT_SUPPORTED_ERR.
80
81* @author Curt Arnold
82* @see http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core#ID-785887307
83*/
84function nodereplacechild40() {
85   var success;
86    if(checkInitialization(builder, "nodereplacechild40") != null) return;
87    var doc;
88      var docElem;
89      var rootName;
90      var publicId = null;
91
92      var systemId = null;
93
94      var newComment;
95      var newDocType;
96      var domImpl;
97      var retNode;
98
99      var docRef = null;
100      if (typeof(this.doc) != 'undefined') {
101        docRef = this.doc;
102      }
103      doc = load(docRef, "doc", "barfoo");
104      docElem = doc.documentElement;
105
106      rootName = docElem.tagName;
107
108      domImpl = doc.implementation;
109newDocType = domImpl.createDocumentType(rootName,publicId,systemId);
110      newComment = doc.createComment("second element goes here");
111      retNode = doc.insertBefore(newComment,docElem);
112
113      try {
114      retNode = doc.replaceChild(newDocType,newComment);
115      fail("throw_HIERARCHY_REQUEST_OR_NOT_SUPPORTED");
116
117      } catch (ex) {
118		  if (typeof(ex.code) != 'undefined') {
119       switch(ex.code) {
120       case /* HIERARCHY_REQUEST_ERR */ 3 :
121       break;
122      case /* NOT_SUPPORTED_ERR */ 9 :
123       break;
124          default:
125          throw ex;
126          }
127       } else {
128       throw ex;
129        }
130         }
131
132}
133
134
135
136
137function runTest() {
138   nodereplacechild40();
139}
140