blob: ef3b35aea408e9c59f6d371ca83576268c34141c (
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Test that popover light dismiss uses the flat tree when nested shadow roots.</title>
<link rel="author" title="Luke Warlow" href="mailto:luke@warlow.dev">
</head>
<body>
<p>Test passes if the inner popover opens after clicking the inner toggle.</p>
<button popovertarget="outerPopover" popovertargetaction="toggle" id="outerPopoverToggle">Toggle</button>
<div id="outerPopover" popover>
<template shadowrootmode="open">
Outer
<button id="innerPopoverToggle">Toggle</button>
<div id="innerContainer">
<template shadowrootmode="open">
<div id="innerPopover" popover>
Inner
</div>
</template>
</div>
</template>
</div>
<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="resources/popover-utils.js"></script>
<script>
promise_test(async () => {
const innerPopoverToggle = outerPopover.shadowRoot.querySelector("#innerPopoverToggle");
const innerContainer = outerPopover.shadowRoot.querySelector('#innerContainer');
const innerPopover = innerContainer.shadowRoot.querySelector("#innerPopover");
innerPopoverToggle.onclick = () => {
innerPopover.togglePopover();
}
assert_false(outerPopover.matches(":popover-open"), "outer popover is initially hidden");
assert_false(innerPopover.matches(":popover-open"), "inner popover is initially hidden");
await clickOn(outerPopoverToggle);
assert_true(outerPopover.matches(":popover-open"), "outer popover is open after clicking the toggle");
assert_false(innerPopover.matches(":popover-open"), "inner popover is initially hidden");
await clickOn(innerPopoverToggle);
assert_true(outerPopover.matches(":popover-open"), "outer popover is not dismissed after clicking the second toggle");
assert_true(innerPopover.matches(":popover-open"), "inner popover is open after clicking the second toggle");
}, "Popover light dismiss uses the flat tree when nested shadow root");
</script>
</body>
</html>
|