blob: 568543da70f8360a80f9ed0e633f55f35f57aa92 [file] [log] [blame]
<!doctype html>
<meta charset=utf-8>
<meta name="timeout" content="long">
<title></title>
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script src="RTCPeerConnection-helper.js"></script>
<script>
'use strict';
// A generous testing duration that will not time out on bots.
const kEncodeDurationMs = 10000;
// The crash this test aims to repro was easy to reproduce using a normal
// getUserMedia() track when running the browser normally, e.g. by navigating
// to https://jsfiddle.net/henbos/fc7gk3ve/11/. But for some reason, the fake
// tracks returned by getUserMedia() when inside this testing environment had
// a much harder time with reproducibility.
//
// By creating a high FPS canvas capture track we are able to repro reliably
// in this WPT environment as well.
function whiteNoise(width, height) {
const canvas =
Object.assign(document.createElement('canvas'), {width, height});
const ctx = canvas.getContext('2d');
ctx.fillRect(0, 0, width, height);
const p = ctx.getImageData(0, 0, width, height);
requestAnimationFrame(function draw () {
for (let i = 0; i < p.data.length; i++) {
const color = Math.random() * 255;
p.data[i++] = color;
p.data[i++] = color;
p.data[i++] = color;
}
ctx.putImageData(p, 0, 0);
requestAnimationFrame(draw);
});
return canvas.captureStream();
}
promise_test(async t => {
const pc1 = new RTCPeerConnection();
t.add_cleanup(() => pc1.close());
const pc2 = new RTCPeerConnection();
t.add_cleanup(() => pc2.close());
const stream = whiteNoise(640, 480);
const [track] = stream.getTracks();
const t1 = pc1.addTransceiver("video", {direction:"sendonly"});
const t2 = pc1.addTransceiver("video", {direction:"sendonly"});
await t1.sender.replaceTrack(track);
await t2.sender.replaceTrack(track);
exchangeIceCandidates(pc1, pc2);
await pc1.setLocalDescription();
await pc2.setRemoteDescription(pc1.localDescription);
await pc2.setLocalDescription();
await pc1.setRemoteDescription(pc2.localDescription);
// In Chromium, each sender instantiates a VideoStreamEncoder during
// negotiation. This test reproduces https://crbug.com/webrtc/11485 where a
// race causes a crash when multiple VideoStreamEncoders are encoding the
// same MediaStreamTrack.
await new Promise(resolve => t.step_timeout(resolve, kEncodeDurationMs));
}, "Two RTCRtpSenders encoding the same track");
</script>