• 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/noderemovechild12";
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       setImplementationAttribute("namespaceAware", true);
43
44      docsLoaded = 0;
45
46      var docRef = null;
47      if (typeof(this.doc) != 'undefined') {
48        docRef = this.doc;
49      }
50      docsLoaded += preload(docRef, "doc", "hc_staff");
51
52       if (docsLoaded == 1) {
53          setUpPageStatus = 'complete';
54       }
55    } catch(ex) {
56    	catchInitializationError(builder, ex);
57        setUpPageStatus = 'complete';
58    }
59}
60
61
62
63//
64//   This method is called on the completion of
65//      each asychronous load started in setUpTests.
66//
67//   When every synchronous loaded document has completed,
68//      the page status is changed which allows the
69//      body of the test to be executed.
70function loadComplete() {
71    if (++docsLoaded == 1) {
72        setUpPageStatus = 'complete';
73    }
74}
75
76
77/**
78*
79	The method removeChild removes the child node indicated by oldChild from the list
80	of children, and returns it.
81
82	Using removeChild on a new DocumentFragment node attempt to remove a new EntityReference node.
83        Also attempt to remove the document fragment node from the EntityReference.  Verify that a
84        NO_MODIFICATION_ALLOWED_ERR (EntityReference node is read-only) or a NOT_FOUND_ERR is thrown.
85
86* @author IBM
87* @author Neil Delima
88* @see http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core#ID-1734834066
89*/
90function noderemovechild12() {
91   var success;
92    if(checkInitialization(builder, "noderemovechild12") != null) return;
93    var doc;
94      var docFrag;
95      var eRef;
96      var removedERef;
97      var appendedChild;
98      var removedChild;
99
100      var docRef = null;
101      if (typeof(this.doc) != 'undefined') {
102        docRef = this.doc;
103      }
104      doc = load(docRef, "doc", "hc_staff");
105      docFrag = doc.createDocumentFragment();
106      eRef = doc.createEntityReference("ent1");
107      appendedChild = docFrag.appendChild(eRef);
108      removedChild = docFrag.removeChild(eRef);
109      removedERef = docFrag.firstChild;
110
111      assertNull("noderemovechild12",removedERef);
112
113      try {
114      removedChild = eRef.removeChild(docFrag);
115
116      } catch (ex) {
117		  if (typeof(ex.code) != 'undefined') {
118       switch(ex.code) {
119       case /* NOT_FOUND_ERR */ 8 :
120       break;
121      case /* NO_MODIFICATION_ALLOWED_ERR */ 7 :
122       break;
123          default:
124          throw ex;
125          }
126       } else {
127       throw ex;
128        }
129         }
130
131}
132
133
134
135
136function runTest() {
137   noderemovechild12();
138}
139