| <!doctype html> |
| <html> |
| <head> |
| <meta charset='utf-8'> |
| <title>SourceBuffer#abort() for already removed buffer from parent media source</title> |
| <script src="/resources/testharness.js"></script> |
| <script src="/resources/testharnessreport.js"></script> |
| </head> |
| <body> |
| <div id="log"></div> |
| |
| <script> |
| var mimes = ['video/webm; codecs="vorbis,vp8"', 'video/mp4']; |
| |
| //check the browser supports the MIME used in this test |
| function isTypeSupported(mime) { |
| if(!MediaSource.isTypeSupported(mime)) { |
| this.step(function() { |
| assert_unreached("Browser doesn't support the MIME used in this test: " + mime); |
| }); |
| this.done(); |
| return false; |
| } |
| return true; |
| } |
| function mediaTest(mime) { |
| async_test(function(t) { |
| if(!isTypeSupported.bind(t)(mime)) { |
| return; |
| } |
| var mediaSource = new MediaSource(); |
| mediaSource.addEventListener('sourceopen', t.step_func_done(function(e) { |
| var sourceBuffer = mediaSource.addSourceBuffer(mime); |
| mediaSource.removeSourceBuffer(sourceBuffer); |
| assert_throws({name: 'InvalidStateError'}, |
| function() { |
| sourceBuffer.abort(); |
| }, |
| 'SourceBuffer#abort() after removing the SourceBuffer object'); |
| }), false); |
| var video = document.createElement('video'); |
| video.src = window.URL.createObjectURL(mediaSource); |
| }, 'SourceBuffer#abort (' + mime + ') : ' + |
| 'if this object has been removed from the sourceBuffers attribute of the parent media source, ' + |
| 'then throw an INVALID_STATE_ERR exception and abort these steps.'); |
| } |
| mimes.forEach(function(mime) { |
| mediaTest(mime); |
| }); |
| </script> |
| </body> |
| </html> |