| OLD | NEW |
| 1 | |
| 2 /* | 1 /* |
| 3 Copyright © 2001-2004 World Wide Web Consortium, | 2 Copyright © 2001-2004 World Wide Web Consortium, |
| 4 (Massachusetts Institute of Technology, European Research Consortium | 3 (Massachusetts Institute of Technology, European Research Consortium |
| 5 for Informatics and Mathematics, Keio University). All | 4 for Informatics and Mathematics, Keio University). All |
| 6 Rights Reserved. This work is distributed under the W3C® Software License [1] i
n the | 5 Rights Reserved. This work is distributed under the W3C® Software License [1] i
n the |
| 7 hope that it will be useful, but WITHOUT ANY WARRANTY; without even | 6 hope that it will be useful, but WITHOUT ANY WARRANTY; without even |
| 8 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | 7 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
| 9 | 8 |
| 10 [1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231 | 9 [1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231 |
| 11 */ | 10 */ |
| 12 | 11 |
| 13 | |
| 14 | |
| 15 /** | 12 /** |
| 16 * Gets URI that identifies the test. | 13 * Gets URI that identifies the test. |
| 17 * @return uri identifier of test | 14 * @return uri identifier of test |
| 18 */ | 15 */ |
| 19 function getTargetURI() { | 16 function getTargetURI() { |
| 20 return "http://www.w3.org/2001/DOM-Test-Suite/level2/events/dispatchEvent1
2"; | 17 return "http://www.w3.org/2001/DOM-Test-Suite/level2/events/dispatchEvent1
2"; |
| 21 } | 18 } |
| 22 | 19 |
| 23 var docsLoaded = -1000000; | 20 var docsLoaded = -1000000; |
| 24 var builder = null; | 21 var builder = null; |
| 25 | 22 |
| 26 // | 23 // |
| 27 // This function is called by the testing framework before | 24 // This function is called by the testing framework before |
| 28 // running the test suite. | 25 // running the test suite. |
| 29 // | 26 // |
| 30 // If there are no configuration exceptions, asynchronous | 27 // If there are no configuration exceptions, asynchronous |
| 31 // document loading is started. Otherwise, the status | 28 // document loading is started. Otherwise, the status |
| 32 // is set to complete and the exception is immediately | 29 // is set to complete and the exception is immediately |
| 33 // raised when entering the body of the test. | 30 // raised when entering the body of the test. |
| 34 // | 31 // |
| 35 function setUpPage() { | 32 function setUpPage() { |
| 36 setUpPageStatus = 'running'; | 33 setUpPageStatus = 'running'; |
| 37 try { | 34 try { |
| 38 // | 35 // |
| 39 // creates test document builder, may throw exception | 36 // creates test document builder, may throw exception |
| 40 // | 37 // |
| 41 builder = createConfiguredBuilder(); | 38 builder = createConfiguredBuilder(); |
| 42 | 39 |
| 43 docsLoaded = 0; | 40 docsLoaded = 0; |
| 44 | 41 |
| 45 var docRef = null; | 42 var docRef = null; |
| 46 if (typeof(this.doc) != 'undefined') { | 43 if (typeof(this.doc) != 'undefined') { |
| 47 docRef = this.doc; | 44 docRef = this.doc; |
| 48 } | 45 } |
| 49 docsLoaded += preload(docRef, "doc", "hc_staff"); | 46 docsLoaded += preload(docRef, "doc", "hc_staff"); |
| 50 | 47 |
| 51 if (docsLoaded == 1) { | 48 if (docsLoaded == 1) { |
| 52 setUpPageStatus = 'complete'; | 49 setUpPageStatus = 'complete'; |
| 53 } | 50 } |
| 54 } catch(ex) { | 51 } catch(ex) { |
| 55 » catchInitializationError(builder, ex); | 52 catchInitializationError(builder, ex); |
| 56 setUpPageStatus = 'complete'; | 53 setUpPageStatus = 'complete'; |
| 57 } | 54 } |
| 58 } | 55 } |
| 59 | 56 |
| 60 | |
| 61 | |
| 62 // | 57 // |
| 63 // This method is called on the completion of | 58 // This method is called on the completion of |
| 64 // each asychronous load started in setUpTests. | 59 // each asychronous load started in setUpTests. |
| 65 // | 60 // |
| 66 // When every synchronous loaded document has completed, | 61 // When every synchronous loaded document has completed, |
| 67 // the page status is changed which allows the | 62 // the page status is changed which allows the |
| 68 // body of the test to be executed. | 63 // body of the test to be executed. |
| 69 function loadComplete() { | 64 function loadComplete() { |
| 70 if (++docsLoaded == 1) { | 65 if (++docsLoaded == 1) { |
| 71 setUpPageStatus = 'complete'; | 66 setUpPageStatus = 'complete'; |
| 72 } | 67 } |
| 73 } | 68 } |
| 74 | 69 |
| 75 //EventMonitor's require a document level variable named monitor | 70 //EventMonitor's require a document level variable named monitor |
| 76 var monitor; | 71 var monitor; |
| 77 » | 72 |
| 78 /** | 73 /** |
| 79 * Inner class implementation for variable other | 74 * Inner class implementation for variable other |
| 80 */ | 75 */ |
| 81 var other; | 76 var other; |
| 82 | 77 |
| 83 /** | 78 /** |
| 84 * Constructor | 79 * Constructor |
| 85 | 80 |
| 86 */ | 81 */ |
| 87 » | 82 |
| 88 function EventListenerN10035() { | 83 function EventListenerN10035() { |
| 89 } | 84 } |
| 90 | 85 |
| 91 /** | 86 /** |
| 92 * | 87 * |
| 93 This method is called whenever an event occurs of the type for which theEventLis
tenerinterface was registered. | 88 This method is called whenever an event occurs of the type for which theEventLis
tenerinterface was registered. |
| 94 | 89 |
| 95 * @param evt | 90 * @param evt |
| 96 TheEventcontains contextual information about the event. It also contains thesto
pPropagationand preventDefaultmethods which are used in determining the event's
flow and default action. | 91 TheEventcontains contextual information about the event. It also contains thesto
pPropagationand preventDefaultmethods which are used in determining the event's
flow and default action. |
| 97 | 92 |
| 98 */ | 93 */ |
| 99 EventListenerN10035.prototype.handleEvent = function(evt) { | 94 EventListenerN10035.prototype.handleEvent = function(evt) { |
| 100 // | 95 // |
| 101 // bring class variables into function scope | 96 // bring class variables into function scope |
| 102 // | 97 // |
| 103 } | 98 } |
| 104 | 99 |
| 105 /** | 100 /** |
| 106 * | 101 * |
| 107 A monitor is added, multiple calls to removeEventListener | 102 A monitor is added, multiple calls to removeEventListener |
| 108 are mde with similar but not identical arguments, and an event is dispatched. | 103 are mde with similar but not identical arguments, and an event is dispatched. |
| 109 The monitor should recieve handleEvent calls. | 104 The monitor should recieve handleEvent calls. |
| 110 | 105 |
| 111 * @author Curt Arnold | 106 * @author Curt Arnold |
| 112 * @see http://www.w3.org/TR/DOM-Level-2-Events/events#Events-EventTarget-dispatc
hEvent | 107 * @see http://www.w3.org/TR/DOM-Level-2-Events/events#Events-EventTarget-dispatc
hEvent |
| 113 * @see http://www.w3.org/TR/DOM-Level-2-Events/events#xpointer(id('Events-EventT
arget-dispatchEvent')/raises/exception[@name='EventException']/descr/p[substring
-before(.,':')='UNSPECIFIED_EVENT_TYPE_ERR']) | 108 * @see http://www.w3.org/TR/DOM-Level-2-Events/events#xpointer(id('Events-EventT
arget-dispatchEvent')/raises/exception[@name='EventException']/descr/p[substring
-before(.,':')='UNSPECIFIED_EVENT_TYPE_ERR']) |
| 114 */ | 109 */ |
| 115 function dispatchEvent12() { | 110 function dispatchEvent12() { |
| 116 var success; | 111 var success; |
| 117 if(checkInitialization(builder, "dispatchEvent12") != null) return; | 112 if(checkInitialization(builder, "dispatchEvent12") != null) return; |
| 118 var doc; | 113 var doc; |
| 119 var target; | 114 var target; |
| 120 var evt; | 115 var evt; |
| 121 var preventDefault; | 116 var preventDefault; |
| 122 monitor = new EventMonitor(); | 117 monitor = new EventMonitor(); |
| 123 | 118 |
| 124 other = new EventListenerN10035(); | 119 other = new EventListenerN10035(); |
| 125 | 120 |
| 126 var events = new Array(); | 121 var events = new Array(); |
| 127 | 122 |
| 128 | |
| 129 var docRef = null; | 123 var docRef = null; |
| 130 if (typeof(this.doc) != 'undefined') { | 124 if (typeof(this.doc) != 'undefined') { |
| 131 docRef = this.doc; | 125 docRef = this.doc; |
| 132 } | 126 } |
| 133 doc = load(docRef, "doc", "hc_staff"); | 127 doc = load(docRef, "doc", "hc_staff"); |
| 134 doc.addEventListener("foo", monitor.handleEvent, false); | 128 doc.addEventListener("foo", monitor.handleEvent, false); |
| 135 doc.removeEventListener("foo", monitor.handleEvent, true); | 129 doc.removeEventListener("foo", monitor.handleEvent, true); |
| 136 » doc.removeEventListener("food", monitor.handleEvent, false); | 130 doc.removeEventListener("food", monitor.handleEvent, false); |
| 137 » doc.removeEventListener("foo", other.handleEvent, false); | 131 doc.removeEventListener("foo", other.handleEvent, false); |
| 138 » evt = doc.createEvent("Events"); | 132 evt = doc.createEvent("Events"); |
| 139 evt.initEvent("foo",true,false); | 133 evt.initEvent("foo",true,false); |
| 140 preventDefault = doc.dispatchEvent(evt); | 134 preventDefault = doc.dispatchEvent(evt); |
| 141 events = monitor.allEvents; | 135 events = monitor.allEvents; |
| 142 assertSize("eventCount",1,events); | 136 assertSize("eventCount",1,events); |
| 143 | 137 |
| 144 } | 138 } |
| 145 | 139 |
| 146 | |
| 147 | |
| 148 | |
| 149 function runTest() { | 140 function runTest() { |
| 150 dispatchEvent12(); | 141 dispatchEvent12(); |
| 151 } | 142 } |
| OLD | NEW |