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/level2/html/HTMLTableRowElement20"; 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", "tablerow"); 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 The insertCell() method inserts an empty TD cell into this row. 79 If index is -1 or equal to the number of cells, the new cell is 80 appended. 81 82 83 Retrieve the fourth TR element and examine the value of 84 the cells length attribute which should be set to six. 85 Check the value of the last TD element. Invoke the 86 insertCell() with an index of negative one 87 which will append the empty cell to the end of the list. 88 Check the value of the newly created cell and make sure it is null 89 and also the numbers of cells should now be seven. 90 91 * @author NIST 92 * @author Rick Rivello 93 * @see http://www.w3.org/TR/DOM-Level-2-HTML/html#ID-68927016 94 */ 95 function HTMLTableRowElement20() { 96 var success; 97 if(checkInitialization(builder, "HTMLTableRowElement20") != null) return; 98 var nodeList; 99 var cellsnodeList; 100 var testNode; 101 var trNode; 102 var cellNode; 103 var value; 104 var newCell; 105 var vcells; 106 var doc; 107 108 var docRef = null; 109 if (typeof(this.doc) != 'undefined') { 110 docRef = this.doc; 111 } 112 doc = load(docRef, "doc", "tablerow"); 113 nodeList = doc.getElementsByTagName("tr"); 114 assertSize("Asize",5,nodeList); 115 testNode = nodeList.item(3); 116 cellsnodeList = testNode.cells; 117 118 vcells = cellsnodeList.length; 119 120 assertEquals("cellsLink1",6,vcells); 121 trNode = cellsnodeList.item(5); 122 cellNode = trNode.firstChild; 123 124 value = cellNode.nodeValue; 125 126 assertEquals("value1Link","1230 North Ave. Dallas, Texas 98551",value); 127 newCell = testNode.insertCell(-1); 128 testNode = nodeList.item(3); 129 cellsnodeList = testNode.cells; 130 131 vcells = cellsnodeList.length; 132 133 assertEquals("cellsLink2",7,vcells); 134 trNode = cellsnodeList.item(6); 135 cellNode = trNode.firstChild; 136 137 assertNull("value2Link",cellNode); 138 139 } 140 141 142 143 144 function runTest() { 145 HTMLTableRowElement20(); 146 } 147