summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/shadow-dom/focus/focus-method-delegatesFocus-nested-browsing-context.html
blob: d2724f17d52b93912544cda8a44aae7017918ac9 (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
<!DOCTYPE html>
<meta charset="utf-8">
<title>HTML Test: focus() on shadow host within an iframe with delegatesFocus</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<body>
<script>
test(() => {
  const iframe = document.createElement("iframe");
  document.body.appendChild(iframe);
  iframe.addEventListener("load", () => {
    iframe.contentDocument.body.innerHTML =
            `<div id="host"></div>`;
    const host = iframe.contentDocument.getElementById("host");
    const firstInput = iframe.contentDocument.createElement("input");
    const secondInput = iframe.contentDocument.createElement("input");

    host.attachShadow({mode: 'open', delegatesFocus: true});
    host.shadowRoot.appendChild(firstInput);
    host.shadowRoot.appendChild(secondInput);

    iframe.contentDocument.body.appendChild(host);

    secondInput.focus();
    assert_equals(host.shadowRoot.activeElement, secondInput);

    // host is a shadow-including-ancestor of secondInput, so
    // the focus should remain secondInput.
    host.focus();
    assert_equals(host.shadowRoot.activeElement, secondInput);
  });
}, "focus delegate step should not be run when the focus target is a shadow-including inclusive ancestor of the current focus.");
</script>
</body>