dom/tests/mochitest/dom-level1-core/test_elementreplaceexistingattribute.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_elementreplaceexistingattribute.html	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,137 @@
     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/elementreplaceexistingattribute</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 ['elementreplaceexistingattribute'];
    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 docRef = null;
    1.45 +      if (typeof(this.doc) != 'undefined') {
    1.46 +        docRef = this.doc;
    1.47 +      }
    1.48 +      docsLoaded += preload(docRef, "doc", "staff");
    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 = 'elementreplaceexistingattribute';
    1.76 +
    1.77 +
    1.78 +
    1.79 +window.doc = window;  
    1.80 +SimpleTest.waitForExplicitFinish();
    1.81 +addLoadEvent(setUpPage);
    1.82 +
    1.83 +
    1.84 +/**
    1.85 +* 
    1.86 +    The "setAttributeNode(newAttr)" method adds a new
    1.87 +   attribute to the Element.  If the "newAttr" Attr node is
    1.88 +   already present in this element, it should replace the
    1.89 +   existing one. 
    1.90 +   
    1.91 +   Retrieve the last child of the third employee and add a 
    1.92 +   new attribute node by invoking the "setAttributeNode(new 
    1.93 +   Attr)" method.  The new attribute node to be added is 
    1.94 +   "street", which is already present in this element.  The
    1.95 +   method should replace the existing Attr node with the 
    1.96 +   new one.  This test uses the "createAttribute(name)"
    1.97 +   method from the Document interface. 
    1.98 +
    1.99 +* @author NIST
   1.100 +* @author Mary Brady
   1.101 +*/
   1.102 +function elementreplaceexistingattribute() {
   1.103 +   var success;
   1.104 +    if(checkInitialization(builder, "elementreplaceexistingattribute") != null) return;
   1.105 +    var doc;
   1.106 +      var elementList;
   1.107 +      var testEmployee;
   1.108 +      var newAttribute;
   1.109 +      var name;
   1.110 +      var setAttr;
   1.111 +      
   1.112 +      var docRef = null;
   1.113 +      if (typeof(this.doc) != 'undefined') {
   1.114 +        docRef = this.doc;
   1.115 +      }
   1.116 +      doc = load(docRef, "doc", "staff");
   1.117 +      elementList = doc.getElementsByTagName("address");
   1.118 +      testEmployee = elementList.item(2);
   1.119 +      newAttribute = doc.createAttribute("street");
   1.120 +      setAttr = testEmployee.setAttributeNode(newAttribute);
   1.121 +      name = testEmployee.getAttribute("street");
   1.122 +      assertEquals("elementReplaceExistingAttributeAssert","",name);
   1.123 +       
   1.124 +}
   1.125 +
   1.126 +</script>
   1.127 +</head>
   1.128 +<body>
   1.129 +<h2>Test http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementreplaceexistingattribute</h2>
   1.130 +<p></p>
   1.131 +<p>
   1.132 +Copyright (c) 2001-2004 World Wide Web Consortium, 
   1.133 +(Massachusetts Institute of Technology, European Research Consortium 
   1.134 +for Informatics and Mathematics, Keio University). All 
   1.135 +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.136 +hope that it will be useful, but WITHOUT ANY WARRANTY; without even 
   1.137 +the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
   1.138 +</p>
   1.139 +</body>
   1.140 +</html>

mercurial