summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html
blob: 1635598efdd28de1a9c40ab62d3a4f75b77d7ea4 (plain)
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
<!doctype html>
<title>await a stable state and sync event handlers</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id=log></div>
<video></video>
<script>
var v;
var t = async_test(function(t) {
  v = document.querySelector('video');
  var a = document.createElement('a');
  a.onclick = t.step_func(function() {
    v.setAttribute('src', '#'); // invokes media load which invokes resource selection
    assert_equals(v.networkState, v.NETWORK_NO_SOURCE, 'networkState in onclick handler');
  });
  a.click(); // sync fires click, so sets src
  // now we should still await a stable state because the script hasn't
  // finished, the event handler has just returned
  assert_equals(v.networkState, v.NETWORK_NO_SOURCE, 'networkState after click()');
  v.removeAttribute('src');
});
t.step(function() {
  // now the sync section of resource selection should have run and should
  // have found no src="" or <source> thus networkState being set to NETWORK_EMPTY.
  // if the sync section was run when onclick returned, then networkState
  // would be either NETWORK_LOADING or NETWORK_NO_SOURCE.
  assert_equals(v.networkState, v.NETWORK_EMPTY, 'networkState after src removed');
  t.done();
});
</script>