blob: 0d57036a6b68bc774aeb0a2abe36751d644af9eb [file] [log] [blame] [edit]
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Testing macFramerate</title>
<script src="../resources/testharness.js"></script>
<script src="../resources/testharnessreport.js"></script>
</head>
<body>
<video id="video" autoplay=""></video>
<script src ="routines.js"></script>
<script>
if (window.internals)
internals.settings.setPeerConnectionVideoScalingAdaptationDisabled(false);
var pc1, pc2;
promise_test(async (test) => {
const localStream = await navigator.mediaDevices.getUserMedia({video:{width:640}});
const stream = await new Promise((resolve, reject) => {
createConnections((firstConnection) => {
pc1 = firstConnection;
const sender = firstConnection.addTrack(localStream.getVideoTracks()[0], localStream);
}, (secondConnection) => {
pc2 = secondConnection;
secondConnection.ontrack = (trackEvent) => {
resolve(trackEvent.streams[0]);
};
});
setTimeout(() => reject("Test timed out"), 5000);
});
video.srcObject = stream;
await video.play();
let settings = stream.getVideoTracks()[0].getSettings();
let counter = 0;
while (++counter < 200 && settings.frameRate < 10) {
await new Promise(resolve => setTimeout(resolve, 50));
settings = stream.getVideoTracks()[0].getSettings();
}
assert_greater_than(settings.frameRate, 5, "remote track settings frame rate");
counter = 0;
while (++counter < 200 && settings.width < 640) {
await new Promise(resolve => setTimeout(resolve, 50));
settings = stream.getVideoTracks()[0].getSettings();
}
assert_greater_than_equal(settings.width, 640, "remote track settings width");
let parameters = pc1.getSenders()[0].getParameters();
parameters.encodings[0].maxFramerate = 30;
parameters.encodings[0].maxBitrate = 10000;
parameters.degradationPreference = "maintain-resolution";
await pc1.getSenders()[0].setParameters(parameters);
await new Promise(resolve => setTimeout(resolve, 1000));
assert_greater_than_equal(settings.width, 640, "remote track width with reduced bitrate and maintain-resolution");
parameters = pc1.getSenders()[0].getParameters();
parameters.degradationPreference = "maintain-framerate";
await pc1.getSenders()[0].setParameters(parameters);
counter = 0;
while (++counter < 200 && settings.width == 640) {
await new Promise(resolve => setTimeout(resolve, 50));
settings = stream.getVideoTracks()[0].getSettings();
}
assert_less_than_equal(settings.width, 480, "remote track width with reduced bitrate and maintain-framerate");
}, "Testing that maxBitrate and maintain-framerate have an effect");
</script>
</body>
</html>