File: element-mutation.html

package info (click to toggle)
firefox 147.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,324 kB
  • sloc: cpp: 7,607,156; javascript: 6,532,492; ansic: 3,775,158; python: 1,415,368; xml: 634,556; asm: 438,949; java: 186,241; sh: 62,751; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (70 lines) | stat: -rw-r--r-- 2,931 bytes parent folder | download | duplicates (2)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
<!DOCTYPE html>
<title>Tests the registry assignment during element mutation</title>
<meta name="author" title="Jayson Chen" href="mailto:jaysonchen@microsoft.com"></meta>
<link rel="help" href="https://wicg.github.io/webcomponents/proposals/Scoped-Custom-Element-Registries">
<link rel="help" href="https://github.com/WICG/webcomponents/issues/923">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>

<body>
<div id="host">
    <div id="shadow-host-1">
        <template shadowrootmode="open" shadowrootclonable="true" shadowrootcustomelementregistry>
            <div id="shadow-host-1-child"></div>
        </template>
    </div>
    <div id="shadow-host-2">
        <template shadowrootmode="open" shadowrootclonable="true" shadowrootcustomelementregistry>
            <div id="shadow-host-2-child"></div>
        </template>
    </div>
</div>

<script>

test(() => {
    const registry = new CustomElementRegistry;

    const element = document.createElement('new-element');
    assert_equals(element.customElementRegistry, window.customElements);

    document.body.appendChild(element);
    const shadow = document.createElement('div').attachShadow({mode: 'open', customElementRegistry: registry})
    shadow.appendChild(element)
    assert_not_equals(element.customElementRegistry, registry);

    document.body.appendChild(element)
    assert_equals(element.customElementRegistry, window.customElements);
}, "An element with global registry should not change its registry when moved into a shadow tree with scoped registry.")

test(() => {
    const clone = host.cloneNode(true);
    const shadowRoot1 = clone.querySelector('#shadow-host-1').shadowRoot;
    const element = shadowRoot1.querySelector('#shadow-host-1-child');

    const registry1 = new CustomElementRegistry;
    registry1.initialize(shadowRoot1);
    assert_equals(element.customElementRegistry, registry1);

    document.querySelector('#host').appendChild(element);
    assert_equals(element.customElementRegistry, registry1);
}, "An element with scoped registry should not change its registry when moved out of the shadow tree.")

test(() => {
    const clone = host.cloneNode(true);
    const shadowRoot1 = clone.querySelector('#shadow-host-1').shadowRoot;
    const shadowRoot2 = clone.querySelector('#shadow-host-2').shadowRoot;
    const element = shadowRoot1.querySelector('#shadow-host-1-child');

    const registry1 = new CustomElementRegistry;
    const registry2 = new CustomElementRegistry;
    registry1.initialize(shadowRoot1);
    registry2.initialize(shadowRoot2);
    assert_equals(element.customElementRegistry, registry1);

    shadowRoot2.appendChild(element);
    assert_equals(element.customElementRegistry, registry1);
}, "An element with scoped registry should not change its registry when moved into another shadow tree with different scoped registry.")

</script>
</body>