@apia/testing 1.0.4 → 2.0.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/dist/TestComponent.d.ts +24 -0
- package/dist/TestComponent.d.ts.map +1 -0
- package/dist/TestComponent.js +84 -0
- package/dist/TestComponent.js.map +1 -0
- package/dist/TestsLogger.d.ts +16 -0
- package/dist/TestsLogger.d.ts.map +1 -0
- package/dist/TestsLogger.js +130 -0
- package/dist/TestsLogger.js.map +1 -0
- package/dist/index.d.ts +66 -94
- package/dist/index.js +33 -288
- package/dist/index.js.map +1 -1
- package/package.json +18 -29
- package/LICENSE.md +0 -21
- package/README.md +0 -28
- package/cleanDist.json +0 -3
- package/entries.json +0 -1
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { FC } from 'react';
|
|
3
|
+
import { EventEmitter } from '@apia/util';
|
|
4
|
+
import { Test } from './index.js';
|
|
5
|
+
|
|
6
|
+
declare class TestComponent<T extends Record<string, unknown>> extends EventEmitter<{
|
|
7
|
+
update: {
|
|
8
|
+
id: string;
|
|
9
|
+
props: Partial<T>;
|
|
10
|
+
};
|
|
11
|
+
updated: string;
|
|
12
|
+
}> {
|
|
13
|
+
#private;
|
|
14
|
+
private name;
|
|
15
|
+
private test;
|
|
16
|
+
id: string;
|
|
17
|
+
Component: react.ForwardRefExoticComponent<react.RefAttributes<object>>;
|
|
18
|
+
constructor(name: string, test: Test, component: FC<T>, initialProps: T);
|
|
19
|
+
unmount: () => void;
|
|
20
|
+
updateProps(newProps: Partial<T>): Promise<void>;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export { TestComponent };
|
|
24
|
+
//# sourceMappingURL=TestComponent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestComponent.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { forwardRef, useState, useEffect } from 'react';
|
|
3
|
+
import { EventEmitter, useMount } from '@apia/util';
|
|
4
|
+
|
|
5
|
+
var __defProp = Object.defineProperty;
|
|
6
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
7
|
+
var __publicField = (obj, key, value) => {
|
|
8
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
9
|
+
return value;
|
|
10
|
+
};
|
|
11
|
+
var __accessCheck = (obj, member, msg) => {
|
|
12
|
+
if (!member.has(obj))
|
|
13
|
+
throw TypeError("Cannot " + msg);
|
|
14
|
+
};
|
|
15
|
+
var __privateGet = (obj, member, getter) => {
|
|
16
|
+
__accessCheck(obj, member, "read from private field");
|
|
17
|
+
return getter ? getter.call(obj) : member.get(obj);
|
|
18
|
+
};
|
|
19
|
+
var __privateAdd = (obj, member, value) => {
|
|
20
|
+
if (member.has(obj))
|
|
21
|
+
throw TypeError("Cannot add the same private member more than once");
|
|
22
|
+
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
23
|
+
};
|
|
24
|
+
var __privateSet = (obj, member, value, setter) => {
|
|
25
|
+
__accessCheck(obj, member, "write to private field");
|
|
26
|
+
setter ? setter.call(obj, value) : member.set(obj, value);
|
|
27
|
+
return value;
|
|
28
|
+
};
|
|
29
|
+
var _component, _props;
|
|
30
|
+
let maxId = 0;
|
|
31
|
+
let maxUpdateId = 0;
|
|
32
|
+
class TestComponent extends EventEmitter {
|
|
33
|
+
constructor(name, test, component, initialProps) {
|
|
34
|
+
super();
|
|
35
|
+
this.name = name;
|
|
36
|
+
this.test = test;
|
|
37
|
+
__privateAdd(this, _component, void 0);
|
|
38
|
+
__privateAdd(this, _props, void 0);
|
|
39
|
+
__publicField(this, "id", `component__${maxId++}`);
|
|
40
|
+
__publicField(this, "Component", forwardRef((_, ref) => {
|
|
41
|
+
const [props, setProps] = useState(__privateGet(this, _props));
|
|
42
|
+
const [lastUpdateId, setLastUpdateId] = useState("");
|
|
43
|
+
const Render = __privateGet(this, _component);
|
|
44
|
+
useMount(() => {
|
|
45
|
+
const suscription = this.on("update", (ev) => {
|
|
46
|
+
setProps((current) => ({ ...current, ...ev.props }));
|
|
47
|
+
setLastUpdateId(ev.id);
|
|
48
|
+
});
|
|
49
|
+
ref({});
|
|
50
|
+
return suscription;
|
|
51
|
+
});
|
|
52
|
+
useEffect(() => {
|
|
53
|
+
setTimeout(() => {
|
|
54
|
+
this.emit("updated", lastUpdateId);
|
|
55
|
+
}, 0);
|
|
56
|
+
}, [lastUpdateId]);
|
|
57
|
+
return /* @__PURE__ */ jsx("div", { id: this.name, children: /* @__PURE__ */ jsx(Render, { ...props }) });
|
|
58
|
+
}));
|
|
59
|
+
__publicField(this, "unmount", () => {
|
|
60
|
+
this.test.unmount(this);
|
|
61
|
+
});
|
|
62
|
+
__privateSet(this, _component, component);
|
|
63
|
+
__privateSet(this, _props, initialProps);
|
|
64
|
+
}
|
|
65
|
+
updateProps(newProps) {
|
|
66
|
+
return new Promise((resolve) => {
|
|
67
|
+
const updateId = `update${maxUpdateId++}`;
|
|
68
|
+
const unsuscribe = this.on("updated", (ev) => {
|
|
69
|
+
if (ev === updateId) {
|
|
70
|
+
unsuscribe();
|
|
71
|
+
resolve();
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
setTimeout(() => {
|
|
75
|
+
this.emit("update", { id: updateId, props: newProps });
|
|
76
|
+
}, 0);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
_component = new WeakMap();
|
|
81
|
+
_props = new WeakMap();
|
|
82
|
+
|
|
83
|
+
export { TestComponent };
|
|
84
|
+
//# sourceMappingURL=TestComponent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestComponent.js","sources":["../src/TestComponent.tsx"],"sourcesContent":["import { FC, RefCallback, forwardRef, useEffect, useState } from 'react';\nimport { EventEmitter, useMount } from '@apia/util';\nimport { Test } from '.';\n\nlet maxId = 0;\nlet maxUpdateId = 0;\n\nexport class TestComponent<\n T extends Record<string, unknown>,\n> extends EventEmitter<{\n update: { id: string; props: Partial<T> };\n updated: string;\n}> {\n #component: FC<T>;\n #props: T;\n\n id = `component__${maxId++}`;\n\n Component = forwardRef<object>((_, ref) => {\n const [props, setProps] = useState(this.#props);\n const [lastUpdateId, setLastUpdateId] = useState('');\n\n const Render = this.#component;\n\n useMount(() => {\n const suscription = this.on('update', (ev) => {\n setProps((current) => ({ ...current, ...ev.props }));\n setLastUpdateId(ev.id);\n });\n\n (ref as RefCallback<object>)({});\n\n return suscription;\n });\n\n useEffect(() => {\n setTimeout(() => {\n this.emit('updated', lastUpdateId);\n }, 0);\n }, [lastUpdateId]);\n\n return (\n <div id={this.name}>\n <Render {...props} />\n </div>\n );\n });\n\n constructor(\n private name: string,\n private test: Test,\n component: FC<T>,\n initialProps: T,\n ) {\n super();\n\n this.#component = component;\n this.#props = initialProps;\n }\n\n unmount = () => {\n this.test.unmount(this);\n };\n\n updateProps(newProps: Partial<T>) {\n return new Promise<void>((resolve) => {\n const updateId = `update${maxUpdateId++}`;\n const unsuscribe = this.on('updated', (ev) => {\n if (ev === updateId) {\n unsuscribe();\n resolve();\n }\n });\n setTimeout(() => {\n this.emit('update', { id: updateId, props: newProps });\n }, 0);\n });\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
type TLogType = 'error' | 'info' | 'success' | 'title' | 'warn';
|
|
2
|
+
declare abstract class TestsLogger {
|
|
3
|
+
abstract error(message: string): void;
|
|
4
|
+
abstract info(message: string): void;
|
|
5
|
+
abstract report(): void;
|
|
6
|
+
abstract success(message: string): void;
|
|
7
|
+
abstract title(message: string): void;
|
|
8
|
+
abstract warn(message: string): void;
|
|
9
|
+
/**
|
|
10
|
+
* Establece qué niveles se muestran y qué niveles no.
|
|
11
|
+
*/
|
|
12
|
+
abstract setDebugLevels(levels: Partial<Record<TLogType, boolean>>): void;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export { type TLogType, TestsLogger };
|
|
16
|
+
//# sourceMappingURL=TestsLogger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestsLogger.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
+
var __publicField = (obj, key, value) => {
|
|
4
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
+
return value;
|
|
6
|
+
};
|
|
7
|
+
var __accessCheck = (obj, member, msg) => {
|
|
8
|
+
if (!member.has(obj))
|
|
9
|
+
throw TypeError("Cannot " + msg);
|
|
10
|
+
};
|
|
11
|
+
var __privateGet = (obj, member, getter) => {
|
|
12
|
+
__accessCheck(obj, member, "read from private field");
|
|
13
|
+
return getter ? getter.call(obj) : member.get(obj);
|
|
14
|
+
};
|
|
15
|
+
var __privateAdd = (obj, member, value) => {
|
|
16
|
+
if (member.has(obj))
|
|
17
|
+
throw TypeError("Cannot add the same private member more than once");
|
|
18
|
+
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
19
|
+
};
|
|
20
|
+
var __privateSet = (obj, member, value, setter) => {
|
|
21
|
+
__accessCheck(obj, member, "write to private field");
|
|
22
|
+
setter ? setter.call(obj, value) : member.set(obj, value);
|
|
23
|
+
return value;
|
|
24
|
+
};
|
|
25
|
+
var _reports, _levels, _log;
|
|
26
|
+
class TestsLogger {
|
|
27
|
+
}
|
|
28
|
+
class ConsoleTestsLogger extends TestsLogger {
|
|
29
|
+
constructor() {
|
|
30
|
+
super();
|
|
31
|
+
__publicField(this, "colors", {
|
|
32
|
+
error: "#f77",
|
|
33
|
+
info: "lightblue",
|
|
34
|
+
success: "lightgreen",
|
|
35
|
+
title: "white",
|
|
36
|
+
warn: "yellow"
|
|
37
|
+
});
|
|
38
|
+
__privateAdd(this, _reports, []);
|
|
39
|
+
__privateAdd(this, _levels, {
|
|
40
|
+
error: true,
|
|
41
|
+
info: true,
|
|
42
|
+
success: true,
|
|
43
|
+
title: true,
|
|
44
|
+
warn: true
|
|
45
|
+
});
|
|
46
|
+
__privateAdd(this, _log, (type, message) => {
|
|
47
|
+
const color = this.colors[type];
|
|
48
|
+
const messages = __privateGet(this, _reports)[__privateGet(this, _reports).length - 1].messages;
|
|
49
|
+
if (!messages[type])
|
|
50
|
+
messages[type] = [];
|
|
51
|
+
messages[type]?.push(message);
|
|
52
|
+
console.info(
|
|
53
|
+
`%c[${type}]%c: ${message}`,
|
|
54
|
+
`color: ${color}`,
|
|
55
|
+
"color: white"
|
|
56
|
+
);
|
|
57
|
+
});
|
|
58
|
+
__publicField(this, "reset", () => {
|
|
59
|
+
__privateSet(this, _reports, [
|
|
60
|
+
{
|
|
61
|
+
title: "Test without title, use method it to set test title.",
|
|
62
|
+
messages: {}
|
|
63
|
+
}
|
|
64
|
+
]);
|
|
65
|
+
});
|
|
66
|
+
this.reset();
|
|
67
|
+
}
|
|
68
|
+
error(message) {
|
|
69
|
+
if (__privateGet(this, _levels).error) {
|
|
70
|
+
console.error(message);
|
|
71
|
+
__privateGet(this, _log).call(this, "error", message);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
info(message) {
|
|
75
|
+
if (__privateGet(this, _levels).info)
|
|
76
|
+
__privateGet(this, _log).call(this, "info", message);
|
|
77
|
+
}
|
|
78
|
+
success(message) {
|
|
79
|
+
if (__privateGet(this, _levels).success)
|
|
80
|
+
__privateGet(this, _log).call(this, "success", message);
|
|
81
|
+
}
|
|
82
|
+
report() {
|
|
83
|
+
for (const report of __privateGet(this, _reports)) {
|
|
84
|
+
const errors = report.messages.error?.length ?? 0;
|
|
85
|
+
const warns = report.messages.warn?.length ?? 0;
|
|
86
|
+
const successes = report.messages.success?.length ?? 0;
|
|
87
|
+
if (successes === warns && warns === errors && errors === 0) {
|
|
88
|
+
if (report.title !== "Test without title, use method it to set test title.")
|
|
89
|
+
console.log(
|
|
90
|
+
`%cFor ${report.title}, no cases made.`,
|
|
91
|
+
"font-weight: bold; padding: 10px"
|
|
92
|
+
);
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
console.log(`%cFor ${report.title}`, "font-weight: bold; padding: 10px");
|
|
96
|
+
console.log(
|
|
97
|
+
`%c${successes} tests succeed.`,
|
|
98
|
+
`color: ${this.colors.success}`
|
|
99
|
+
);
|
|
100
|
+
console.log(`%c${warns} warnings sent.`, `color: ${this.colors.warn}`);
|
|
101
|
+
console.log(`%c${errors} errors found.`, `color: ${this.colors.error}`);
|
|
102
|
+
}
|
|
103
|
+
this.reset();
|
|
104
|
+
}
|
|
105
|
+
title(title) {
|
|
106
|
+
__privateGet(this, _reports).push({ title, messages: {} });
|
|
107
|
+
if (__privateGet(this, _levels).title) {
|
|
108
|
+
const color = this.colors.title;
|
|
109
|
+
console.info(
|
|
110
|
+
`%c${title}`,
|
|
111
|
+
`color: ${color}; font-weight: bold; padding: 10px`
|
|
112
|
+
);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
warn(message) {
|
|
116
|
+
if (__privateGet(this, _levels).warn) {
|
|
117
|
+
console.warn(message);
|
|
118
|
+
__privateGet(this, _log).call(this, "warn", message);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
setDebugLevels(levels) {
|
|
122
|
+
__privateSet(this, _levels, { ...__privateGet(this, _levels), ...levels });
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
_reports = new WeakMap();
|
|
126
|
+
_levels = new WeakMap();
|
|
127
|
+
_log = new WeakMap();
|
|
128
|
+
|
|
129
|
+
export { ConsoleTestsLogger, TestsLogger };
|
|
130
|
+
//# sourceMappingURL=TestsLogger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestsLogger.js","sources":["../src/TestsLogger.ts"],"sourcesContent":["export type TLogType = 'error' | 'info' | 'success' | 'title' | 'warn';\n\nexport abstract class TestsLogger {\n abstract error(message: string): void;\n abstract info(message: string): void;\n abstract report(): void;\n abstract success(message: string): void;\n abstract title(message: string): void;\n abstract warn(message: string): void;\n\n /**\n * Establece qué niveles se muestran y qué niveles no.\n */\n abstract setDebugLevels(levels: Partial<Record<TLogType, boolean>>): void;\n}\n\nexport class ConsoleTestsLogger extends TestsLogger {\n colors = {\n error: '#f77',\n info: 'lightblue',\n success: 'lightgreen',\n title: 'white',\n warn: 'yellow',\n };\n\n #reports: {\n title: string;\n messages: Partial<Record<keyof TestsLogger, string[]>>;\n }[] = [];\n\n #levels = {\n error: true,\n info: true,\n success: true,\n title: true,\n warn: true,\n };\n\n #log = (type: TLogType, message: string) => {\n const color = this.colors[type];\n\n const messages = this.#reports[this.#reports.length - 1].messages;\n if (!messages[type]) messages[type] = [];\n messages[type]?.push(message);\n\n console.info(\n `%c[${type}]%c: ${message}`,\n `color: ${color}`,\n 'color: white',\n );\n };\n\n constructor() {\n super();\n\n this.reset();\n }\n\n error(message: string): void {\n if (this.#levels.error) {\n console.error(message);\n this.#log('error', message);\n }\n }\n\n info(message: string): void {\n if (this.#levels.info) this.#log('info', message);\n }\n\n success(message: string): void {\n if (this.#levels.success) this.#log('success', message);\n }\n\n report() {\n for (const report of this.#reports) {\n const errors = report.messages.error?.length ?? 0;\n const warns = report.messages.warn?.length ?? 0;\n const successes = report.messages.success?.length ?? 0;\n\n if (successes === warns && warns === errors && errors === 0) {\n if (\n report.title !==\n 'Test without title, use method it to set test title.'\n )\n console.log(\n `%cFor ${report.title}, no cases made.`,\n 'font-weight: bold; padding: 10px',\n );\n continue;\n }\n\n console.log(`%cFor ${report.title}`, 'font-weight: bold; padding: 10px');\n console.log(\n `%c${successes} tests succeed.`,\n `color: ${this.colors.success}`,\n );\n console.log(`%c${warns} warnings sent.`, `color: ${this.colors.warn}`);\n console.log(`%c${errors} errors found.`, `color: ${this.colors.error}`);\n }\n\n this.reset();\n }\n\n reset = () => {\n this.#reports = [\n {\n title: 'Test without title, use method it to set test title.',\n messages: {},\n },\n ];\n };\n\n title(title: string): void {\n this.#reports.push({ title, messages: {} });\n\n if (this.#levels.title) {\n const color = this.colors.title;\n\n console.info(\n `%c${title}`,\n `color: ${color}; font-weight: bold; padding: 10px`,\n );\n }\n }\n\n warn(message: string): void {\n if (this.#levels.warn) {\n console.warn(message);\n this.#log('warn', message);\n }\n }\n\n setDebugLevels(levels: Partial<Record<TLogType, boolean>>): void {\n this.#levels = { ...this.#levels, ...levels };\n }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAA,QAAA,EAAA,OAAA,EAAA,IAAA,CAAA;AAEO,MAAe,WAAY,CAAA;AAYlC,CAAA;AAEO,MAAM,2BAA2B,WAAY,CAAA;AAAA,EAoClD,WAAc,GAAA;AACZ,IAAM,KAAA,EAAA,CAAA;AApCR,IAAS,aAAA,CAAA,IAAA,EAAA,QAAA,EAAA;AAAA,MACP,KAAO,EAAA,MAAA;AAAA,MACP,IAAM,EAAA,WAAA;AAAA,MACN,OAAS,EAAA,YAAA;AAAA,MACT,KAAO,EAAA,OAAA;AAAA,MACP,IAAM,EAAA,QAAA;AAAA,KACR,CAAA,CAAA;AAEA,IAAA,YAAA,CAAA,IAAA,EAAA,QAAA,EAGM,EAAC,CAAA,CAAA;AAEP,IAAU,YAAA,CAAA,IAAA,EAAA,OAAA,EAAA;AAAA,MACR,KAAO,EAAA,IAAA;AAAA,MACP,IAAM,EAAA,IAAA;AAAA,MACN,OAAS,EAAA,IAAA;AAAA,MACT,KAAO,EAAA,IAAA;AAAA,MACP,IAAM,EAAA,IAAA;AAAA,KACR,CAAA,CAAA;AAEA,IAAO,YAAA,CAAA,IAAA,EAAA,IAAA,EAAA,CAAC,MAAgB,OAAoB,KAAA;AAC1C,MAAM,MAAA,KAAA,GAAQ,IAAK,CAAA,MAAA,CAAO,IAAI,CAAA,CAAA;AAE9B,MAAA,MAAM,WAAW,YAAK,CAAA,IAAA,EAAA,QAAA,CAAA,CAAS,mBAAK,QAAS,CAAA,CAAA,MAAA,GAAS,CAAC,CAAE,CAAA,QAAA,CAAA;AACzD,MAAI,IAAA,CAAC,SAAS,IAAI,CAAA;AAAG,QAAS,QAAA,CAAA,IAAI,IAAI,EAAC,CAAA;AACvC,MAAS,QAAA,CAAA,IAAI,CAAG,EAAA,IAAA,CAAK,OAAO,CAAA,CAAA;AAE5B,MAAQ,OAAA,CAAA,IAAA;AAAA,QACN,CAAA,GAAA,EAAM,IAAI,CAAA,KAAA,EAAQ,OAAO,CAAA,CAAA;AAAA,QACzB,UAAU,KAAK,CAAA,CAAA;AAAA,QACf,cAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAqDA,IAAA,aAAA,CAAA,IAAA,EAAA,OAAA,EAAQ,MAAM;AACZ,MAAA,YAAA,CAAA,IAAA,EAAK,QAAW,EAAA;AAAA,QACd;AAAA,UACE,KAAO,EAAA,sDAAA;AAAA,UACP,UAAU,EAAC;AAAA,SACb;AAAA,OACF,CAAA,CAAA;AAAA,KACF,CAAA,CAAA;AAvDE,IAAA,IAAA,CAAK,KAAM,EAAA,CAAA;AAAA,GACb;AAAA,EAEA,MAAM,OAAuB,EAAA;AAC3B,IAAI,IAAA,YAAA,CAAA,IAAA,EAAK,SAAQ,KAAO,EAAA;AACtB,MAAA,OAAA,CAAQ,MAAM,OAAO,CAAA,CAAA;AACrB,MAAK,YAAA,CAAA,IAAA,EAAA,IAAA,CAAA,CAAL,WAAU,OAAS,EAAA,OAAA,CAAA,CAAA;AAAA,KACrB;AAAA,GACF;AAAA,EAEA,KAAK,OAAuB,EAAA;AAC1B,IAAA,IAAI,mBAAK,OAAQ,CAAA,CAAA,IAAA;AAAM,MAAK,YAAA,CAAA,IAAA,EAAA,IAAA,CAAA,CAAL,WAAU,MAAQ,EAAA,OAAA,CAAA,CAAA;AAAA,GAC3C;AAAA,EAEA,QAAQ,OAAuB,EAAA;AAC7B,IAAA,IAAI,mBAAK,OAAQ,CAAA,CAAA,OAAA;AAAS,MAAK,YAAA,CAAA,IAAA,EAAA,IAAA,CAAA,CAAL,WAAU,SAAW,EAAA,OAAA,CAAA,CAAA;AAAA,GACjD;AAAA,EAEA,MAAS,GAAA;AACP,IAAW,KAAA,MAAA,MAAA,IAAU,mBAAK,QAAU,CAAA,EAAA;AAClC,MAAA,MAAM,MAAS,GAAA,MAAA,CAAO,QAAS,CAAA,KAAA,EAAO,MAAU,IAAA,CAAA,CAAA;AAChD,MAAA,MAAM,KAAQ,GAAA,MAAA,CAAO,QAAS,CAAA,IAAA,EAAM,MAAU,IAAA,CAAA,CAAA;AAC9C,MAAA,MAAM,SAAY,GAAA,MAAA,CAAO,QAAS,CAAA,OAAA,EAAS,MAAU,IAAA,CAAA,CAAA;AAErD,MAAA,IAAI,SAAc,KAAA,KAAA,IAAS,KAAU,KAAA,MAAA,IAAU,WAAW,CAAG,EAAA;AAC3D,QAAA,IACE,OAAO,KACP,KAAA,sDAAA;AAEA,UAAQ,OAAA,CAAA,GAAA;AAAA,YACN,CAAA,MAAA,EAAS,OAAO,KAAK,CAAA,gBAAA,CAAA;AAAA,YACrB,kCAAA;AAAA,WACF,CAAA;AACF,QAAA,SAAA;AAAA,OACF;AAEA,MAAA,OAAA,CAAQ,GAAI,CAAA,CAAA,MAAA,EAAS,MAAO,CAAA,KAAK,IAAI,kCAAkC,CAAA,CAAA;AACvE,MAAQ,OAAA,CAAA,GAAA;AAAA,QACN,KAAK,SAAS,CAAA,eAAA,CAAA;AAAA,QACd,CAAA,OAAA,EAAU,IAAK,CAAA,MAAA,CAAO,OAAO,CAAA,CAAA;AAAA,OAC/B,CAAA;AACA,MAAQ,OAAA,CAAA,GAAA,CAAI,KAAK,KAAK,CAAA,eAAA,CAAA,EAAmB,UAAU,IAAK,CAAA,MAAA,CAAO,IAAI,CAAE,CAAA,CAAA,CAAA;AACrE,MAAQ,OAAA,CAAA,GAAA,CAAI,KAAK,MAAM,CAAA,cAAA,CAAA,EAAkB,UAAU,IAAK,CAAA,MAAA,CAAO,KAAK,CAAE,CAAA,CAAA,CAAA;AAAA,KACxE;AAEA,IAAA,IAAA,CAAK,KAAM,EAAA,CAAA;AAAA,GACb;AAAA,EAWA,MAAM,KAAqB,EAAA;AACzB,IAAA,YAAA,CAAA,IAAA,EAAK,UAAS,IAAK,CAAA,EAAE,OAAO,QAAU,EAAA,IAAI,CAAA,CAAA;AAE1C,IAAI,IAAA,YAAA,CAAA,IAAA,EAAK,SAAQ,KAAO,EAAA;AACtB,MAAM,MAAA,KAAA,GAAQ,KAAK,MAAO,CAAA,KAAA,CAAA;AAE1B,MAAQ,OAAA,CAAA,IAAA;AAAA,QACN,KAAK,KAAK,CAAA,CAAA;AAAA,QACV,UAAU,KAAK,CAAA,kCAAA,CAAA;AAAA,OACjB,CAAA;AAAA,KACF;AAAA,GACF;AAAA,EAEA,KAAK,OAAuB,EAAA;AAC1B,IAAI,IAAA,YAAA,CAAA,IAAA,EAAK,SAAQ,IAAM,EAAA;AACrB,MAAA,OAAA,CAAQ,KAAK,OAAO,CAAA,CAAA;AACpB,MAAK,YAAA,CAAA,IAAA,EAAA,IAAA,CAAA,CAAL,WAAU,MAAQ,EAAA,OAAA,CAAA,CAAA;AAAA,KACpB;AAAA,GACF;AAAA,EAEA,eAAe,MAAkD,EAAA;AAC/D,IAAA,YAAA,CAAA,IAAA,EAAK,SAAU,EAAE,GAAG,YAAK,CAAA,IAAA,EAAA,OAAA,CAAA,EAAS,GAAG,MAAO,EAAA,CAAA,CAAA;AAAA,GAC9C;AACF,CAAA;AA9GE,QAAA,GAAA,IAAA,OAAA,EAAA,CAAA;AAKA,OAAA,GAAA,IAAA,OAAA,EAAA,CAAA;AAQA,IAAA,GAAA,IAAA,OAAA,EAAA;;;;"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,99 +1,71 @@
|
|
|
1
|
-
import * as
|
|
2
|
-
import { FC, CSSProperties } from 'react';
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
3
2
|
import { EventEmitter } from '@apia/util';
|
|
3
|
+
import { CSSProperties, FC } from 'react';
|
|
4
|
+
import { TestComponent } from './TestComponent.js';
|
|
5
|
+
import { TestsLogger } from './TestsLogger.js';
|
|
4
6
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
declare
|
|
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
|
-
get root(): HTMLElement | null;
|
|
67
|
-
/**
|
|
68
|
-
* Hace foco sobre un elemento del DOM y resuelve cuando puede hacer foco o
|
|
69
|
-
* rompe cuando no puede hacer después de 5 intentos.
|
|
70
|
-
*/
|
|
71
|
-
focus: (selector: string, check?: ((element: HTMLElement) => boolean) | undefined, options?: TRunOptions) => Promise<HTMLElement | null>;
|
|
72
|
-
/**
|
|
73
|
-
* Anuncia un nuevo grupo de tests
|
|
74
|
-
*/
|
|
75
|
-
it: (text: string) => void;
|
|
76
|
-
/**
|
|
77
|
-
* Monta un componente para usarlo en el testing
|
|
78
|
-
*/
|
|
79
|
-
mount: <T extends Record<string, unknown>>(name: string, component: FC<T>, initialProps: T) => Promise<TestComponent<T>>;
|
|
80
|
-
report: () => void;
|
|
81
|
-
/**
|
|
82
|
-
* Corre una tarea que va a intentar hasta n veces cada ms milisegundos antes
|
|
83
|
-
* de resolver como fallo.
|
|
84
|
-
*
|
|
85
|
-
* @parameter options
|
|
86
|
-
*/
|
|
87
|
-
should: (name: string, cb: () => boolean | Promise<boolean>, options?: Omit<TRunOptions, 'silence'>) => Promise<void>;
|
|
88
|
-
unmount: (component: TestComponent<any>) => void;
|
|
89
|
-
/**
|
|
90
|
-
* Espera por una condición a suceder, intentando n veces cada ms
|
|
91
|
-
* milisegundos. La diferencia principal con should es que este método no se
|
|
92
|
-
* ocupa de si un test pasa o falla, sino simplemente que trata de cumplir una
|
|
93
|
-
* condición. Es especialmente útil para intentar hacer foco o esperar algún
|
|
94
|
-
* evento en un futuro cercano.
|
|
95
|
-
*/
|
|
96
|
-
wait: (name: string, cb: () => boolean | Promise<boolean>, options?: TRunOptions) => Promise<unknown>;
|
|
7
|
+
type TRunOptions = Partial<{
|
|
8
|
+
/**
|
|
9
|
+
* Delay al inicio
|
|
10
|
+
*/
|
|
11
|
+
delay: number;
|
|
12
|
+
/**
|
|
13
|
+
* Cantidad de veces a ejecutar
|
|
14
|
+
*/
|
|
15
|
+
n: number;
|
|
16
|
+
/**
|
|
17
|
+
* Demora entre reintentos
|
|
18
|
+
*/
|
|
19
|
+
ms: number;
|
|
20
|
+
/**
|
|
21
|
+
* Omitir mensajes
|
|
22
|
+
*/
|
|
23
|
+
silence: boolean;
|
|
24
|
+
}>;
|
|
25
|
+
declare class Test extends EventEmitter<{
|
|
26
|
+
componentsListUpdated: boolean;
|
|
27
|
+
componentMounted: string;
|
|
28
|
+
}> {
|
|
29
|
+
#private;
|
|
30
|
+
logger: TestsLogger;
|
|
31
|
+
Component: ({ style }: {
|
|
32
|
+
style: CSSProperties;
|
|
33
|
+
}) => react_jsx_runtime.JSX.Element;
|
|
34
|
+
/**
|
|
35
|
+
* Devuelve el elemento html sobre el cual se están montando los tests
|
|
36
|
+
*/
|
|
37
|
+
get root(): HTMLElement | null;
|
|
38
|
+
/**
|
|
39
|
+
* Hace foco sobre un elemento del DOM y resuelve cuando puede hacer foco o
|
|
40
|
+
* rompe cuando no puede hacer después de 5 intentos.
|
|
41
|
+
*/
|
|
42
|
+
focus: (selector: string, check?: ((element: HTMLElement) => boolean) | undefined, options?: TRunOptions) => Promise<HTMLElement | null>;
|
|
43
|
+
/**
|
|
44
|
+
* Anuncia un nuevo grupo de tests
|
|
45
|
+
*/
|
|
46
|
+
it: (text: string) => void;
|
|
47
|
+
/**
|
|
48
|
+
* Monta un componente para usarlo en el testing
|
|
49
|
+
*/
|
|
50
|
+
mount: <T extends Record<string, unknown>>(name: string, component: FC<T>, initialProps: T) => Promise<TestComponent<T>>;
|
|
51
|
+
report: () => void;
|
|
52
|
+
/**
|
|
53
|
+
* Corre una tarea que va a intentar hasta n veces cada ms milisegundos antes
|
|
54
|
+
* de resolver como fallo.
|
|
55
|
+
*
|
|
56
|
+
* @parameter options
|
|
57
|
+
*/
|
|
58
|
+
should: (name: string, cb: () => boolean | Promise<boolean>, options?: Omit<TRunOptions, 'silence'>) => Promise<void>;
|
|
59
|
+
unmount: (component: TestComponent<any>) => void;
|
|
60
|
+
/**
|
|
61
|
+
* Espera por una condición a suceder, intentando n veces cada ms
|
|
62
|
+
* milisegundos. La diferencia principal con should es que este método no se
|
|
63
|
+
* ocupa de si un test pasa o falla, sino simplemente que trata de cumplir una
|
|
64
|
+
* condición. Es especialmente útil para intentar hacer foco o esperar algún
|
|
65
|
+
* evento en un futuro cercano.
|
|
66
|
+
*/
|
|
67
|
+
wait: (name: string, cb: () => boolean | Promise<boolean>, options?: TRunOptions) => Promise<unknown>;
|
|
97
68
|
}
|
|
98
69
|
|
|
99
70
|
export { Test, TestComponent, TestsLogger };
|
|
71
|
+
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.js
CHANGED
|
@@ -1,250 +1,15 @@
|
|
|
1
1
|
import { jsx } from 'react/jsx-runtime';
|
|
2
2
|
import { EventEmitter, useMount } from '@apia/util';
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
var __hasOwnProp$2 = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __propIsEnum$2 = Object.prototype.propertyIsEnumerable;
|
|
9
|
-
var __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
10
|
-
var __spreadValues$2 = (a, b) => {
|
|
11
|
-
for (var prop in b || (b = {}))
|
|
12
|
-
if (__hasOwnProp$2.call(b, prop))
|
|
13
|
-
__defNormalProp$2(a, prop, b[prop]);
|
|
14
|
-
if (__getOwnPropSymbols$2)
|
|
15
|
-
for (var prop of __getOwnPropSymbols$2(b)) {
|
|
16
|
-
if (__propIsEnum$2.call(b, prop))
|
|
17
|
-
__defNormalProp$2(a, prop, b[prop]);
|
|
18
|
-
}
|
|
19
|
-
return a;
|
|
20
|
-
};
|
|
21
|
-
var __accessCheck$2 = (obj, member, msg) => {
|
|
22
|
-
if (!member.has(obj))
|
|
23
|
-
throw TypeError("Cannot " + msg);
|
|
24
|
-
};
|
|
25
|
-
var __privateGet$2 = (obj, member, getter) => {
|
|
26
|
-
__accessCheck$2(obj, member, "read from private field");
|
|
27
|
-
return getter ? getter.call(obj) : member.get(obj);
|
|
28
|
-
};
|
|
29
|
-
var __privateAdd$2 = (obj, member, value) => {
|
|
30
|
-
if (member.has(obj))
|
|
31
|
-
throw TypeError("Cannot add the same private member more than once");
|
|
32
|
-
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
33
|
-
};
|
|
34
|
-
var __privateSet$2 = (obj, member, value, setter) => {
|
|
35
|
-
__accessCheck$2(obj, member, "write to private field");
|
|
36
|
-
setter ? setter.call(obj, value) : member.set(obj, value);
|
|
37
|
-
return value;
|
|
38
|
-
};
|
|
39
|
-
var _component, _props;
|
|
40
|
-
let maxId = 0;
|
|
41
|
-
let maxUpdateId = 0;
|
|
42
|
-
class TestComponent extends EventEmitter {
|
|
43
|
-
constructor(name, test, component, initialProps) {
|
|
44
|
-
super();
|
|
45
|
-
this.name = name;
|
|
46
|
-
this.test = test;
|
|
47
|
-
__privateAdd$2(this, _component, void 0);
|
|
48
|
-
__privateAdd$2(this, _props, void 0);
|
|
49
|
-
this.id = `component__${maxId++}`;
|
|
50
|
-
this.Component = forwardRef((_, ref) => {
|
|
51
|
-
const [props, setProps] = useState(__privateGet$2(this, _props));
|
|
52
|
-
const [lastUpdateId, setLastUpdateId] = useState("");
|
|
53
|
-
const Render = __privateGet$2(this, _component);
|
|
54
|
-
useMount(() => {
|
|
55
|
-
const suscription = this.on("update", (ev) => {
|
|
56
|
-
setProps((current) => __spreadValues$2(__spreadValues$2({}, current), ev.props));
|
|
57
|
-
setLastUpdateId(ev.id);
|
|
58
|
-
});
|
|
59
|
-
ref({});
|
|
60
|
-
return suscription;
|
|
61
|
-
});
|
|
62
|
-
useEffect(() => {
|
|
63
|
-
setTimeout(() => {
|
|
64
|
-
this.emit("updated", lastUpdateId);
|
|
65
|
-
}, 0);
|
|
66
|
-
}, [lastUpdateId]);
|
|
67
|
-
return /* @__PURE__ */ jsx("div", { id: this.name, children: /* @__PURE__ */ jsx(Render, __spreadValues$2({}, props)) });
|
|
68
|
-
});
|
|
69
|
-
this.unmount = () => {
|
|
70
|
-
this.test.unmount(this);
|
|
71
|
-
};
|
|
72
|
-
__privateSet$2(this, _component, component);
|
|
73
|
-
__privateSet$2(this, _props, initialProps);
|
|
74
|
-
}
|
|
75
|
-
updateProps(newProps) {
|
|
76
|
-
return new Promise((resolve) => {
|
|
77
|
-
const updateId = `update${maxUpdateId++}`;
|
|
78
|
-
const unsuscribe = this.on("updated", (ev) => {
|
|
79
|
-
if (ev === updateId) {
|
|
80
|
-
unsuscribe();
|
|
81
|
-
resolve();
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
setTimeout(() => {
|
|
85
|
-
this.emit("update", { id: updateId, props: newProps });
|
|
86
|
-
}, 0);
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
_component = new WeakMap();
|
|
91
|
-
_props = new WeakMap();
|
|
92
|
-
|
|
93
|
-
var __defProp$1 = Object.defineProperty;
|
|
94
|
-
var __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;
|
|
95
|
-
var __hasOwnProp$1 = Object.prototype.hasOwnProperty;
|
|
96
|
-
var __propIsEnum$1 = Object.prototype.propertyIsEnumerable;
|
|
97
|
-
var __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
98
|
-
var __spreadValues$1 = (a, b) => {
|
|
99
|
-
for (var prop in b || (b = {}))
|
|
100
|
-
if (__hasOwnProp$1.call(b, prop))
|
|
101
|
-
__defNormalProp$1(a, prop, b[prop]);
|
|
102
|
-
if (__getOwnPropSymbols$1)
|
|
103
|
-
for (var prop of __getOwnPropSymbols$1(b)) {
|
|
104
|
-
if (__propIsEnum$1.call(b, prop))
|
|
105
|
-
__defNormalProp$1(a, prop, b[prop]);
|
|
106
|
-
}
|
|
107
|
-
return a;
|
|
108
|
-
};
|
|
109
|
-
var __accessCheck$1 = (obj, member, msg) => {
|
|
110
|
-
if (!member.has(obj))
|
|
111
|
-
throw TypeError("Cannot " + msg);
|
|
112
|
-
};
|
|
113
|
-
var __privateGet$1 = (obj, member, getter) => {
|
|
114
|
-
__accessCheck$1(obj, member, "read from private field");
|
|
115
|
-
return getter ? getter.call(obj) : member.get(obj);
|
|
116
|
-
};
|
|
117
|
-
var __privateAdd$1 = (obj, member, value) => {
|
|
118
|
-
if (member.has(obj))
|
|
119
|
-
throw TypeError("Cannot add the same private member more than once");
|
|
120
|
-
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
121
|
-
};
|
|
122
|
-
var __privateSet$1 = (obj, member, value, setter) => {
|
|
123
|
-
__accessCheck$1(obj, member, "write to private field");
|
|
124
|
-
setter ? setter.call(obj, value) : member.set(obj, value);
|
|
125
|
-
return value;
|
|
126
|
-
};
|
|
127
|
-
var _reports, _levels, _log;
|
|
128
|
-
class TestsLogger {
|
|
129
|
-
}
|
|
130
|
-
class ConsoleTestsLogger extends TestsLogger {
|
|
131
|
-
constructor() {
|
|
132
|
-
super();
|
|
133
|
-
this.colors = {
|
|
134
|
-
error: "#f77",
|
|
135
|
-
info: "lightblue",
|
|
136
|
-
success: "lightgreen",
|
|
137
|
-
title: "white",
|
|
138
|
-
warn: "yellow"
|
|
139
|
-
};
|
|
140
|
-
__privateAdd$1(this, _reports, []);
|
|
141
|
-
__privateAdd$1(this, _levels, {
|
|
142
|
-
error: true,
|
|
143
|
-
info: true,
|
|
144
|
-
success: true,
|
|
145
|
-
title: true,
|
|
146
|
-
warn: true
|
|
147
|
-
});
|
|
148
|
-
__privateAdd$1(this, _log, (type, message) => {
|
|
149
|
-
var _a;
|
|
150
|
-
const color = this.colors[type];
|
|
151
|
-
const messages = __privateGet$1(this, _reports)[__privateGet$1(this, _reports).length - 1].messages;
|
|
152
|
-
if (!messages[type])
|
|
153
|
-
messages[type] = [];
|
|
154
|
-
(_a = messages[type]) == null ? void 0 : _a.push(message);
|
|
155
|
-
console.info(
|
|
156
|
-
`%c[${type}]%c: ${message}`,
|
|
157
|
-
`color: ${color}`,
|
|
158
|
-
"color: white"
|
|
159
|
-
);
|
|
160
|
-
});
|
|
161
|
-
this.reset = () => {
|
|
162
|
-
__privateSet$1(this, _reports, [
|
|
163
|
-
{
|
|
164
|
-
title: "Test without title, use method it to set test title.",
|
|
165
|
-
messages: {}
|
|
166
|
-
}
|
|
167
|
-
]);
|
|
168
|
-
};
|
|
169
|
-
this.reset();
|
|
170
|
-
}
|
|
171
|
-
error(message) {
|
|
172
|
-
if (__privateGet$1(this, _levels).error) {
|
|
173
|
-
console.error(message);
|
|
174
|
-
__privateGet$1(this, _log).call(this, "error", message);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
info(message) {
|
|
178
|
-
if (__privateGet$1(this, _levels).info)
|
|
179
|
-
__privateGet$1(this, _log).call(this, "info", message);
|
|
180
|
-
}
|
|
181
|
-
success(message) {
|
|
182
|
-
if (__privateGet$1(this, _levels).success)
|
|
183
|
-
__privateGet$1(this, _log).call(this, "success", message);
|
|
184
|
-
}
|
|
185
|
-
report() {
|
|
186
|
-
var _a, _b, _c, _d, _e, _f;
|
|
187
|
-
for (const report of __privateGet$1(this, _reports)) {
|
|
188
|
-
const errors = (_b = (_a = report.messages.error) == null ? void 0 : _a.length) != null ? _b : 0;
|
|
189
|
-
const warns = (_d = (_c = report.messages.warn) == null ? void 0 : _c.length) != null ? _d : 0;
|
|
190
|
-
const successes = (_f = (_e = report.messages.success) == null ? void 0 : _e.length) != null ? _f : 0;
|
|
191
|
-
if (successes === warns && warns === errors && errors === 0) {
|
|
192
|
-
if (report.title !== "Test without title, use method it to set test title.")
|
|
193
|
-
console.log(
|
|
194
|
-
`%cFor ${report.title}, no cases made.`,
|
|
195
|
-
"font-weight: bold; padding: 10px"
|
|
196
|
-
);
|
|
197
|
-
continue;
|
|
198
|
-
}
|
|
199
|
-
console.log(`%cFor ${report.title}`, "font-weight: bold; padding: 10px");
|
|
200
|
-
console.log(
|
|
201
|
-
`%c${successes} tests succeed.`,
|
|
202
|
-
`color: ${this.colors.success}`
|
|
203
|
-
);
|
|
204
|
-
console.log(`%c${warns} warnings sent.`, `color: ${this.colors.warn}`);
|
|
205
|
-
console.log(`%c${errors} errors found.`, `color: ${this.colors.error}`);
|
|
206
|
-
}
|
|
207
|
-
this.reset();
|
|
208
|
-
}
|
|
209
|
-
title(title) {
|
|
210
|
-
__privateGet$1(this, _reports).push({ title, messages: {} });
|
|
211
|
-
if (__privateGet$1(this, _levels).title) {
|
|
212
|
-
const color = this.colors.title;
|
|
213
|
-
console.info(
|
|
214
|
-
`%c${title}`,
|
|
215
|
-
`color: ${color}; font-weight: bold; padding: 10px`
|
|
216
|
-
);
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
warn(message) {
|
|
220
|
-
if (__privateGet$1(this, _levels).warn) {
|
|
221
|
-
console.warn(message);
|
|
222
|
-
__privateGet$1(this, _log).call(this, "warn", message);
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
setDebugLevels(levels) {
|
|
226
|
-
__privateSet$1(this, _levels, __spreadValues$1(__spreadValues$1({}, __privateGet$1(this, _levels)), levels));
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
_reports = new WeakMap();
|
|
230
|
-
_levels = new WeakMap();
|
|
231
|
-
_log = new WeakMap();
|
|
3
|
+
import { useState } from 'react';
|
|
4
|
+
import { TestComponent } from './TestComponent.js';
|
|
5
|
+
import { ConsoleTestsLogger } from './TestsLogger.js';
|
|
6
|
+
export { TestsLogger } from './TestsLogger.js';
|
|
232
7
|
|
|
233
8
|
var __defProp = Object.defineProperty;
|
|
234
|
-
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
235
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
236
|
-
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
237
9
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
238
|
-
var
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
__defNormalProp(a, prop, b[prop]);
|
|
242
|
-
if (__getOwnPropSymbols)
|
|
243
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
244
|
-
if (__propIsEnum.call(b, prop))
|
|
245
|
-
__defNormalProp(a, prop, b[prop]);
|
|
246
|
-
}
|
|
247
|
-
return a;
|
|
10
|
+
var __publicField = (obj, key, value) => {
|
|
11
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
12
|
+
return value;
|
|
248
13
|
};
|
|
249
14
|
var __accessCheck = (obj, member, msg) => {
|
|
250
15
|
if (!member.has(obj))
|
|
@@ -264,41 +29,21 @@ var __privateSet = (obj, member, value, setter) => {
|
|
|
264
29
|
setter ? setter.call(obj, value) : member.set(obj, value);
|
|
265
30
|
return value;
|
|
266
31
|
};
|
|
267
|
-
var __async = (__this, __arguments, generator) => {
|
|
268
|
-
return new Promise((resolve, reject) => {
|
|
269
|
-
var fulfilled = (value) => {
|
|
270
|
-
try {
|
|
271
|
-
step(generator.next(value));
|
|
272
|
-
} catch (e) {
|
|
273
|
-
reject(e);
|
|
274
|
-
}
|
|
275
|
-
};
|
|
276
|
-
var rejected = (value) => {
|
|
277
|
-
try {
|
|
278
|
-
step(generator.throw(value));
|
|
279
|
-
} catch (e) {
|
|
280
|
-
reject(e);
|
|
281
|
-
}
|
|
282
|
-
};
|
|
283
|
-
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
284
|
-
step((generator = generator.apply(__this, __arguments)).next());
|
|
285
|
-
});
|
|
286
|
-
};
|
|
287
32
|
var _components, _ref, _running, _run;
|
|
288
33
|
class Test extends EventEmitter {
|
|
289
34
|
constructor() {
|
|
290
35
|
super(...arguments);
|
|
291
36
|
__privateAdd(this, _components, []);
|
|
292
37
|
__privateAdd(this, _ref, null);
|
|
293
|
-
this
|
|
294
|
-
this
|
|
38
|
+
__publicField(this, "logger", new ConsoleTestsLogger());
|
|
39
|
+
__publicField(this, "Component", ({ style }) => {
|
|
295
40
|
const [components, setComponents] = useState(__privateGet(this, _components));
|
|
296
41
|
useMount(() => {
|
|
297
42
|
return this.on("componentsListUpdated", () => {
|
|
298
43
|
setComponents([...__privateGet(this, _components)]);
|
|
299
44
|
});
|
|
300
45
|
});
|
|
301
|
-
return /* @__PURE__ */ jsx("div", { ref: (el) => __privateSet(this, _ref, el), style:
|
|
46
|
+
return /* @__PURE__ */ jsx("div", { ref: (el) => __privateSet(this, _ref, el), style: { display: "none", ...style }, children: components.map((current) => /* @__PURE__ */ jsx(
|
|
302
47
|
current.Component,
|
|
303
48
|
{
|
|
304
49
|
ref: (el) => {
|
|
@@ -308,21 +53,20 @@ class Test extends EventEmitter {
|
|
|
308
53
|
},
|
|
309
54
|
current.id
|
|
310
55
|
)) });
|
|
311
|
-
};
|
|
56
|
+
});
|
|
312
57
|
/**
|
|
313
58
|
* Hace foco sobre un elemento del DOM y resuelve cuando puede hacer foco o
|
|
314
59
|
* rompe cuando no puede hacer después de 5 intentos.
|
|
315
60
|
*/
|
|
316
|
-
this
|
|
61
|
+
__publicField(this, "focus", (selector, check, options) => {
|
|
317
62
|
const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);
|
|
318
63
|
return new Promise((resolve) => {
|
|
319
64
|
setTimeout(() => {
|
|
320
65
|
let tries = actualOptions.n;
|
|
321
66
|
const interval = setInterval(() => {
|
|
322
|
-
var _a;
|
|
323
67
|
this.logger.info(`Trying to focus with selector ${selector}`);
|
|
324
68
|
tries--;
|
|
325
|
-
const element =
|
|
69
|
+
const element = this.root?.querySelector(selector);
|
|
326
70
|
if (element) {
|
|
327
71
|
element.focus();
|
|
328
72
|
if (check ? check(element) : element === document.activeElement) {
|
|
@@ -337,17 +81,17 @@ class Test extends EventEmitter {
|
|
|
337
81
|
}, actualOptions.ms);
|
|
338
82
|
}, actualOptions.delay);
|
|
339
83
|
});
|
|
340
|
-
};
|
|
84
|
+
});
|
|
341
85
|
/**
|
|
342
86
|
* Anuncia un nuevo grupo de tests
|
|
343
87
|
*/
|
|
344
|
-
this
|
|
88
|
+
__publicField(this, "it", (text) => {
|
|
345
89
|
this.logger.title(text);
|
|
346
|
-
};
|
|
90
|
+
});
|
|
347
91
|
/**
|
|
348
92
|
* Monta un componente para usarlo en el testing
|
|
349
93
|
*/
|
|
350
|
-
this
|
|
94
|
+
__publicField(this, "mount", (name, component, initialProps) => {
|
|
351
95
|
return new Promise((resolve) => {
|
|
352
96
|
const newComponent = new TestComponent(
|
|
353
97
|
name,
|
|
@@ -364,10 +108,10 @@ class Test extends EventEmitter {
|
|
|
364
108
|
}
|
|
365
109
|
});
|
|
366
110
|
});
|
|
367
|
-
};
|
|
368
|
-
this
|
|
111
|
+
});
|
|
112
|
+
__publicField(this, "report", () => {
|
|
369
113
|
this.logger.report();
|
|
370
|
-
};
|
|
114
|
+
});
|
|
371
115
|
__privateAdd(this, _running, false);
|
|
372
116
|
/**
|
|
373
117
|
* Corre una tarea que va a intentar hasta n veces cada ms milisegundos antes
|
|
@@ -375,8 +119,8 @@ class Test extends EventEmitter {
|
|
|
375
119
|
*
|
|
376
120
|
* @parameter options
|
|
377
121
|
*/
|
|
378
|
-
this
|
|
379
|
-
|
|
122
|
+
__publicField(this, "should", async (name, cb, options) => {
|
|
123
|
+
await this.wait("", () => !__privateGet(this, _running), { silence: true, n: 300 });
|
|
380
124
|
__privateSet(this, _running, true);
|
|
381
125
|
const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);
|
|
382
126
|
return new Promise((resolve) => {
|
|
@@ -417,12 +161,12 @@ class Test extends EventEmitter {
|
|
|
417
161
|
}, actualOptions.delay);
|
|
418
162
|
});
|
|
419
163
|
});
|
|
420
|
-
this
|
|
164
|
+
__publicField(this, "unmount", (component) => {
|
|
421
165
|
__privateSet(this, _components, __privateGet(this, _components).filter(
|
|
422
166
|
(current) => current !== component
|
|
423
167
|
));
|
|
424
168
|
this.emit("componentsListUpdated", true);
|
|
425
|
-
};
|
|
169
|
+
});
|
|
426
170
|
/**
|
|
427
171
|
* Espera por una condición a suceder, intentando n veces cada ms
|
|
428
172
|
* milisegundos. La diferencia principal con should es que este método no se
|
|
@@ -430,7 +174,7 @@ class Test extends EventEmitter {
|
|
|
430
174
|
* condición. Es especialmente útil para intentar hacer foco o esperar algún
|
|
431
175
|
* evento en un futuro cercano.
|
|
432
176
|
*/
|
|
433
|
-
this
|
|
177
|
+
__publicField(this, "wait", async (name, cb, options) => {
|
|
434
178
|
const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);
|
|
435
179
|
return new Promise((resolve) => {
|
|
436
180
|
setTimeout(() => {
|
|
@@ -440,8 +184,8 @@ class Test extends EventEmitter {
|
|
|
440
184
|
const tryAgain = () => {
|
|
441
185
|
window.requestAnimationFrame(() => {
|
|
442
186
|
if (tries-- > 0) {
|
|
443
|
-
void (() =>
|
|
444
|
-
const result =
|
|
187
|
+
void (async () => {
|
|
188
|
+
const result = await cb();
|
|
445
189
|
if (!result) {
|
|
446
190
|
setTimeout(() => {
|
|
447
191
|
tryAgain();
|
|
@@ -449,7 +193,7 @@ class Test extends EventEmitter {
|
|
|
449
193
|
} else {
|
|
450
194
|
resolve(true);
|
|
451
195
|
}
|
|
452
|
-
})
|
|
196
|
+
})();
|
|
453
197
|
} else {
|
|
454
198
|
resolve(false);
|
|
455
199
|
}
|
|
@@ -459,9 +203,9 @@ class Test extends EventEmitter {
|
|
|
459
203
|
}, actualOptions.delay);
|
|
460
204
|
});
|
|
461
205
|
});
|
|
462
|
-
__privateAdd(this, _run, (task) =>
|
|
206
|
+
__privateAdd(this, _run, async (task) => {
|
|
463
207
|
try {
|
|
464
|
-
const taskResult =
|
|
208
|
+
const taskResult = await task.cb();
|
|
465
209
|
if (taskResult) {
|
|
466
210
|
return true;
|
|
467
211
|
} else {
|
|
@@ -471,7 +215,7 @@ class Test extends EventEmitter {
|
|
|
471
215
|
this.logger.error(String(e));
|
|
472
216
|
return false;
|
|
473
217
|
}
|
|
474
|
-
})
|
|
218
|
+
});
|
|
475
219
|
}
|
|
476
220
|
/**
|
|
477
221
|
* Devuelve el elemento html sobre el cual se están montando los tests
|
|
@@ -485,4 +229,5 @@ _ref = new WeakMap();
|
|
|
485
229
|
_running = new WeakMap();
|
|
486
230
|
_run = new WeakMap();
|
|
487
231
|
|
|
488
|
-
export { Test, TestComponent
|
|
232
|
+
export { Test, TestComponent };
|
|
233
|
+
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/TestComponent.tsx","../src/TestsLogger.ts","../src/index.tsx"],"sourcesContent":["import { FC, RefCallback, forwardRef, useEffect, useState } from 'react';\nimport { EventEmitter, useMount } from '@apia/util';\nimport { Test } from '.';\n\nlet maxId = 0;\nlet maxUpdateId = 0;\n\nexport class TestComponent<\n T extends Record<string, unknown>,\n> extends EventEmitter<{\n update: { id: string; props: Partial<T> };\n updated: string;\n}> {\n #component: FC<T>;\n #props: T;\n\n id = `component__${maxId++}`;\n\n Component = forwardRef<object>((_, ref) => {\n const [props, setProps] = useState(this.#props);\n const [lastUpdateId, setLastUpdateId] = useState('');\n\n const Render = this.#component;\n\n useMount(() => {\n const suscription = this.on('update', (ev) => {\n setProps((current) => ({ ...current, ...ev.props }));\n setLastUpdateId(ev.id);\n });\n\n (ref as RefCallback<object>)({});\n\n return suscription;\n });\n\n useEffect(() => {\n setTimeout(() => {\n this.emit('updated', lastUpdateId);\n }, 0);\n }, [lastUpdateId]);\n\n return (\n <div id={this.name}>\n <Render {...props} />\n </div>\n );\n });\n\n constructor(\n private name: string,\n private test: Test,\n component: FC<T>,\n initialProps: T,\n ) {\n super();\n\n this.#component = component;\n this.#props = initialProps;\n }\n\n unmount = () => {\n this.test.unmount(this);\n };\n\n updateProps(newProps: Partial<T>) {\n return new Promise<void>((resolve) => {\n const updateId = `update${maxUpdateId++}`;\n const unsuscribe = this.on('updated', (ev) => {\n if (ev === updateId) {\n unsuscribe();\n resolve();\n }\n });\n setTimeout(() => {\n this.emit('update', { id: updateId, props: newProps });\n }, 0);\n });\n }\n}\n","export type TLogType = 'error' | 'info' | 'success' | 'title' | 'warn';\n\nexport abstract class TestsLogger {\n abstract error(message: string): void;\n abstract info(message: string): void;\n abstract report(): void;\n abstract success(message: string): void;\n abstract title(message: string): void;\n abstract warn(message: string): void;\n\n /**\n * Establece qué niveles se muestran y qué niveles no.\n */\n abstract setDebugLevels(levels: Partial<Record<TLogType, boolean>>): void;\n}\n\nexport class ConsoleTestsLogger extends TestsLogger {\n colors = {\n error: '#f77',\n info: 'lightblue',\n success: 'lightgreen',\n title: 'white',\n warn: 'yellow',\n };\n\n #reports: {\n title: string;\n messages: Partial<Record<keyof TestsLogger, string[]>>;\n }[] = [];\n\n #levels = {\n error: true,\n info: true,\n success: true,\n title: true,\n warn: true,\n };\n\n #log = (type: TLogType, message: string) => {\n const color = this.colors[type];\n\n const messages = this.#reports[this.#reports.length - 1].messages;\n if (!messages[type]) messages[type] = [];\n messages[type]?.push(message);\n\n console.info(\n `%c[${type}]%c: ${message}`,\n `color: ${color}`,\n 'color: white',\n );\n };\n\n constructor() {\n super();\n\n this.reset();\n }\n\n error(message: string): void {\n if (this.#levels.error) {\n console.error(message);\n this.#log('error', message);\n }\n }\n\n info(message: string): void {\n if (this.#levels.info) this.#log('info', message);\n }\n\n success(message: string): void {\n if (this.#levels.success) this.#log('success', message);\n }\n\n report() {\n for (const report of this.#reports) {\n const errors = report.messages.error?.length ?? 0;\n const warns = report.messages.warn?.length ?? 0;\n const successes = report.messages.success?.length ?? 0;\n\n if (successes === warns && warns === errors && errors === 0) {\n if (\n report.title !==\n 'Test without title, use method it to set test title.'\n )\n console.log(\n `%cFor ${report.title}, no cases made.`,\n 'font-weight: bold; padding: 10px',\n );\n continue;\n }\n\n console.log(`%cFor ${report.title}`, 'font-weight: bold; padding: 10px');\n console.log(\n `%c${successes} tests succeed.`,\n `color: ${this.colors.success}`,\n );\n console.log(`%c${warns} warnings sent.`, `color: ${this.colors.warn}`);\n console.log(`%c${errors} errors found.`, `color: ${this.colors.error}`);\n }\n\n this.reset();\n }\n\n reset = () => {\n this.#reports = [\n {\n title: 'Test without title, use method it to set test title.',\n messages: {},\n },\n ];\n };\n\n title(title: string): void {\n this.#reports.push({ title, messages: {} });\n\n if (this.#levels.title) {\n const color = this.colors.title;\n\n console.info(\n `%c${title}`,\n `color: ${color}; font-weight: bold; padding: 10px`,\n );\n }\n }\n\n warn(message: string): void {\n if (this.#levels.warn) {\n console.warn(message);\n this.#log('warn', message);\n }\n }\n\n setDebugLevels(levels: Partial<Record<TLogType, boolean>>): void {\n this.#levels = { ...this.#levels, ...levels };\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { EventEmitter, useMount } from '@apia/util';\nimport { CSSProperties, FC, useState } from 'react';\nimport { TestComponent } from './TestComponent';\nimport { ConsoleTestsLogger, TestsLogger } from './TestsLogger';\n\ntype TTask = {\n name: string;\n cb: () => Promise<boolean> | boolean;\n};\n\ntype TRunOptions = Partial<{\n /**\n * Delay al inicio\n */\n delay: number;\n /**\n * Cantidad de veces a ejecutar\n */\n n: number;\n /**\n * Demora entre reintentos\n */\n ms: number;\n /**\n * Omitir mensajes\n */\n silence: boolean;\n}>;\n\nexport class Test extends EventEmitter<{\n componentsListUpdated: boolean;\n componentMounted: string;\n}> {\n #components: TestComponent<any>[] = [];\n #ref: HTMLElement | null = null;\n\n logger: TestsLogger = new ConsoleTestsLogger();\n\n Component = ({ style }: { style: CSSProperties }) => {\n const [components, setComponents] = useState(this.#components);\n\n useMount(() => {\n return this.on('componentsListUpdated', () => {\n setComponents([...this.#components]);\n });\n });\n\n return (\n <div ref={(el) => (this.#ref = el)} style={{ display: 'none', ...style }}>\n {components.map((current) => (\n <current.Component\n ref={(el) => {\n if (el) this.emit('componentMounted', current.id);\n }}\n key={current.id}\n />\n ))}\n </div>\n );\n };\n\n /**\n * Devuelve el elemento html sobre el cual se están montando los tests\n */\n get root() {\n return this.#ref;\n }\n\n /**\n * Hace foco sobre un elemento del DOM y resuelve cuando puede hacer foco o\n * rompe cuando no puede hacer después de 5 intentos.\n */\n focus = (\n selector: string,\n check?: (element: HTMLElement) => boolean,\n options?: TRunOptions,\n ) => {\n const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);\n\n return new Promise<HTMLElement | null>((resolve) => {\n setTimeout(() => {\n let tries = actualOptions.n;\n const interval = setInterval(() => {\n this.logger.info(`Trying to focus with selector ${selector}`);\n tries--;\n const element = this.root?.querySelector<HTMLElement>(selector);\n\n if (element) {\n element.focus();\n\n if (check ? check(element) : element === document.activeElement) {\n clearInterval(interval);\n resolve(element);\n }\n }\n\n if (tries === 0) {\n clearInterval(interval);\n resolve(null);\n }\n }, actualOptions.ms);\n }, actualOptions.delay);\n });\n };\n\n /**\n * Anuncia un nuevo grupo de tests\n */\n it = (text: string) => {\n this.logger.title(text);\n };\n\n /**\n * Monta un componente para usarlo en el testing\n */\n mount = <T extends Record<string, unknown>>(\n name: string,\n component: FC<T>,\n initialProps: T,\n ) => {\n return new Promise<TestComponent<T>>((resolve) => {\n const newComponent = new TestComponent(\n name,\n this,\n component,\n initialProps,\n );\n this.#components.push(newComponent);\n this.emit('componentsListUpdated', true);\n const unsuscribe = this.on('componentMounted', (ev) => {\n if (ev === newComponent.id) {\n unsuscribe();\n resolve(newComponent);\n }\n });\n });\n };\n\n report = () => {\n this.logger.report();\n };\n\n #running = false;\n\n /**\n * Corre una tarea que va a intentar hasta n veces cada ms milisegundos antes\n * de resolver como fallo.\n *\n * @parameter options\n */\n should = async (\n name: string,\n cb: () => boolean | Promise<boolean>,\n options?: Omit<TRunOptions, 'silence'>,\n ) => {\n await this.wait('', () => !this.#running, { silence: true, n: 300 });\n\n this.#running = true;\n const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);\n\n return new Promise<void>((resolve) => {\n setTimeout(() => {\n let tries = actualOptions.n;\n\n const tryAgain = () => {\n window.requestAnimationFrame(() => {\n this.#run({ name, cb })\n .then((result) => {\n if (!result && tries-- > 0) {\n setTimeout(() => {\n tryAgain();\n }, actualOptions.ms);\n this.logger.warn(`[RETRY ${5 - tries}] ${name}`);\n } else if (result) {\n this.logger.success(`${name}`);\n resolve();\n this.#running = false;\n } else {\n this.logger.error(name);\n resolve();\n this.#running = false;\n }\n })\n .catch(() => {\n if (tries-- > 0) {\n setTimeout(() => {\n tryAgain();\n }, actualOptions.ms);\n this.logger.warn(`[RETRY ${5 - tries}] ${name}`);\n } else {\n this.logger.error(`[CATCH] ${name}`);\n resolve();\n this.#running = false;\n }\n });\n });\n };\n\n tryAgain();\n }, actualOptions.delay);\n });\n };\n\n unmount = (component: TestComponent<any>) => {\n this.#components = this.#components.filter(\n (current) => current !== component,\n );\n this.emit('componentsListUpdated', true);\n };\n\n /**\n * Espera por una condición a suceder, intentando n veces cada ms\n * milisegundos. La diferencia principal con should es que este método no se\n * ocupa de si un test pasa o falla, sino simplemente que trata de cumplir una\n * condición. Es especialmente útil para intentar hacer foco o esperar algún\n * evento en un futuro cercano.\n */\n wait = async (\n name: string,\n cb: () => boolean | Promise<boolean>,\n options?: TRunOptions,\n ) => {\n const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);\n\n return new Promise((resolve) => {\n setTimeout(() => {\n let tries = actualOptions.n;\n\n if (!actualOptions.silence) this.logger.info(`[WAITING] ${name}`);\n\n const tryAgain = () => {\n window.requestAnimationFrame(() => {\n if (tries-- > 0) {\n void (async () => {\n const result = await cb();\n if (!result) {\n setTimeout(() => {\n tryAgain();\n }, actualOptions.ms);\n } else {\n resolve(true);\n }\n })();\n } else {\n resolve(false);\n }\n });\n };\n\n tryAgain();\n }, actualOptions.delay);\n });\n };\n\n #run = async (task: TTask) => {\n try {\n const taskResult = await task.cb();\n\n if (taskResult) {\n return true;\n } else {\n return false;\n }\n } catch (e) {\n this.logger.error(String(e));\n return false;\n }\n };\n}\n\nexport { TestComponent, TestsLogger };\n"],"names":["__privateAdd","__privateGet","__spreadValues","__privateSet"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/index.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { EventEmitter, useMount } from '@apia/util';\nimport { CSSProperties, FC, useState } from 'react';\nimport { TestComponent } from './TestComponent';\nimport { ConsoleTestsLogger, TestsLogger } from './TestsLogger';\n\ntype TTask = {\n name: string;\n cb: () => Promise<boolean> | boolean;\n};\n\ntype TRunOptions = Partial<{\n /**\n * Delay al inicio\n */\n delay: number;\n /**\n * Cantidad de veces a ejecutar\n */\n n: number;\n /**\n * Demora entre reintentos\n */\n ms: number;\n /**\n * Omitir mensajes\n */\n silence: boolean;\n}>;\n\nexport class Test extends EventEmitter<{\n componentsListUpdated: boolean;\n componentMounted: string;\n}> {\n #components: TestComponent<any>[] = [];\n #ref: HTMLElement | null = null;\n\n logger: TestsLogger = new ConsoleTestsLogger();\n\n Component = ({ style }: { style: CSSProperties }) => {\n const [components, setComponents] = useState(this.#components);\n\n useMount(() => {\n return this.on('componentsListUpdated', () => {\n setComponents([...this.#components]);\n });\n });\n\n return (\n <div ref={(el) => (this.#ref = el)} style={{ display: 'none', ...style }}>\n {components.map((current) => (\n <current.Component\n ref={(el) => {\n if (el) this.emit('componentMounted', current.id);\n }}\n key={current.id}\n />\n ))}\n </div>\n );\n };\n\n /**\n * Devuelve el elemento html sobre el cual se están montando los tests\n */\n get root() {\n return this.#ref;\n }\n\n /**\n * Hace foco sobre un elemento del DOM y resuelve cuando puede hacer foco o\n * rompe cuando no puede hacer después de 5 intentos.\n */\n focus = (\n selector: string,\n check?: (element: HTMLElement) => boolean,\n options?: TRunOptions,\n ) => {\n const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);\n\n return new Promise<HTMLElement | null>((resolve) => {\n setTimeout(() => {\n let tries = actualOptions.n;\n const interval = setInterval(() => {\n this.logger.info(`Trying to focus with selector ${selector}`);\n tries--;\n const element = this.root?.querySelector<HTMLElement>(selector);\n\n if (element) {\n element.focus();\n\n if (check ? check(element) : element === document.activeElement) {\n clearInterval(interval);\n resolve(element);\n }\n }\n\n if (tries === 0) {\n clearInterval(interval);\n resolve(null);\n }\n }, actualOptions.ms);\n }, actualOptions.delay);\n });\n };\n\n /**\n * Anuncia un nuevo grupo de tests\n */\n it = (text: string) => {\n this.logger.title(text);\n };\n\n /**\n * Monta un componente para usarlo en el testing\n */\n mount = <T extends Record<string, unknown>>(\n name: string,\n component: FC<T>,\n initialProps: T,\n ) => {\n return new Promise<TestComponent<T>>((resolve) => {\n const newComponent = new TestComponent(\n name,\n this,\n component,\n initialProps,\n );\n this.#components.push(newComponent);\n this.emit('componentsListUpdated', true);\n const unsuscribe = this.on('componentMounted', (ev) => {\n if (ev === newComponent.id) {\n unsuscribe();\n resolve(newComponent);\n }\n });\n });\n };\n\n report = () => {\n this.logger.report();\n };\n\n #running = false;\n\n /**\n * Corre una tarea que va a intentar hasta n veces cada ms milisegundos antes\n * de resolver como fallo.\n *\n * @parameter options\n */\n should = async (\n name: string,\n cb: () => boolean | Promise<boolean>,\n options?: Omit<TRunOptions, 'silence'>,\n ) => {\n await this.wait('', () => !this.#running, { silence: true, n: 300 });\n\n this.#running = true;\n const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);\n\n return new Promise<void>((resolve) => {\n setTimeout(() => {\n let tries = actualOptions.n;\n\n const tryAgain = () => {\n window.requestAnimationFrame(() => {\n this.#run({ name, cb })\n .then((result) => {\n if (!result && tries-- > 0) {\n setTimeout(() => {\n tryAgain();\n }, actualOptions.ms);\n this.logger.warn(`[RETRY ${5 - tries}] ${name}`);\n } else if (result) {\n this.logger.success(`${name}`);\n resolve();\n this.#running = false;\n } else {\n this.logger.error(name);\n resolve();\n this.#running = false;\n }\n })\n .catch(() => {\n if (tries-- > 0) {\n setTimeout(() => {\n tryAgain();\n }, actualOptions.ms);\n this.logger.warn(`[RETRY ${5 - tries}] ${name}`);\n } else {\n this.logger.error(`[CATCH] ${name}`);\n resolve();\n this.#running = false;\n }\n });\n });\n };\n\n tryAgain();\n }, actualOptions.delay);\n });\n };\n\n unmount = (component: TestComponent<any>) => {\n this.#components = this.#components.filter(\n (current) => current !== component,\n );\n this.emit('componentsListUpdated', true);\n };\n\n /**\n * Espera por una condición a suceder, intentando n veces cada ms\n * milisegundos. La diferencia principal con should es que este método no se\n * ocupa de si un test pasa o falla, sino simplemente que trata de cumplir una\n * condición. Es especialmente útil para intentar hacer foco o esperar algún\n * evento en un futuro cercano.\n */\n wait = async (\n name: string,\n cb: () => boolean | Promise<boolean>,\n options?: TRunOptions,\n ) => {\n const actualOptions = Object.assign({ delay: 0, ms: 250, n: 5 }, options);\n\n return new Promise((resolve) => {\n setTimeout(() => {\n let tries = actualOptions.n;\n\n if (!actualOptions.silence) this.logger.info(`[WAITING] ${name}`);\n\n const tryAgain = () => {\n window.requestAnimationFrame(() => {\n if (tries-- > 0) {\n void (async () => {\n const result = await cb();\n if (!result) {\n setTimeout(() => {\n tryAgain();\n }, actualOptions.ms);\n } else {\n resolve(true);\n }\n })();\n } else {\n resolve(false);\n }\n });\n };\n\n tryAgain();\n }, actualOptions.delay);\n });\n };\n\n #run = async (task: TTask) => {\n try {\n const taskResult = await task.cb();\n\n if (taskResult) {\n return true;\n } else {\n return false;\n }\n } catch (e) {\n this.logger.error(String(e));\n return false;\n }\n };\n}\n\nexport { TestComponent, TestsLogger };\n"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,29 +1,26 @@
|
|
|
1
1
|
{
|
|
2
|
-
"author": "alexisleite <alexisleite@live.com>",
|
|
3
|
-
"homepage": "",
|
|
4
|
-
"license": "MIT",
|
|
5
2
|
"name": "@apia/testing",
|
|
3
|
+
"version": "2.0.0",
|
|
6
4
|
"sideEffects": false,
|
|
7
|
-
"
|
|
8
|
-
"
|
|
9
|
-
"
|
|
5
|
+
"author": "Alexis Leite <alexisleite@live.com>",
|
|
6
|
+
"main": "dist/index.js",
|
|
7
|
+
"module": "dist/index.js",
|
|
8
|
+
"type": "module",
|
|
9
|
+
"typings": "dist/index.d.ts",
|
|
10
10
|
"scripts": {
|
|
11
|
-
"
|
|
12
|
-
"
|
|
13
|
-
"
|
|
11
|
+
"libDev": "rollup --config ../../config/rollup.common.mjs --environment MODE:development,ENTRY:index.tsx",
|
|
12
|
+
"libBuild": "rollup --config ../../config/rollup.common.mjs --environment MODE:production,ENTRY:index.tsx",
|
|
13
|
+
"libWatch": "rollup --watch --config ../../config/rollup.common.mjs --environment MODE:development,ENTRY:index.tsx,WATCH:true"
|
|
14
|
+
},
|
|
15
|
+
"dependencies": {
|
|
16
|
+
"@apia/util": "^2.0.0"
|
|
14
17
|
},
|
|
15
18
|
"devDependencies": {
|
|
16
|
-
"@
|
|
17
|
-
"@
|
|
18
|
-
"@
|
|
19
|
-
"
|
|
20
|
-
"
|
|
21
|
-
"esbuild": "^0.17.14",
|
|
22
|
-
"rollup": "^3.20.2",
|
|
23
|
-
"rollup-plugin-bundle-analyzer": "^1.6.6",
|
|
24
|
-
"rollup-plugin-dts": "^5.3.0",
|
|
25
|
-
"rollup-plugin-esbuild": "^5.0.0",
|
|
26
|
-
"typescript": "^4.9.5"
|
|
19
|
+
"@types/react": "^18.2.43",
|
|
20
|
+
"@types/react-dom": "^18.2.17",
|
|
21
|
+
"@typescript-eslint/eslint-plugin": "^6.14.0",
|
|
22
|
+
"axios": "^1.3.5",
|
|
23
|
+
"typescript": "5.4.2"
|
|
27
24
|
},
|
|
28
25
|
"peerDependencies": {
|
|
29
26
|
"react": "^18.2.0",
|
|
@@ -33,13 +30,5 @@
|
|
|
33
30
|
"access": "public",
|
|
34
31
|
"registry": "https://registry.npmjs.org/"
|
|
35
32
|
},
|
|
36
|
-
"
|
|
37
|
-
"type": "git",
|
|
38
|
-
"url": "http://corp-gitlab-01.domst.st.net/products/apia/ApiaNPMPackages.git",
|
|
39
|
-
"directory": "packages/initiator"
|
|
40
|
-
},
|
|
41
|
-
"dependencies": {
|
|
42
|
-
"@apia/util": "^1.0.4"
|
|
43
|
-
},
|
|
44
|
-
"gitHead": "6c198a4643a693e25634e89cb227c56d9d12476d"
|
|
33
|
+
"gitHead": "755c990cc9875e99922cc0f7194d9f0a479bdc71"
|
|
45
34
|
}
|
package/LICENSE.md
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright (c) [year] [fullname]
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
SOFTWARE.
|
package/README.md
DELETED
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
# Initiator
|
|
2
|
-
|
|
3
|
-
Este package se creó con la única utilidad de copiarlo entero y pegarlo a la hora de crear un nuevo package.
|
|
4
|
-
|
|
5
|
-
Este iniciador permite crear un paquete que compila typescript y puede ser importado desde otros packages.
|
|
6
|
-
|
|
7
|
-
## IMPORTANTE
|
|
8
|
-
|
|
9
|
-
Los archivos **tsconfig.json** y **tsup.config.ts** no son archivos únicos sino symlinks a archivos de configuración comunes a todos los packages. En caso de que sea necesario modificar alguno de ellos **que en la gran mayoría de los casos no sería necesario**, es necesario eliminar el archivo a modificar y crear uno nuevo.
|
|
10
|
-
|
|
11
|
-
## Procedimiento
|
|
12
|
-
|
|
13
|
-
- Copiar la carpeta initiator y pegarla con otro nombre dentro de packages.
|
|
14
|
-
- Modificar el package.json:
|
|
15
|
-
- Eliminar la línea ```private: true```.
|
|
16
|
-
- Cambiar la ocurrencia `initiator` por el nombre del nuevo paquete.
|
|
17
|
-
- Agregar los scripts convenientes: dev, build, etc.
|
|
18
|
-
- Ejecutar el comando lerna bootstrap desde la carpeta raíz.
|
|
19
|
-
|
|
20
|
-
Luego de ejecutar estos pasos, el package estaría listo para comenzar a usarse.
|
|
21
|
-
|
|
22
|
-
Este package trae como dependencias por defecto theme-ui y react. Si se desea agregar más dependencias se debe ejecutar el comando ```lerna add --scope="@apia/packageName" dependencyName```. Ejemplo, si creamos un paquete con el nombre @apia/myPackage y queremos agregar lodash como dependencia, ejecutamos el comando ```lerna add --scope="@apia/myPackage" lodash```.
|
|
23
|
-
|
|
24
|
-
**Importante 1**: Dado que estamos desarrollando packages, es importante determinar si las dependencias que vamos a agregar son de tipo dependency o de tipo peerDependency.
|
|
25
|
-
|
|
26
|
-
**Importante 2**: lerna no permite instalar de a varias dependencias a la vez como lo hace npm, por lo tanto, si se desea agregar varias dependencias se debe ejecutar el comando anterior tantas veces como dependencias se quiera agregar.
|
|
27
|
-
|
|
28
|
-
**Importante 3**: React y theme-ui vienen instalados como peerDependencies. En caso de no ser necesarios pueden ser removidos, pero en cualquier caso asegurarse de que estas dependencias no sean instaladas como dependencies puesto que esto causaría comportamientos indeseados en la aplicación.
|
package/cleanDist.json
DELETED
package/entries.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
["./src/index.tsx"]
|