-
Notifications
You must be signed in to change notification settings - Fork 439
Expand file tree
/
Copy pathindex.spec.js
More file actions
93 lines (79 loc) · 3.38 KB
/
index.spec.js
File metadata and controls
93 lines (79 loc) · 3.38 KB
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
import { createElement } from 'lwc';
import Component from 'x/component';
import Parent from 'x/parent';
import Light from 'x/light';
import { jasmine } from '../../../helpers/jasmine.js';
import {
attachReportingControlDispatcher,
detachReportingControlDispatcher,
} from '../../../helpers/reporting-control.js';
// Should be kept in sync with the enum in vm.ts
const ShadowMode = {
Native: 0,
Synthetic: 1,
};
describe('ShadowModeUsage', () => {
let dispatcher;
beforeEach(() => {
dispatcher = jasmine.createSpy();
attachReportingControlDispatcher(dispatcher, ['ShadowModeUsage']);
});
afterEach(() => {
detachReportingControlDispatcher();
});
it('should report the shadow mode for the rendered component', () => {
const element = createElement('x-component', { is: Component });
document.body.appendChild(element);
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'x-component',
mode: process.env.NATIVE_SHADOW ? ShadowMode.Native : ShadowMode.Synthetic,
});
});
it('should report the shadow mode for all rendered components', () => {
const element = createElement('x-parent', { is: Parent });
document.body.appendChild(element);
expect(dispatcher).toHaveBeenCalledTimes(3);
// x-parent depends on environment
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'x-parent',
mode: process.env.NATIVE_SHADOW ? ShadowMode.Native : ShadowMode.Synthetic,
});
// x-native should be set to native always
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'x-native',
mode: ShadowMode.Native,
});
// x-component depends on environment
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'x-component',
mode: process.env.NATIVE_SHADOW ? ShadowMode.Native : ShadowMode.Synthetic,
});
});
it('should report the shadow mode for components when created using CustomElementConstructor', () => {
const ParentCustomElement = Parent.CustomElementConstructor;
customElements.define('x-parent-custom-element', ParentCustomElement);
const element = document.createElement('x-parent-custom-element');
document.body.appendChild(element);
expect(dispatcher).toHaveBeenCalledTimes(3);
// x-parent depends on environment
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'X-PARENT-CUSTOM-ELEMENT',
mode: process.env.NATIVE_SHADOW ? ShadowMode.Native : ShadowMode.Synthetic,
});
// x-native should be set to native always
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'x-native',
mode: ShadowMode.Native,
});
// x-component depends on environment
expect(dispatcher).toHaveBeenCalledWith('ShadowModeUsage', {
tagName: 'x-component',
mode: process.env.NATIVE_SHADOW ? ShadowMode.Native : ShadowMode.Synthetic,
});
});
it('should report no shadow mode for light DOM components', () => {
const element = createElement('x-light', { is: Light });
document.body.appendChild(element);
expect(dispatcher).toHaveBeenCalledTimes(0);
});
});