chromium/third_party/blink/web_tests/external/wpt/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-pointer-insert-source.html

<!doctype html>
<title>pointer updates (adding source elements)</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id=log></div>
<script>
var a = 0;
var b = 0;
var c = 0;
var x1 = 0;
var x2 = 0;
var x3 = 0;
var x4 = 0;
</script>
<video
 ><source onerror=a++
 ><source onerror=b++ src='resources/delayed-broken-video.py'
 ><source onerror=c++
 ></video
>
<script>
async_test(function(t) {
  var video = document.querySelector('video');
  // add source elements
  var source1 = document.createElement('source'); source1.onerror = function() { x1++; };
  var source2 = document.createElement('source'); source2.onerror = function() { x2++; };
  var source3 = document.createElement('source'); source3.onerror = function() { x3++; };
  var source4 = document.createElement('source'); source4.onerror = function() { x4++; };
  video.insertBefore(source1, video.querySelector('[onerror="a++"]'));
  video.insertBefore(source2, video.querySelector('[onerror="b++"]'));
  video.insertBefore(source3, video.querySelector('[onerror="c++"]'));
  video.appendChild(source4);
  window.onload = t.step_func(function() {
    assert_equals(a, 1, 'error events on a');
    assert_equals(b, 1, 'error events on b');
    assert_equals(c, 1, 'error events on c');
    assert_equals(x1, 0, 'error events on x1');
    assert_equals(x2, 0, 'error events on x2');
    assert_equals(x3, 1, 'error events on x3');
    assert_equals(x4, 1, 'error events on x4');
    t.done();
  });
});
</script>