|  | <!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> |