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/level1/core/hc_namednodemapsetnameditemthatexists"; 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 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. 69function loadComplete() { 70 if (++docsLoaded == 1) { 71 setUpPageStatus = 'complete'; 72 } 73} 74 75 76/** 77* 78 If the node to be added by the "setNamedItem(arg)" method 79 already exists in the NamedNodeMap, it is replaced by 80 the new one. 81 82 Retrieve the second 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. 91 This node is then retrieved using the "getNamedItem(name)" 92 method. This test uses the "createAttribute(name)" 93 method from the document interface 94 95* @author Curt Arnold 96* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-1025163788 97* @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-349467F9 98*/ 99function hc_namednodemapsetnameditemthatexists() { 100 var success; 101 if(checkInitialization(builder, "hc_namednodemapsetnameditemthatexists") != null) return; 102 var doc; 103 var elementList; 104 var newAttribute; 105 var testAddress; 106 var attributes; 107 var districtNode; 108 var attrValue; 109 var setNode; 110 111 var docRef = null; 112 if (typeof(this.doc) != 'undefined') { 113 docRef = this.doc; 114 } 115 doc = load(docRef, "doc", "hc_staff"); 116 elementList = doc.getElementsByTagName("acronym"); 117 testAddress = elementList.item(1); 118 newAttribute = doc.createAttribute("class"); 119 attributes = testAddress.attributes; 120 121 setNode = attributes.setNamedItem(newAttribute); 122 districtNode = attributes.getNamedItem("class"); 123 attrValue = districtNode.nodeValue; 124 125 assertEquals("namednodemapSetNamedItemThatExistsAssert","",attrValue); 126 127} 128 129 130 131 132function runTest() { 133 hc_namednodemapsetnameditemthatexists(); 134} 135