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>