1<!DOCTYPE html>
2<title>Event phases order</title>
3<script src="/resources/testharness.js"></script>
4<script src="/resources/testharnessreport.js"></script>
5<div id="log"></div>
6<script>
7async_test(function() {
8    document.addEventListener('DOMContentLoaded', this.step_func_done(function() {
9        var parent = document.getElementById('parent');
10        var child = document.getElementById('child');
11
12        var order = [];
13
14        parent.addEventListener('click', this.step_func(function(){ order.push(1) }), true);
15        child.addEventListener('click', this.step_func(function(){ order.push(2) }), false);
16        parent.addEventListener('click', this.step_func(function(){ order.push(3) }), false);
17
18        child.dispatchEvent(new Event('click', {bubbles: true}));
19
20        assert_array_equals(order, [1, 2, 3]);
21    }));
22}, "Event phases order");
23</script>
24<div id="parent">
25    <div id="child"></div>
26</div>
27