<!DOCTYPE html>
<html>
<head>
<title> Dispatch additional events inside an event listener </title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
</head>
<body>
<div id=log></div>
<table id="table" border="1" style="display: none">
<tbody id="table-body">
<tr id="table-row">
<td id="table-cell">Shady Grove</td>
<td>Aeolian</td>
</tr>
<tr id="parent">
<td id="target">Over the river, Charlie</td>
<td>Dorian</td>
</tr>
</tbody>
</table>
<script>
var EVENT = "foo";
var TARGET = document.getElementById("target");
var PARENT = document.getElementById("parent");
var TBODY = document.getElementById("table-body");
var TABLE = document.getElementById("table");
var BODY = document.body;
var HTML = document.documentElement;
var CurrentTargets = [window, document, HTML, BODY, TABLE, TBODY, PARENT, TARGET];
var ExpectResult = [window, document, HTML, BODY, TABLE, TARGET, PARENT, TBODY,
TABLE, BODY, HTML, document, window, TBODY, PARENT, TARGET];
var ActualResult = [];
var ExpectTypes = "foo,foo,foo,foo,foo,bar,bar,bar,bar,bar,bar,bar,bar,foo,foo,foo,";
var ActualTypes = "";
var description = "Test Description: " +
"Implementations of the DOM event model must be reentrant. Event listeners may perform actions that " +
"cause additional events to be dispatched. Such events are handled in a synchronous manner, the event " +
"propagation that causes the event listener to be triggered must resume only after the event dispatch " +
"of the new event is completed.";
test(function()
{
for (var i=0; i < CurrentTargets.length; i++)
{
CurrentTargets[i].addEventListener(EVENT, TestEvent, true);
CurrentTargets[i].addEventListener("bar", TestEvent, false);
}
var evt = document.createEvent("Event");
evt.initEvent(EVENT, false, true);
TARGET.dispatchEvent(evt);
assert_array_equals(ActualResult, ExpectResult, "ActualResult");
assert_equals(ActualTypes, ExpectTypes, "ActualTypes");
}, description);
function TestEvent(evt)
{
ActualResult.push(evt.currentTarget);
ActualTypes += evt.type + ",";
if (TABLE == evt.currentTarget && EVENT == evt.type)
{
var e = document.createEvent("Event");
e.initEvent("bar", true, true);
TARGET.dispatchEvent(e);
}
}
</script>
</body>
</html>