popover-close-request.html (1545B)
1 <!DOCTYPE html> 2 <meta charset="utf-8"> 3 <title>Popover close request behavior</title> 4 <script src="/resources/testharness.js"></script> 5 <script src="/resources/testharnessreport.js"></script> 6 <script src="/resources/testdriver.js"></script> 7 <script src="/resources/testdriver-actions.js"></script> 8 <script src="/resources/testdriver-vendor.js"></script> 9 <script src="/common/top-layer.js"></script> 10 <script src="/close-watcher/resources/helpers.js"></script> 11 12 <div popover id=p1> 13 Inside popover 1 14 <div popover id=p2>Inside popover 2</div> 15 </div> 16 17 <script> 18 promise_test(async () => { 19 const popover1 = document.querySelector('#p1'); 20 const popover2 = document.querySelector('#p2'); 21 22 popover1.showPopover(); 23 24 // Bless the opening of popover2, so it doesn't get grouped with popover1 by 25 // the close watcher infrastructure. 26 await blessTopLayer(popover1); 27 popover2.showPopover(); 28 29 assert_true(popover1.matches(':popover-open'), "Starting: popover1 must be open"); 30 assert_true(popover2.matches(':popover-open'), "Starting: popover2 must be open"); 31 32 await sendCloseRequest(); 33 assert_true(popover1.matches(':popover-open'), "After one close request, popover1 must be open"); 34 assert_false(popover2.matches(':popover-open'), "After one close request, popover2 must be closed"); 35 36 await sendCloseRequest(); 37 assert_false(popover1.matches(':popover-open'), "After two close requests, popover1 must be closed"); 38 assert_false(popover2.matches(':popover-open'), "After two close requests, popover2 must be closed"); 39 }); 40 </script>