| Index: LayoutTests/http/tests/media/media-source/mediasource-sourcebuffer-mode.html
|
| diff --git a/LayoutTests/http/tests/media/media-source/mediasource-sourcebuffer-mode.html b/LayoutTests/http/tests/media/media-source/mediasource-sourcebuffer-mode.html
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..a20c6f33c6beab3eabc0032aa338af1cc109e1ee
|
| --- /dev/null
|
| +++ b/LayoutTests/http/tests/media/media-source/mediasource-sourcebuffer-mode.html
|
| @@ -0,0 +1,83 @@
|
| +<!DOCTYPE html>
|
| +<html>
|
| + <head>
|
| + <script src="/w3c/resources/testharness.js"></script>
|
| + <script src="/w3c/resources/testharnessreport.js"></script>
|
| + <script src="mediasource-util.js"></script>
|
| + <script src="/media/resources/media-source/webm/segment-info.js"></script>
|
| +
|
| + <link rel='stylesheet' href='/w3c/resources/testharness.css'>
|
| + </head>
|
| + <body>
|
| + <div id="log"></div>
|
| + <script>
|
| + mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
|
| + {
|
| + assert_true(sourceBuffer.mode == 'segments');
|
| + test.done();
|
| + }, 'Test initial value of SourceBuffer.mode is "segments"');
|
| +
|
| + mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
|
| + {
|
| + sourceBuffer.mode = 'sequence';
|
| + assert_true(sourceBuffer.mode == 'sequence');
|
| + sourceBuffer.mode = 'segments';
|
| + assert_true(sourceBuffer.mode == 'segments');
|
| + assert_throws('InvalidAccessError',
|
| + function() { sourceBuffer.mode = 'invalidmode'; },
|
| + 'Setting invalid sourceBuffer.mode threw InvalidAccessError.');
|
| + test.done();
|
| + }, 'Test setting SourceBuffer.mode');
|
| +
|
| + mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
|
| + {
|
| + mediaSource.removeSourceBuffer(sourceBuffer);
|
| + assert_throws('InvalidStateError',
|
| + function() { sourceBuffer.mode = 'segments'; },
|
| + 'Setting valid sourceBuffer.mode on removed SourceBuffer threw InvalidStateError.');
|
| + test.done();
|
| + }, 'Test setting a removed SourceBuffer\'s mode');
|
| +
|
| + mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
|
| + {
|
| + sourceBuffer.appendBuffer(mediaData);
|
| + assert_true(sourceBuffer.updating, 'updating attribute is true');
|
| + assert_throws('InvalidStateError',
|
| + function() { sourceBuffer.mode = 'segments'; },
|
| + 'Setting valid sourceBuffer.mode on updating SourceBuffer threw InvalidStateError.');
|
| + test.done();
|
| + }, 'Test setting SourceBuffer.mode while still updating');
|
| +
|
| + mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
|
| + {
|
| + test.expectEvent(sourceBuffer, 'updateend', 'Append ended.');
|
| + sourceBuffer.appendBuffer(mediaData);
|
| +
|
| + test.waitForExpectedEvents(function()
|
| + {
|
| + assert_false(sourceBuffer.updating, 'updating attribute is false');
|
| +
|
| + test.expectEvent(mediaSource, 'sourceended', 'MediaSource sourceended event');
|
| + mediaSource.endOfStream();
|
| + assert_equals(mediaSource.readyState, 'ended', 'MediaSource readyState is \'ended\'');
|
| + });
|
| +
|
| + test.waitForExpectedEvents(function()
|
| + {
|
| + assert_equals(mediaSource.readyState, 'ended', 'MediaSource readyState is \'ended\'');
|
| +
|
| + test.expectEvent(mediaSource, 'sourceopen', 'MediaSource sourceopen event');
|
| + sourceBuffer.mode = 'segments';
|
| +
|
| + assert_equals(mediaSource.readyState, 'open', 'MediaSource readyState is \'open\'');
|
| + });
|
| +
|
| + test.waitForExpectedEvents(function()
|
| + {
|
| + assert_equals(mediaSource.readyState, 'open', 'MediaSource readyState is \'open\'');
|
| + test.done();
|
| + });
|
| + }, 'Test setting SourceBuffer.mode triggers parent MediaSource \'ended\' to \'open\' transition.');
|
| + </script>
|
| + </body>
|
| +</html>
|
|
|