Skip to content

Commit

Permalink
Fix connectedCallback with document fragments
Browse files Browse the repository at this point in the history
This regressed in 1f5acae. Closes #3290.

Co-authored-by: Domenic Denicola <d@domenic.me>
  • Loading branch information
GrantGryczan and domenic committed Nov 21, 2021
1 parent 79ff734 commit 15cbed6
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/jsdom/living/nodes/Node-impl.js
Original file line number Diff line number Diff line change
Expand Up @@ -838,7 +838,7 @@ class NodeImpl extends EventTargetImpl {
this._descendantAdded(this, node);

if (isConnected === undefined) {
isConnected = nodeImpl.isConnected;
isConnected = node.isConnected;
}

if (isConnected) {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,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>

0 comments on commit 15cbed6

Please sign in to comment.