Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

<!doctype html>
<html>
<head>
<meta charset=utf-8>
<title>RTCPeerConnection Screen-sharing Simulcast Tests</title>
<meta name="timeout" content="long">
<script src="../third_party/sdp/sdp.js"></script>
<script src="simulcast.js"></script>
<script src="../RTCPeerConnection-helper.js"></script>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
</head>
<body>
<script>
async function getDisplayMedia(options) {
const button = document.createElement("button");
button.innerHTML = "getDisplayMedia button";
document.body.prepend(button);
const p = new Promise((resolve, reject) => button.onclick = () => {
navigator.mediaDevices.getDisplayMedia(options).then(resolve, reject);
button.remove();
});
await test_driver.click(button);
return p;
}
promise_test(async t => {
// Test getDisplayMedia with simulcast
await test_driver.bless('getDisplayMedia');
const stream = await getDisplayMedia({
video: {width: 640, height: 480}
});
t.add_cleanup(() => stream.getTracks().forEach(track => track.stop()));
const rids = [0, 1];
const pc1 = new RTCPeerConnection();
t.add_cleanup(() => pc1.close());
const pc2 = new RTCPeerConnection();
t.add_cleanup(() => pc2.close());
return negotiateSimulcastAndWaitForVideo(t, stream, rids, pc1, pc2);
}, 'Basic simulcast setup with two spatial layers');
</script>
</body>
</html>