summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/custom-elements/connected-callbacks-template.html
blob: ed404332dbd8b675e02cbc5448873bcee1114744 (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
<!DOCTYPE html>
<meta charset="utf-8">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<!-- Regression test for https://github.com/jsdom/jsdom/issues/3290 -->

<body>
<script>
"use strict";

test(() => {
  let innerConnectedCallbackCalled = false;
  customElements.define("inner-element", class extends HTMLElement {
    connectedCallback() {
      innerConnectedCallbackCalled = true;
    }
  });

  let outerConnectedCallbackCalled = false;
  customElements.define("outer-element", class extends HTMLElement {
    connectedCallback() {
      const template = document.createElement("template");
      template.innerHTML = "<inner-element></inner-element>";
      this.appendChild(document.importNode(template.content, true));
      outerConnectedCallbackCalled = true;
    }
  });

  document.body.appendChild(document.createElement("outer-element"));
  assert_true(innerConnectedCallbackCalled, "inner connectedCallback must be called");
  assert_true(outerConnectedCallbackCalled, "outer connectedCallback must be called");
}, "Nested custom element connectedCallback insertion involving a template DocumentFragment");
</script>