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/level1/core/hc_namednodemapsetnameditemreturnvalue"; 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", "hc_staff"); 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 If the "setNamedItem(arg)" method replaces an already 79 existing node with the same name then the already 80 existing node is returned. 81 82 Retrieve the third employee and create a NamedNodeMap 83 object from the attributes of the last child by 84 invoking the "getAttributes()" method. Once the 85 list is created an invocation of the "setNamedItem(arg)" 86 method is done with arg=newAttr, where newAttr is a 87 new Attr Node previously created and whose node name 88 already exists in the map. The "setNamedItem(arg)" 89 method should replace the already existing node with 90 the new one and return the existing node. 91 This test uses the "createAttribute(name)" method from 92 the document interface. 93 94 * @author Curt Arnold 95 * @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-1025163788 96 * @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-349467F9 97 */ 98 function hc_namednodemapsetnameditemreturnvalue() { 99 var success; 100 if(checkInitialization(builder, "hc_namednodemapsetnameditemreturnvalue") != null) return; 101 var doc; 102 var elementList; 103 var newAttribute; 104 var testAddress; 105 var attributes; 106 var newNode; 107 var attrValue; 108 109 var docRef = null; 110 if (typeof(this.doc) != 'undefined') { 111 docRef = this.doc; 112 } 113 doc = load(docRef, "doc", "hc_staff"); 114 elementList = doc.getElementsByTagName("acronym"); 115 testAddress = elementList.item(2); 116 newAttribute = doc.createAttribute("class"); 117 attributes = testAddress.attributes; 118 119 newNode = attributes.setNamedItem(newAttribute); 120 assertNotNull("previousAttrNotNull",newNode); 121 attrValue = newNode.nodeValue; 122 123 assertEquals("previousAttrValue","No",attrValue); 124 125 } 126 127 128 129 130 function runTest() { 131 hc_namednodemapsetnameditemreturnvalue(); 132 } 133