1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
  
     | 
    
      <!doctype html>
<meta charset=utf-8>
<title>The end</title>
<link rel=help href="https://html.spec.whatwg.org/multipage/#the-end">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id="log"></div>
<script>
async_test(function() {
  document.addEventListener("DOMContentLoaded", this.step_func_done(function(e) {
    assert_equals(e.type, "DOMContentLoaded");
    assert_true(e.bubbles, "bubbles should be true");
    assert_false(e.cancelable, "cancelable should be false");
    assert_equals(e.target, document, "target should be document");
    assert_true(e.isTrusted, "isTrusted should be true");
    assert_class_string(e, "Event");
  }));
}, "DOMContentLoaded");
async_test(function() {
  window.addEventListener("load", this.step_func_done(function(e) {
    assert_equals(e.type, "load");
    assert_false(e.bubbles, "bubbles should be false");
    assert_false(e.cancelable, "cancelable should be false");
    assert_equals(e.target, document, "target should be document");
    assert_true(e.isTrusted, "isTrusted should be true");
    assert_class_string(e, "Event");
  }));
}, "load");
async_test(function() {
  window.addEventListener("pageshow", this.step_func_done(function(e) {
    assert_equals(e.type, "pageshow");
    // https://github.com/whatwg/html/issues/6794
    assert_true(e.bubbles, "bubbles should be true");
    assert_true(e.cancelable, "cancelable should be true");
    assert_equals(e.target, document, "target should be document");
    assert_true(e.isTrusted, "isTrusted should be true");
    assert_class_string(e, "PageTransitionEvent");
  }));
}, "pageshow");
async_test(function() {
  var seen_dcl = false;
  var seen_load = false;
  document.addEventListener("DOMContentLoaded", this.step_func(function() {
    seen_dcl = true;
  }));
  window.addEventListener("load", this.step_func(function() {
    seen_load = true;
    assert_true(seen_dcl, "DOMContentLoaded should be fired before load");
  }));
  window.addEventListener("pageshow", this.step_func_done(function() {
    assert_true(seen_load, "load should be fired before pageshow")
  }));
}, "order");
</script>
 
     |