dom/tests/mochitest/dom-level2-core/test_nodehasattributes04.html

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/dom/tests/mochitest/dom-level2-core/test_nodehasattributes04.html	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,138 @@
     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/level2/core/nodehasattributes04</title>
    1.10 +<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css">
    1.11 +<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
    1.12 +<script type="text/javascript" src="DOMTestCase.js"></script>
    1.13 +<script type="text/javascript" src="exclusions.js"></script>
    1.14 +<script type="text/javascript">
    1.15 +// expose test function names
    1.16 +function exposeTestFunctionNames()
    1.17 +{
    1.18 +return ['nodehasattributes04'];
    1.19 +}
    1.20 +
    1.21 +var docsLoaded = -1000000;
    1.22 +var builder = null;
    1.23 +
    1.24 +//
    1.25 +//   This function is called by the testing framework before
    1.26 +//      running the test suite.
    1.27 +//
    1.28 +//   If there are no configuration exceptions, asynchronous
    1.29 +//        document loading is started.  Otherwise, the status
    1.30 +//        is set to complete and the exception is immediately
    1.31 +//        raised when entering the body of the test.
    1.32 +//
    1.33 +function setUpPage() {
    1.34 +   setUpPageStatus = 'running';
    1.35 +   try {
    1.36 +     //
    1.37 +     //   creates test document builder, may throw exception
    1.38 +     //
    1.39 +     builder = createConfiguredBuilder();
    1.40 +       setImplementationAttribute("namespaceAware", true);
    1.41 +
    1.42 +      docsLoaded = 0;
    1.43 +      
    1.44 +      var docRef = null;
    1.45 +      if (typeof(this.doc) != 'undefined') {
    1.46 +        docRef = this.doc;
    1.47 +      }
    1.48 +      docsLoaded += preload(docRef, "doc", "staffNS");
    1.49 +        
    1.50 +       if (docsLoaded == 1) {
    1.51 +          setUpPage = 'complete';
    1.52 +       }
    1.53 +    } catch(ex) {
    1.54 +    	catchInitializationError(builder, ex);
    1.55 +        setUpPage = 'complete';
    1.56 +    }
    1.57 +}
    1.58 +
    1.59 +//
    1.60 +//   This method is called on the completion of 
    1.61 +//      each asychronous load started in setUpTests.
    1.62 +//
    1.63 +//   When every synchronous loaded document has completed,
    1.64 +//      the page status is changed which allows the
    1.65 +//      body of the test to be executed.
    1.66 +function loadComplete() {
    1.67 +  if (++docsLoaded == 1) {
    1.68 +    setUpPageStatus = 'complete';
    1.69 +    runJSUnitTests();
    1.70 +    markTodos();
    1.71 +    SimpleTest.finish();
    1.72 +  }
    1.73 +}
    1.74 +
    1.75 +var docName = 'nodehasattributes04';
    1.76 +
    1.77 +
    1.78 +/**
    1.79 +* 
    1.80 +	The method hasAttributes returns whether this node (if it is an element) has any attributes.
    1.81 +
    1.82 +	Create a new Document, Element and Attr node.  Add the Attr to the Element and append the 
    1.83 +	Element to the Document.  Retreive the newly created element node from the document and check
    1.84 +	if it has attributes using hasAttributes.
    1.85 +
    1.86 +* @author IBM
    1.87 +* @author Neil Delima
    1.88 +* @see http://www.w3.org/TR/DOM-Level-2-Core/core#ID-NodeHasAttrs
    1.89 +*/
    1.90 +function nodehasattributes04() {
    1.91 +   var success;
    1.92 +    if(checkInitialization(builder, "nodehasattributes04") != null) return;
    1.93 +    var doc;
    1.94 +      var newDoc;
    1.95 +      var docType = null;
    1.96 +
    1.97 +      var domImpl;
    1.98 +      var element;
    1.99 +      var elementTest;
   1.100 +      var elementDoc;
   1.101 +      var attribute;
   1.102 +      var setNode;
   1.103 +      var appendedChild;
   1.104 +      var elementList;
   1.105 +      var hasAttributes;
   1.106 +      
   1.107 +      var docRef = null;
   1.108 +      if (typeof(this.doc) != 'undefined') {
   1.109 +        docRef = this.doc;
   1.110 +      }
   1.111 +      doc = load(docRef, "doc", "staffNS");
   1.112 +      domImpl = doc.implementation;
   1.113 +newDoc = domImpl.createDocument("http://www.w3.org/DOM/Test","test",docType);
   1.114 +      element = newDoc.createElementNS("http://www.w3.org/DOM/Test","dom:elem");
   1.115 +      attribute = newDoc.createAttribute("attr");
   1.116 +      setNode = element.setAttributeNode(attribute);
   1.117 +      elementDoc = newDoc.documentElement;
   1.118 +
   1.119 +      appendedChild = elementDoc.appendChild(element);
   1.120 +      elementList = newDoc.getElementsByTagNameNS("http://www.w3.org/DOM/Test","elem");
   1.121 +      elementTest = elementList.item(0);
   1.122 +      hasAttributes = elementTest.hasAttributes();
   1.123 +      assertTrue("nodehasattributes04",hasAttributes);
   1.124 +
   1.125 +}
   1.126 +
   1.127 +</script>
   1.128 +</head>
   1.129 +<body>
   1.130 +<h2>Test http://www.w3.org/2001/DOM-Test-Suite/level2/core/nodehasattributes04</h2>
   1.131 +<p></p>
   1.132 +<p>
   1.133 +Copyright (c) 2001-2004 World Wide Web Consortium, 
   1.134 +(Massachusetts Institute of Technology, European Research Consortium 
   1.135 +for Informatics and Mathematics, Keio University). All 
   1.136 +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.137 +hope that it will be useful, but WITHOUT ANY WARRANTY; without even 
   1.138 +the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
   1.139 +</p>
   1.140 +</body>
   1.141 +</html>

mercurial