@lynx-js/testing-environment 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/README.md +72 -0
- package/dist/env/vitest/index.cjs +55 -0
- package/dist/env/vitest/index.d.ts +8 -0
- package/dist/env/vitest/index.js +21 -0
- package/dist/index.cjs +329 -0
- package/dist/index.d.ts +114 -0
- package/dist/index.js +283 -0
- package/dist/lynx/ElementPAPI.cjs +264 -0
- package/dist/lynx/ElementPAPI.d.ts +110 -0
- package/dist/lynx/ElementPAPI.js +230 -0
- package/dist/lynx/GlobalThis.cjs +49 -0
- package/dist/lynx/GlobalThis.d.ts +13 -0
- package/dist/lynx/GlobalThis.js +15 -0
- package/dist/util.cjs +41 -0
- package/dist/util.d.ts +8 -0
- package/dist/util.js +7 -0
- package/package.json +58 -0
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
function _define_property(obj, key, value) {
|
|
2
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
3
|
+
value: value,
|
|
4
|
+
enumerable: true,
|
|
5
|
+
configurable: true,
|
|
6
|
+
writable: true
|
|
7
|
+
});
|
|
8
|
+
else obj[key] = value;
|
|
9
|
+
return obj;
|
|
10
|
+
}
|
|
11
|
+
const initElementTree = ()=>{
|
|
12
|
+
let uiSignNext = 0;
|
|
13
|
+
const uniqueId2Element = new Map();
|
|
14
|
+
return new class {
|
|
15
|
+
countElement(element, parentComponentUniqueId) {
|
|
16
|
+
element.$$uiSign = uiSignNext++;
|
|
17
|
+
uniqueId2Element.set(element.$$uiSign, element);
|
|
18
|
+
element.parentComponentUniqueId = parentComponentUniqueId;
|
|
19
|
+
}
|
|
20
|
+
__CreatePage(_tag, parentComponentUniqueId) {
|
|
21
|
+
const page = this.__CreateElement('page', parentComponentUniqueId);
|
|
22
|
+
this.root = page;
|
|
23
|
+
lynxTestingEnv.jsdom.window.document.body.appendChild(page);
|
|
24
|
+
return page;
|
|
25
|
+
}
|
|
26
|
+
__CreateRawText(text) {
|
|
27
|
+
const element = lynxTestingEnv.jsdom.window.document.createTextNode(text);
|
|
28
|
+
this.countElement(element, 0);
|
|
29
|
+
return element;
|
|
30
|
+
}
|
|
31
|
+
__GetElementUniqueID(e) {
|
|
32
|
+
return e.$$uiSign;
|
|
33
|
+
}
|
|
34
|
+
__SetClasses(e, cls) {
|
|
35
|
+
e.className = cls;
|
|
36
|
+
}
|
|
37
|
+
__CreateElement(tag, parentComponentUniqueId) {
|
|
38
|
+
if ('raw-text' === tag) return this.__CreateRawText('');
|
|
39
|
+
const element = lynxTestingEnv.jsdom.window.document.createElement(tag);
|
|
40
|
+
this.countElement(element, parentComponentUniqueId);
|
|
41
|
+
return element;
|
|
42
|
+
}
|
|
43
|
+
__CreateView(parentComponentUniqueId) {
|
|
44
|
+
return this.__CreateElement('view', parentComponentUniqueId);
|
|
45
|
+
}
|
|
46
|
+
__CreateScrollView(parentComponentUniqueId) {
|
|
47
|
+
return this.__CreateElement('scroll-view', parentComponentUniqueId);
|
|
48
|
+
}
|
|
49
|
+
__FirstElement(e) {
|
|
50
|
+
return e.firstChild;
|
|
51
|
+
}
|
|
52
|
+
__CreateText(parentComponentUniqueId) {
|
|
53
|
+
return this.__CreateElement('text', parentComponentUniqueId);
|
|
54
|
+
}
|
|
55
|
+
__CreateImage(parentComponentUniqueId) {
|
|
56
|
+
return this.__CreateElement('image', parentComponentUniqueId);
|
|
57
|
+
}
|
|
58
|
+
__CreateWrapperElement(parentComponentUniqueId) {
|
|
59
|
+
return this.__CreateElement('wrapper', parentComponentUniqueId);
|
|
60
|
+
}
|
|
61
|
+
__AddInlineStyle(e, key, value) {
|
|
62
|
+
e.style[key] = value;
|
|
63
|
+
}
|
|
64
|
+
__AppendElement(parent, child) {
|
|
65
|
+
parent.appendChild(child);
|
|
66
|
+
}
|
|
67
|
+
__SetCSSId(e, id, entryName) {
|
|
68
|
+
const cssId = `${entryName ?? '__Card__'}:${id}`;
|
|
69
|
+
if (Array.isArray(e)) e.forEach((item)=>{
|
|
70
|
+
item.cssId = cssId;
|
|
71
|
+
});
|
|
72
|
+
else e.cssId = cssId;
|
|
73
|
+
}
|
|
74
|
+
__SetAttribute(e, key, value) {
|
|
75
|
+
if ('style' === key || 'class' === key || 'className' === key || 'key' === key || 'id' === key || 'ref' === key || /^data-/.exec(key) || /^(bind|catch|global-bind|capture-bind|capture-catch)[A-Za-z]/.exec(key)) throw new Error(`Cannot use __SetAttribute for "${key}"`);
|
|
76
|
+
if ('update-list-info' === key) {
|
|
77
|
+
let listInfoStr = e.getAttribute(key);
|
|
78
|
+
let listInfo = listInfoStr ? JSON.parse(listInfoStr) : [];
|
|
79
|
+
listInfo.push(value);
|
|
80
|
+
e.setAttribute(key, JSON.stringify(listInfo));
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
if ('text' === key) {
|
|
84
|
+
e.textContent = value;
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (null === value) return void e.removeAttribute(key);
|
|
88
|
+
if ('string' == typeof value) return void e.setAttribute(key, value);
|
|
89
|
+
e.setAttribute(key, JSON.stringify(value));
|
|
90
|
+
}
|
|
91
|
+
__AddEvent(e, eventType, eventName, eventHandler) {
|
|
92
|
+
var _e_eventMap;
|
|
93
|
+
if (null == (_e_eventMap = e.eventMap) ? void 0 : _e_eventMap[`${eventType}:${eventName}`]) {
|
|
94
|
+
e.removeEventListener(`${eventType}:${eventName}`, e.eventMap[`${eventType}:${eventName}`]);
|
|
95
|
+
delete e.eventMap[`${eventType}:${eventName}`];
|
|
96
|
+
}
|
|
97
|
+
if (void 0 === eventHandler) return;
|
|
98
|
+
if ('string' != typeof eventHandler && void 0 === eventHandler['type']) throw new Error(`event must be string, but got ${typeof eventHandler}`);
|
|
99
|
+
const listener = (evt)=>{
|
|
100
|
+
if ('object' == typeof eventHandler && 'worklet' === eventHandler['type']) {
|
|
101
|
+
const isBackground = !__MAIN_THREAD__;
|
|
102
|
+
globalThis.lynxTestingEnv.switchToMainThread();
|
|
103
|
+
runWorklet(eventHandler.value, [
|
|
104
|
+
Object.assign({}, evt)
|
|
105
|
+
]);
|
|
106
|
+
if (isBackground) globalThis.lynxTestingEnv.switchToBackgroundThread();
|
|
107
|
+
} else {
|
|
108
|
+
if ('catchEvent' === eventType || 'capture-catch' === eventType) evt.stopPropagation();
|
|
109
|
+
globalThis.lynxCoreInject.tt.publishEvent(eventHandler, evt);
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
e.eventMap = e.eventMap ?? {};
|
|
113
|
+
e.eventMap[`${eventType}:${eventName}`] = listener;
|
|
114
|
+
e.addEventListener(`${eventType}:${eventName}`, listener, {
|
|
115
|
+
capture: 'capture-bind' === eventType || 'capture-catch' === eventType
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
__GetEvent(e, eventType, eventName) {
|
|
119
|
+
var _e_eventMap;
|
|
120
|
+
const jsFunction = null == (_e_eventMap = e.eventMap) ? void 0 : _e_eventMap[`${eventType}:${eventName}`];
|
|
121
|
+
if (void 0 !== jsFunction) return {
|
|
122
|
+
type: eventType,
|
|
123
|
+
name: eventName,
|
|
124
|
+
jsFunction
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
__SetID(e, id) {
|
|
128
|
+
e.id = id;
|
|
129
|
+
}
|
|
130
|
+
__SetInlineStyles(e, styles) {
|
|
131
|
+
if ('string' == typeof styles) e.style.cssText = styles;
|
|
132
|
+
else Object.assign(e.style, styles);
|
|
133
|
+
}
|
|
134
|
+
__AddDataset(e, key, value) {
|
|
135
|
+
e.dataset[key] = value;
|
|
136
|
+
}
|
|
137
|
+
__SetDataset(e, dataset) {
|
|
138
|
+
Object.assign(e.dataset, dataset);
|
|
139
|
+
}
|
|
140
|
+
__SetGestureDetector(e, id, type, config, relationMap) {
|
|
141
|
+
e.gesture = {
|
|
142
|
+
id,
|
|
143
|
+
type,
|
|
144
|
+
config,
|
|
145
|
+
relationMap
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
__GetDataset(e) {
|
|
149
|
+
return e.dataset;
|
|
150
|
+
}
|
|
151
|
+
__RemoveElement(parent, child) {
|
|
152
|
+
let ch = parent.firstChild;
|
|
153
|
+
while(ch)if (ch === child) {
|
|
154
|
+
parent.removeChild(ch);
|
|
155
|
+
break;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
__InsertElementBefore(parent, child, ref) {
|
|
159
|
+
if (void 0 === ref) parent.appendChild(child);
|
|
160
|
+
else parent.insertBefore(child, ref);
|
|
161
|
+
}
|
|
162
|
+
__ReplaceElement(newElement, oldElement) {
|
|
163
|
+
const parent = oldElement.parentNode;
|
|
164
|
+
if (!parent) throw new Error('unreachable');
|
|
165
|
+
parent.replaceChild(newElement, oldElement);
|
|
166
|
+
}
|
|
167
|
+
__FlushElementTree() {}
|
|
168
|
+
__UpdateListComponents(_list, _components) {}
|
|
169
|
+
__UpdateListCallbacks(list, componentAtIndex, enqueueComponent) {
|
|
170
|
+
Object.defineProperties(list, {
|
|
171
|
+
componentAtIndex: {
|
|
172
|
+
enumerable: false,
|
|
173
|
+
configurable: true,
|
|
174
|
+
value: componentAtIndex
|
|
175
|
+
},
|
|
176
|
+
enqueueComponent: {
|
|
177
|
+
enumerable: false,
|
|
178
|
+
configurable: true,
|
|
179
|
+
value: enqueueComponent
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
__CreateList(parentComponentUniqueId, componentAtIndex, enqueueComponent) {
|
|
184
|
+
const e = this.__CreateElement('list', parentComponentUniqueId);
|
|
185
|
+
Object.defineProperties(e, {
|
|
186
|
+
componentAtIndex: {
|
|
187
|
+
enumerable: false,
|
|
188
|
+
configurable: true,
|
|
189
|
+
value: componentAtIndex
|
|
190
|
+
},
|
|
191
|
+
enqueueComponent: {
|
|
192
|
+
enumerable: false,
|
|
193
|
+
configurable: true,
|
|
194
|
+
value: enqueueComponent
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
return e;
|
|
198
|
+
}
|
|
199
|
+
__GetTag(ele) {
|
|
200
|
+
return ele.nodeName;
|
|
201
|
+
}
|
|
202
|
+
__GetAttributeByName(ele, name) {
|
|
203
|
+
return ele.getAttribute(name);
|
|
204
|
+
}
|
|
205
|
+
clear() {
|
|
206
|
+
this.root = void 0;
|
|
207
|
+
}
|
|
208
|
+
toTree() {
|
|
209
|
+
return this.root;
|
|
210
|
+
}
|
|
211
|
+
enterListItemAtIndex(e, index, ...args) {
|
|
212
|
+
const { componentAtIndex, $$uiSign } = e;
|
|
213
|
+
return componentAtIndex(e, $$uiSign, index, ...args);
|
|
214
|
+
}
|
|
215
|
+
leaveListItem(e, uiSign) {
|
|
216
|
+
const { enqueueComponent, $$uiSign } = e;
|
|
217
|
+
enqueueComponent(e, $$uiSign, uiSign);
|
|
218
|
+
}
|
|
219
|
+
toJSON() {
|
|
220
|
+
return this.toTree();
|
|
221
|
+
}
|
|
222
|
+
__GetElementByUniqueId(uniqueId) {
|
|
223
|
+
return uniqueId2Element.get(uniqueId);
|
|
224
|
+
}
|
|
225
|
+
constructor(){
|
|
226
|
+
_define_property(this, "root", void 0);
|
|
227
|
+
}
|
|
228
|
+
}();
|
|
229
|
+
};
|
|
230
|
+
export { initElementTree };
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
createGlobalThis: ()=>createGlobalThis
|
|
28
|
+
});
|
|
29
|
+
const external_util_cjs_namespaceObject = require("../util.cjs");
|
|
30
|
+
function installOwnProperties(globalThis) {
|
|
31
|
+
(0, external_util_cjs_namespaceObject.define)(globalThis, {
|
|
32
|
+
get globalThis () {
|
|
33
|
+
return globalThis._globalProxy;
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
const createGlobalThis = ()=>{
|
|
38
|
+
const globalThis = {};
|
|
39
|
+
globalThis._globalObject = globalThis._globalProxy = globalThis;
|
|
40
|
+
installOwnProperties(globalThis);
|
|
41
|
+
return globalThis;
|
|
42
|
+
};
|
|
43
|
+
exports.createGlobalThis = __webpack_exports__.createGlobalThis;
|
|
44
|
+
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
45
|
+
"createGlobalThis"
|
|
46
|
+
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
47
|
+
Object.defineProperty(exports, '__esModule', {
|
|
48
|
+
value: true
|
|
49
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare const createGlobalThis: () => LynxGlobalThis;
|
|
2
|
+
/**
|
|
3
|
+
* The `globalThis` object of Lynx dual thread environment.
|
|
4
|
+
*
|
|
5
|
+
* @public
|
|
6
|
+
*/
|
|
7
|
+
export interface LynxGlobalThis {
|
|
8
|
+
/**
|
|
9
|
+
* The globalThis object.
|
|
10
|
+
*/
|
|
11
|
+
globalThis: LynxGlobalThis;
|
|
12
|
+
[key: string]: any;
|
|
13
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as __WEBPACK_EXTERNAL_MODULE__util_js_1dab4bad__ from "../util.js";
|
|
2
|
+
function installOwnProperties(globalThis) {
|
|
3
|
+
(0, __WEBPACK_EXTERNAL_MODULE__util_js_1dab4bad__.define)(globalThis, {
|
|
4
|
+
get globalThis () {
|
|
5
|
+
return globalThis._globalProxy;
|
|
6
|
+
}
|
|
7
|
+
});
|
|
8
|
+
}
|
|
9
|
+
const createGlobalThis = ()=>{
|
|
10
|
+
const globalThis = {};
|
|
11
|
+
globalThis._globalObject = globalThis._globalProxy = globalThis;
|
|
12
|
+
installOwnProperties(globalThis);
|
|
13
|
+
return globalThis;
|
|
14
|
+
};
|
|
15
|
+
export { createGlobalThis };
|
package/dist/util.cjs
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
define: ()=>define
|
|
28
|
+
});
|
|
29
|
+
function define(object, properties) {
|
|
30
|
+
for (const name of Object.getOwnPropertyNames(properties)){
|
|
31
|
+
const propDesc = Object.getOwnPropertyDescriptor(properties, name);
|
|
32
|
+
Object.defineProperty(object, name, propDesc);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.define = __webpack_exports__.define;
|
|
36
|
+
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
37
|
+
"define"
|
|
38
|
+
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
39
|
+
Object.defineProperty(exports, '__esModule', {
|
|
40
|
+
value: true
|
|
41
|
+
});
|
package/dist/util.d.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Define a set of properties on an object, by copying the property descriptors
|
|
3
|
+
* from the original object.
|
|
4
|
+
*
|
|
5
|
+
* - `object` {Object} the target object
|
|
6
|
+
* - `properties` {Object} the source from which to copy property descriptors
|
|
7
|
+
*/
|
|
8
|
+
export declare function define(object: any, properties: any): void;
|
package/dist/util.js
ADDED
package/package.json
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@lynx-js/testing-environment",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "A subset of a Lynx environment to be useful for testing",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"Lynx",
|
|
7
|
+
"ReactLynx",
|
|
8
|
+
"testing"
|
|
9
|
+
],
|
|
10
|
+
"repository": {
|
|
11
|
+
"type": "git",
|
|
12
|
+
"url": "https://github.com/lynx-family/lynx-stack.git",
|
|
13
|
+
"directory": "packages/testing-library/test-environment"
|
|
14
|
+
},
|
|
15
|
+
"license": "Apache-2.0",
|
|
16
|
+
"author": {
|
|
17
|
+
"name": "Yiming Li",
|
|
18
|
+
"email": "yimingli.cs@gmail.com"
|
|
19
|
+
},
|
|
20
|
+
"type": "module",
|
|
21
|
+
"exports": {
|
|
22
|
+
".": {
|
|
23
|
+
"types": "./dist/index.d.ts",
|
|
24
|
+
"import": "./dist/index.js",
|
|
25
|
+
"require": "./dist/index.cjs",
|
|
26
|
+
"default": "./dist/index.js"
|
|
27
|
+
},
|
|
28
|
+
"./env/vitest": {
|
|
29
|
+
"types": "./dist/env/vitest/index.d.ts",
|
|
30
|
+
"import": "./dist/env/vitest/index.js",
|
|
31
|
+
"require": "./dist/env/vitest/index.cjs",
|
|
32
|
+
"default": "./dist/env/vitest/index.js"
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
"main": "./dist/index.cjs",
|
|
36
|
+
"module": "./dist/index.js",
|
|
37
|
+
"types": "./dist/index.d.ts",
|
|
38
|
+
"typesVersions": {
|
|
39
|
+
"*": {
|
|
40
|
+
"env/vitest": [
|
|
41
|
+
"./dist/env/vitest/index.d.ts"
|
|
42
|
+
]
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
"files": [
|
|
46
|
+
"dist"
|
|
47
|
+
],
|
|
48
|
+
"devDependencies": {
|
|
49
|
+
"@testing-library/jest-dom": "^6.6.3",
|
|
50
|
+
"@types/jsdom": "^21.1.7",
|
|
51
|
+
"rsbuild-plugin-publint": "0.3.1"
|
|
52
|
+
},
|
|
53
|
+
"scripts": {
|
|
54
|
+
"api-extractor": "api-extractor run --verbose",
|
|
55
|
+
"build": "rslib build",
|
|
56
|
+
"dev": "rslib build --watch"
|
|
57
|
+
}
|
|
58
|
+
}
|