tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

picture-in-picture-report-only.html (1404B)


      1 <!DOCTYPE html>
      2 <html>
      3  <head>
      4    <script src='/common/media.js'></script>
      5    <script src='/resources/testharness.js'></script>
      6    <script src='/resources/testharnessreport.js'></script>
      7    <script src="/resources/testdriver.js"></script>
      8    <script src="/resources/testdriver-vendor.js"></script>
      9    <script src='../resources/picture-in-picture.js'></script>
     10  </head>
     11  <body>
     12    <script>
     13 const check_report_format = ([reports, observer]) => {
     14  const report = reports[0];
     15  assert_equals(report.type, "permissions-policy-violation");
     16  assert_equals(report.body.featureId, "picture-in-picture");
     17  assert_equals(report.body.disposition, "report");
     18 };
     19 
     20 const loadVideo = () => new Promise(resolve => {
     21    const video = document.createElement('video');
     22    video.src = getVideoURI('/media/movie_5');
     23    video.addEventListener('loadedmetadata', () => {
     24      resolve(video);
     25    }, { once: true });
     26 });
     27 
     28 promise_pip_test(async (t) => {
     29  const report = new Promise(resolve => {
     30    new ReportingObserver((reports, observer) => resolve([reports, observer]),
     31                          {types: ['permissions-policy-violation']}).observe();
     32  });
     33  const videoElement = await loadVideo();
     34  await test_driver.bless('picture-in-picture');
     35  await videoElement.requestPictureInPicture();
     36  check_report_format(await report);
     37 }, "Picture-in-Picture report only mode");
     38    </script>
     39  </body>
     40 </html>