blob: 79a0d4cacb6744780b0908a18a704edbe988984b [file] [log] [blame]
<!DOCTYPE html>
<html>
<head>
<script src="../../resources/js-test-pre.js"></script>
<script src="resources/apply-constraints-utils.js"></script>
<script>
let tests = [
{
message: "set width, height, and frame rate to valid values.",
constraint: { width: 640, height: 480, frameRate: 30 },
expected: { width: 640, height: 480, frameRate: 30 },
},
{
message: "change width and height, frame rate should remain unchanged.",
constraint: { width: 320, height: 240 },
expected: { width: 320, height: 240, frameRate: 30 },
},
{
message: "the 'exact' constraint can't be satisfied, promise should reject and no settings should change.",
constraint: { width: { exact: 2000 } },
expected: { width: 320, height: 240, frameRate: 30 },
error: "width",
},
{
message: "the 'min' constraint can't be satisfied, promise should reject and no settings should change.",
constraint: { width: 640, height: {min: 3000}, },
expected: { width: 320, height: 240, frameRate: 30 },
error: "height",
},
{
message: "the 'max' constraint can't be satisfied, promise should reject and no settings should change.",
constraint: { frameRate: {max: 6}, },
expected: { frameRate: 30 },
error: "frameRate",
},
{
message: "the 'exact' constraint can be satisfied.",
constraint: { width: { exact: 400 } },
expected: { width: 400, height: 240 },
},
{
message: "the 'ideal' constraint can't be satisfied but the 'min' can, max should be chosen.",
constraint: { width: {min: 300, ideal: 5000} },
expected: { width: 1920, height: 240 },
},
{
message: "'ideal' and 'min' constraints can be satisfied, 'ideal' should be chosen.",
constraint: { width: {min: 320, ideal: 1280}, height: {min: 480, ideal: 720}, },
expected: { width: 1280, height: 720 },
},
{
message: "ideal width is greater than track capability, should be clamped to the maximum value.",
constraint: { width: 3000 },
expected: { width: 1920},
},
{
message: "all values are less than track capabilities, should be clamped to the minimum values.",
constraint: { width: 160, height: 120, frameRate: 10 },
expected: { width: 320, height: 240, frameRate: 15 },
},
{
message: "set facing mode, width and height should remain unchanged",
constraint: { facingMode: "environment" },
expected: { width: 320, height: 240, facingMode: "environment" },
},
{
message: "illegal facing mode value should be ignored, height should change.",
constraint: { facingMode: "USER", height: 400 },
expected: { facingMode: "environment", width: 320, height: 400 },
},
{
message: "unknown constraint should be ignored, frame rate should change.",
constraint: { FACINGMODE: "user", frameRate: 30 },
expected: { facingMode: "environment", frameRate: 30 },
},
{
message: "aspect ratio should change width and height.",
constraint: { aspectRatio: (4/3).toFixed(4) },
expected: { width: 320, height: 240 },
},
{
message: "new aspect ratio should again change width and height.",
constraint: { aspectRatio: (16/9).toFixed(4) },
expected: { width: 320, height: 180 },
},
{
message: "when aspect ratio has been set, changing width should change height.",
constraint: { width: 1920 },
expected: { width: 1920, height: 1080},
},
{
message: "when aspect ratio has been set, changing height should change width.",
constraint: { height: 576 },
expected: { width: 1024, height: 576},
},
{
message: "the 'exact' deviceID doesn't match, promise should reject.",
constraint: { deviceId: {exact: "20983-20o198-109283-098-09812"}, },
expected: { },
error: "deviceId",
},
];
let tester = new ConstraintsTest({ video: true }, tests, "Tests applyConstraints on a video stream track.")
.onStreamReady((s) => {
stream = s;
shouldBe('stream.getVideoTracks().length', '1');
shouldBe('stream.getAudioTracks().length', '0');
tester.setStreamTrack(stream.getVideoTracks()[0]);
})
.onVideoReady((v) => {
video = v;
shouldBe('video.videoTracks.length', '1');
shouldBe('video.audioTracks.length', '0');
})
.start();
</script>
<script src="../../resources/js-test-post.js"></script>
</head>
<body>
<video controls id="video"</video>
<br>
<div id="div"></div>
</body>
</html>