summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/fenced-frame/web-usb.https.html
blob: 3156f68ea736f2bdf34a679d51a3a04f15ae08dd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<!DOCTYPE html>
<title>Test WebUSB navigator.usb.requestDevice()</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/utils.js"></script>
<script src="/common/dispatcher/dispatcher.js"></script>
<script src="resources/utils.js"></script>

<body>
<script>
promise_test(async () => {
  const frame = attachFencedFrameContext();
  await frame.execute(async () => {
    // Request USB access inside the fenced frame. It should fail.
    // https://github.com/shivanigithub/fenced-frame#security-considerations.
    try {
      await navigator.usb.requestDevice({ filters: [{ vendorId: 0}] });
      throw 'The USB request should not succeed.';
    } catch (e) {
      assert_equals(e.name, 'SecurityError');
      assert_equals(e.message,
        "Failed to execute 'requestDevice' on 'USB': " +
        'Access to the feature "usb" is disallowed by permissions policy.',
        'Fenced frame has the right error for usb.requestDevice.');
    }
  });
}, 'navigator.usb.requestDevice');
</script>
</body>