Home | History | Annotate | Download | only in core
      1 
      2 /*
      3 Copyright  2001-2004 World Wide Web Consortium, 
      4 (Massachusetts Institute of Technology, European Research Consortium 
      5 for Informatics and Mathematics, Keio University). All 
      6 Rights Reserved. This work is distributed under the W3C Software License [1] in the 
      7 hope that it will be useful, but WITHOUT ANY WARRANTY; without even 
      8 the 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     */
     19 function getTargetURI() {
     20       return "http://www.w3.org/2001/DOM-Test-Suite/level3/core/nodeappendchild01";
     21    }
     22 
     23 var docsLoaded = -1000000;
     24 var 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 //
     35 function 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.
     69 function loadComplete() {
     70     if (++docsLoaded == 1) {
     71         setUpPageStatus = 'complete';
     72     }
     73 }
     74 
     75 
     76 /**
     77 * 
     78 An attempt to add a second doctype node should result in a HIERARCHY_REQUEST_ERR
     79 or a NOT_SUPPORTED_ERR.
     80 
     81 * @author Curt Arnold
     82 * @see http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core#ID-184E7107
     83 */
     84 function nodeappendchild01() {
     85    var success;
     86     if(checkInitialization(builder, "nodeappendchild01") != null) return;
     87     var doc;
     88       var domImpl;
     89       var docType;
     90       var nullPubId = null;
     91 
     92       var nullSysId = null;
     93 
     94       var appendedChild;
     95       var tagName;
     96       var docElem;
     97       
     98       var docRef = null;
     99       if (typeof(this.doc) != 'undefined') {
    100         docRef = this.doc;
    101       }
    102       doc = load(docRef, "doc", "barfoo");
    103       docElem = doc.documentElement;
    104 
    105       tagName = docElem.tagName;
    106 
    107       domImpl = doc.implementation;
    108 docType = domImpl.createDocumentType(tagName,nullPubId,nullSysId);
    109       
    110       try {
    111       appendedChild = doc.appendChild(docType);
    112       fail("throw_HIERARCHY_REQUEST_OR_NOT_SUPPORTED");
    113      
    114       } catch (ex) {
    115 		  if (typeof(ex.code) != 'undefined') {      
    116        switch(ex.code) {
    117        case /* HIERARCHY_REQUEST_ERR */ 3 :
    118        break;
    119       case /* NOT_SUPPORTED_ERR */ 9 :
    120        break;
    121           default:
    122           throw ex;
    123           }
    124        } else { 
    125        throw ex;
    126         }
    127          }
    128         
    129 }
    130 
    131 
    132 
    133 
    134 function runTest() {
    135    nodeappendchild01();
    136 }
    137