44 lines
1.3 KiB
HTML
44 lines
1.3 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<title>media-source-has-audio-video</title>
|
|
<script src="media-source-loader.js"></script>
|
|
<script src="../video-test.js"></script>
|
|
<script>
|
|
window.addEventListener('load', event => {
|
|
findMediaElement();
|
|
|
|
window.sourceBuffer = new MediaSource();
|
|
|
|
loader = new MediaSourceLoader('content/test-fragmented-manifest.json');
|
|
loader.onload = mediaDataLoaded;
|
|
loader.onerror = mediaDataLoadingFailed;
|
|
});
|
|
|
|
function mediaDataLoadingFailed() {
|
|
failTest('Media data loading failed');
|
|
}
|
|
|
|
async function mediaDataLoaded() {
|
|
window.mediaSource = new MediaSource();
|
|
run('video.src = URL.createObjectURL(mediaSource)');
|
|
waitFor(video, 'error').then(failTest);
|
|
await waitFor(mediaSource, 'sourceopen');
|
|
|
|
run('mediaSource.duration = loader.duration()');
|
|
run('sourceBuffer = mediaSource.addSourceBuffer(loader.type())');
|
|
run('sourceBuffer.appendBuffer(loader.initSegment())');
|
|
await waitFor(sourceBuffer, 'update');
|
|
|
|
await testExpectedEventually('internals.mediaUsageState(video).hasVideo', true);
|
|
await testExpectedEventually('internals.mediaUsageState(video).hasAudio', true);
|
|
endTest();
|
|
}
|
|
|
|
</script>
|
|
</head>
|
|
<body>
|
|
<video></video>
|
|
</body>
|
|
</html>
|