Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
- This WPT test may be referenced by the following Test IDs:
- /mediacapture-streams/GUM-required-constraint-with-ideal-value.https.html - WPT Dashboard Interop Dashboard
<!doctype html>
<html>
<head>
<title>Ideal value in required constraint in getUserMedia</title>
<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>
<script src=permission-helper.js></script>
</head>
<body>
<p class="instructions">When prompted, accept to share your video stream.</p>
<h1 class="instructions">Description</h1>
<p class="instructions">This test checks that setting a required constraint
with an ideal value in getUserMedia works</p>
<div id='log'></div>
<script>
promise_test(async t => {
await setMediaPermission("granted", ["camera"]);
const stream = await navigator.mediaDevices.getUserMedia({video: {width: {ideal: 320, min: 160}}});
assert_equals(stream.getVideoTracks().length, 1, "the media stream has exactly one video track");
assert_equals(stream.getVideoTracks()[0].getSettings().width, 320, 'ideal width is selected for getUserMedia() video tracks');
const video = document.createElement('video');
video.srcObject = stream;
await video.play();
assert_equals(video.videoWidth, 320, 'video width equals to track width');
stream.getVideoTracks()[0].stop();
}, "Tests that setting a required constraint with an ideal value in getUserMedia works");
</script>
</body>
</html>