https://github.com/web-platform-tests/wpt
Raw File
Tip revision: 8e253afd467510fd23201bd9086920eb06ce920a authored by Hallvord R. M. Steen on 19 October 2014, 21:58:51 UTC
making it clearer what events are firing, in what order and what the state of the request is at each step
Tip revision: 8e253af
mediasource-play-then-seek-back.html
<!DOCTYPE html>
<html>
    <head>
        <title>Simple MediaSource playback &amp; seek test case.</title>
        <script src="/resources/testharness.js"></script>
        <script src="/resources/testharnessreport.js"></script>
        <script src="mediasource-util.js"></script>
    </head>
    <body>
        <div id="log"></div>
        <script>

            mediasource_testafterdataloaded(function(test, mediaElement, mediaSource, segmentInfo, sourceBuffer, mediaData)
            {

                mediaElement.play();
                // Append all the segments
                test.expectEvent(sourceBuffer, 'updateend', 'sourceBuffer');
                test.expectEvent(mediaElement, 'playing', 'Playing triggered');
                sourceBuffer.appendBuffer(mediaData);

                function confirmPlayThenEnd()
                {
                    test.waitForCurrentTimeChange(mediaElement, function ()
                    {
                        assert_greater_than(mediaElement.currentTime, 0.0, 'Playback has started after seek.');
                        test.done();
                    });
                }

                function finishSeekThenPlay()
                {
                    assert_true(mediaElement.seeking, 'mediaElement is seeking');
                    assert_equals(mediaElement.currentTime, 0.0, 'Current time is 0.0');
                    test.expectEvent(mediaElement, 'seeked', 'mediaElement finished seek');

                    test.waitForExpectedEvents(confirmPlayThenEnd);
                }

                function delayedPlayHandler()
                {
                    assert_greater_than(mediaElement.currentTime, 0.0, 'Playback has started.');
                    test.expectEvent(mediaElement, 'seeking', 'mediaElement');
                    mediaElement.currentTime = 0.0;

                    test.waitForExpectedEvents(finishSeekThenPlay);
                }

                test.waitForExpectedEvents(function()
                {
                    test.waitForCurrentTimeChange(mediaElement, delayedPlayHandler);
                });

            }, 'Test playing then seeking back.');
        </script>
    </body>
</html>
back to top