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_textsplittextthree"; 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 After the "splitText(offset)" method breaks the Text node 79 into two Text nodes, the new Text node contains all the 80 content at and after the offset point. 81 82 Retrieve the textual data from the second child of the 83 third employee and invoke the "splitText(offset)" method. 84 The new Text node should contain all the content 85 at and after the offset point. The "getNodeValue()" 86 method is called to check that the new node now contains 87 the characters at and after position seven. 88 (Starting count at 0) 89 90 * @author Curt Arnold 91 * @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-38853C1D 92 */ 93 function hc_textsplittextthree() { 94 var success; 95 if(checkInitialization(builder, "hc_textsplittextthree") != null) return; 96 var doc; 97 var elementList; 98 var nameNode; 99 var textNode; 100 var splitNode; 101 var value; 102 103 var docRef = null; 104 if (typeof(this.doc) != 'undefined') { 105 docRef = this.doc; 106 } 107 doc = load(docRef, "doc", "hc_staff"); 108 elementList = doc.getElementsByTagName("strong"); 109 nameNode = elementList.item(2); 110 textNode = nameNode.firstChild; 111 112 splitNode = textNode.splitText(6); 113 value = splitNode.nodeValue; 114 115 assertEquals("textSplitTextThreeAssert"," Jones",value); 116 117 } 118 119 120 121 122 function runTest() { 123 hc_textsplittextthree(); 124 } 125