40 lines
1.5 KiB
HTML
40 lines
1.5 KiB
HTML
<!DOCTYPE html>
|
|
<meta charset="utf-8">
|
|
<title>Popover close request behavior</title>
|
|
<script src="/resources/testharness.js"></script>
|
|
<script src="/resources/testharnessreport.js"></script>
|
|
<script src="/resources/testdriver.js"></script>
|
|
<script src="/resources/testdriver-actions.js"></script>
|
|
<script src="/resources/testdriver-vendor.js"></script>
|
|
<script src="/common/top-layer.js"></script>
|
|
<script src="/close-watcher/resources/helpers.js"></script>
|
|
|
|
<div popover id=p1>
|
|
Inside popover 1
|
|
<div popover id=p2>Inside popover 2</div>
|
|
</div>
|
|
|
|
<script>
|
|
promise_test(async () => {
|
|
const popover1 = document.querySelector('#p1');
|
|
const popover2 = document.querySelector('#p2');
|
|
|
|
popover1.showPopover();
|
|
|
|
// Bless the opening of popover2, so it doesn't get grouped with popover1 by
|
|
// the close watcher infrastructure.
|
|
await blessTopLayer(popover1);
|
|
popover2.showPopover();
|
|
|
|
assert_true(popover1.matches(':popover-open'), "Starting: popover1 must be open");
|
|
assert_true(popover2.matches(':popover-open'), "Starting: popover2 must be open");
|
|
|
|
await sendCloseRequest();
|
|
assert_true(popover1.matches(':popover-open'), "After one close request, popover1 must be open");
|
|
assert_false(popover2.matches(':popover-open'), "After one close request, popover2 must be closed");
|
|
|
|
await sendCloseRequest();
|
|
assert_false(popover1.matches(':popover-open'), "After two close requests, popover1 must be closed");
|
|
assert_false(popover2.matches(':popover-open'), "After two close requests, popover2 must be closed");
|
|
});
|
|
</script>
|