@git.zone/tstest 3.1.1 → 3.1.4
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_ts/00_commitinfo_data.js +1 -1
- package/dist_ts_tapbundle/webhelpers.js +12 -2
- package/npmextra.json +11 -5
- package/package.json +13 -12
- package/readme.md +19 -0
- package/ts/00_commitinfo_data.ts +1 -1
- package/dist_ts/tstest.classes.tap.parser.old.d.ts +0 -50
- package/dist_ts/tstest.classes.tap.parser.old.js +0 -332
- package/dist_ts_tapbundle/tapbundle.protocols.d.ts +0 -88
- package/dist_ts_tapbundle/tapbundle.protocols.js +0 -168
- package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.d.ts +0 -8
- package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.js +0 -9
- package/dist_ts_tapbundle/ts_tapbundle/index.d.ts +0 -6
- package/dist_ts_tapbundle/ts_tapbundle/index.js +0 -7
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.d.ts +0 -10
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.js +0 -13
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.d.ts +0 -104
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.js +0 -401
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.d.ts +0 -38
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.js +0 -110
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.d.ts +0 -109
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.js +0 -241
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.d.ts +0 -8
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.js +0 -7
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.d.ts +0 -8
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.js +0 -10
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.d.ts +0 -3
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.js +0 -5
- package/dist_ts_tapbundle/ts_tapbundle/webhelpers.d.ts +0 -7
- package/dist_ts_tapbundle/ts_tapbundle/webhelpers.js +0 -35
- package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.d.ts +0 -5
- package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.js +0 -13
- package/dist_ts_tapbundle/ts_tapbundle_node/plugins.d.ts +0 -11
- package/dist_ts_tapbundle/ts_tapbundle_node/plugins.js +0 -14
|
@@ -1,401 +0,0 @@
|
|
|
1
|
-
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
-
import { PreTask } from './tapbundle.classes.pretask.js';
|
|
3
|
-
import { TapTest } from './tapbundle.classes.taptest.js';
|
|
4
|
-
class TestBuilder {
|
|
5
|
-
constructor(tap) {
|
|
6
|
-
this._tags = [];
|
|
7
|
-
this._priority = 'medium';
|
|
8
|
-
this._tap = tap;
|
|
9
|
-
}
|
|
10
|
-
tags(...tags) {
|
|
11
|
-
this._tags = tags;
|
|
12
|
-
return this;
|
|
13
|
-
}
|
|
14
|
-
priority(level) {
|
|
15
|
-
this._priority = level;
|
|
16
|
-
return this;
|
|
17
|
-
}
|
|
18
|
-
retry(count) {
|
|
19
|
-
this._retryCount = count;
|
|
20
|
-
return this;
|
|
21
|
-
}
|
|
22
|
-
timeout(ms) {
|
|
23
|
-
this._timeoutMs = ms;
|
|
24
|
-
return this;
|
|
25
|
-
}
|
|
26
|
-
test(description, testFunction) {
|
|
27
|
-
const test = this._tap.test(description, testFunction, 'normal');
|
|
28
|
-
// Apply settings to the test
|
|
29
|
-
if (this._tags.length > 0) {
|
|
30
|
-
test.tags = this._tags;
|
|
31
|
-
}
|
|
32
|
-
test.priority = this._priority;
|
|
33
|
-
if (this._retryCount !== undefined) {
|
|
34
|
-
test.tapTools.retry(this._retryCount);
|
|
35
|
-
}
|
|
36
|
-
if (this._timeoutMs !== undefined) {
|
|
37
|
-
test.timeoutMs = this._timeoutMs;
|
|
38
|
-
}
|
|
39
|
-
return test;
|
|
40
|
-
}
|
|
41
|
-
testOnly(description, testFunction) {
|
|
42
|
-
const test = this._tap.test(description, testFunction, 'only');
|
|
43
|
-
// Apply settings to the test
|
|
44
|
-
if (this._tags.length > 0) {
|
|
45
|
-
test.tags = this._tags;
|
|
46
|
-
}
|
|
47
|
-
test.priority = this._priority;
|
|
48
|
-
if (this._retryCount !== undefined) {
|
|
49
|
-
test.tapTools.retry(this._retryCount);
|
|
50
|
-
}
|
|
51
|
-
if (this._timeoutMs !== undefined) {
|
|
52
|
-
test.timeoutMs = this._timeoutMs;
|
|
53
|
-
}
|
|
54
|
-
return test;
|
|
55
|
-
}
|
|
56
|
-
testSkip(description, testFunction) {
|
|
57
|
-
const test = this._tap.test(description, testFunction, 'skip');
|
|
58
|
-
// Apply settings to the test
|
|
59
|
-
if (this._tags.length > 0) {
|
|
60
|
-
test.tags = this._tags;
|
|
61
|
-
}
|
|
62
|
-
test.priority = this._priority;
|
|
63
|
-
if (this._retryCount !== undefined) {
|
|
64
|
-
test.tapTools.retry(this._retryCount);
|
|
65
|
-
}
|
|
66
|
-
if (this._timeoutMs !== undefined) {
|
|
67
|
-
test.timeoutMs = this._timeoutMs;
|
|
68
|
-
}
|
|
69
|
-
return test;
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
export class Tap {
|
|
73
|
-
constructor() {
|
|
74
|
-
this._skipCount = 0;
|
|
75
|
-
this._filterTags = [];
|
|
76
|
-
/**
|
|
77
|
-
* skips a test
|
|
78
|
-
* tests marked with tap.skip.test() are never executed
|
|
79
|
-
*/
|
|
80
|
-
this.skip = {
|
|
81
|
-
test: (descriptionArg, functionArg) => {
|
|
82
|
-
console.log(`skipped test: ${descriptionArg}`);
|
|
83
|
-
this._skipCount++;
|
|
84
|
-
},
|
|
85
|
-
testParallel: (descriptionArg, functionArg) => {
|
|
86
|
-
console.log(`skipped test: ${descriptionArg}`);
|
|
87
|
-
this._skipCount++;
|
|
88
|
-
},
|
|
89
|
-
};
|
|
90
|
-
/**
|
|
91
|
-
* only executes tests marked as ONLY
|
|
92
|
-
*/
|
|
93
|
-
this.only = {
|
|
94
|
-
test: (descriptionArg, testFunctionArg) => {
|
|
95
|
-
this.test(descriptionArg, testFunctionArg, 'only');
|
|
96
|
-
},
|
|
97
|
-
};
|
|
98
|
-
this._tapPreTasks = [];
|
|
99
|
-
this._tapTests = [];
|
|
100
|
-
this._tapTestsOnly = [];
|
|
101
|
-
this._currentSuite = null;
|
|
102
|
-
this._rootSuites = [];
|
|
103
|
-
// Get filter tags from environment
|
|
104
|
-
if (process.env.TSTEST_FILTER_TAGS) {
|
|
105
|
-
this._filterTags = process.env.TSTEST_FILTER_TAGS.split(',');
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
// Fluent test builder
|
|
109
|
-
tags(...tags) {
|
|
110
|
-
const builder = new TestBuilder(this);
|
|
111
|
-
return builder.tags(...tags);
|
|
112
|
-
}
|
|
113
|
-
priority(level) {
|
|
114
|
-
const builder = new TestBuilder(this);
|
|
115
|
-
return builder.priority(level);
|
|
116
|
-
}
|
|
117
|
-
retry(count) {
|
|
118
|
-
const builder = new TestBuilder(this);
|
|
119
|
-
return builder.retry(count);
|
|
120
|
-
}
|
|
121
|
-
timeout(ms) {
|
|
122
|
-
const builder = new TestBuilder(this);
|
|
123
|
-
return builder.timeout(ms);
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* Normal test function, will run one by one
|
|
127
|
-
* @param testDescription - A description of what the test does
|
|
128
|
-
* @param testFunction - A Function that returns a Promise and resolves or rejects
|
|
129
|
-
*/
|
|
130
|
-
test(testDescription, testFunction, modeArg = 'normal') {
|
|
131
|
-
const localTest = new TapTest({
|
|
132
|
-
description: testDescription,
|
|
133
|
-
testFunction,
|
|
134
|
-
parallel: false,
|
|
135
|
-
});
|
|
136
|
-
// No options applied here - use the fluent builder syntax instead
|
|
137
|
-
// If we're in a suite, add test to the suite
|
|
138
|
-
if (this._currentSuite) {
|
|
139
|
-
this._currentSuite.tests.push(localTest);
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
// Otherwise add to global test list
|
|
143
|
-
if (modeArg === 'normal') {
|
|
144
|
-
this._tapTests.push(localTest);
|
|
145
|
-
}
|
|
146
|
-
else if (modeArg === 'only') {
|
|
147
|
-
this._tapTestsOnly.push(localTest);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
return localTest;
|
|
151
|
-
}
|
|
152
|
-
preTask(descriptionArg, functionArg) {
|
|
153
|
-
this._tapPreTasks.push(new PreTask(descriptionArg, functionArg));
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* A parallel test that will not be waited for before the next starts.
|
|
157
|
-
* @param testDescription - A description of what the test does
|
|
158
|
-
* @param testFunction - A Function that returns a Promise and resolves or rejects
|
|
159
|
-
*/
|
|
160
|
-
testParallel(testDescription, testFunction) {
|
|
161
|
-
const localTest = new TapTest({
|
|
162
|
-
description: testDescription,
|
|
163
|
-
testFunction,
|
|
164
|
-
parallel: true,
|
|
165
|
-
});
|
|
166
|
-
if (this._currentSuite) {
|
|
167
|
-
this._currentSuite.tests.push(localTest);
|
|
168
|
-
}
|
|
169
|
-
else {
|
|
170
|
-
this._tapTests.push(localTest);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
/**
|
|
174
|
-
* Create a test suite for grouping related tests
|
|
175
|
-
*/
|
|
176
|
-
describe(description, suiteFunction) {
|
|
177
|
-
const suite = {
|
|
178
|
-
description,
|
|
179
|
-
tests: [],
|
|
180
|
-
children: [],
|
|
181
|
-
parent: this._currentSuite,
|
|
182
|
-
};
|
|
183
|
-
// Add to parent or root
|
|
184
|
-
if (this._currentSuite) {
|
|
185
|
-
this._currentSuite.children.push(suite);
|
|
186
|
-
}
|
|
187
|
-
else {
|
|
188
|
-
this._rootSuites.push(suite);
|
|
189
|
-
}
|
|
190
|
-
// Execute suite function in context
|
|
191
|
-
const previousSuite = this._currentSuite;
|
|
192
|
-
this._currentSuite = suite;
|
|
193
|
-
try {
|
|
194
|
-
suiteFunction();
|
|
195
|
-
}
|
|
196
|
-
finally {
|
|
197
|
-
this._currentSuite = previousSuite;
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
/**
|
|
201
|
-
* Set up a function to run before each test in the current suite
|
|
202
|
-
*/
|
|
203
|
-
beforeEach(setupFunction) {
|
|
204
|
-
if (this._currentSuite) {
|
|
205
|
-
this._currentSuite.beforeEach = setupFunction;
|
|
206
|
-
}
|
|
207
|
-
else {
|
|
208
|
-
throw new Error('beforeEach can only be used inside a describe block');
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
/**
|
|
212
|
-
* Set up a function to run after each test in the current suite
|
|
213
|
-
*/
|
|
214
|
-
afterEach(teardownFunction) {
|
|
215
|
-
if (this._currentSuite) {
|
|
216
|
-
this._currentSuite.afterEach = teardownFunction;
|
|
217
|
-
}
|
|
218
|
-
else {
|
|
219
|
-
throw new Error('afterEach can only be used inside a describe block');
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
/**
|
|
223
|
-
* collect all tests from suites
|
|
224
|
-
*/
|
|
225
|
-
_collectTests(suite, tests = []) {
|
|
226
|
-
tests.push(...suite.tests);
|
|
227
|
-
for (const childSuite of suite.children) {
|
|
228
|
-
this._collectTests(childSuite, tests);
|
|
229
|
-
}
|
|
230
|
-
return tests;
|
|
231
|
-
}
|
|
232
|
-
/**
|
|
233
|
-
* starts the test evaluation
|
|
234
|
-
*/
|
|
235
|
-
async start(optionsArg) {
|
|
236
|
-
// lets set the tapbundle promise
|
|
237
|
-
const smartenvInstance = new plugins.smartenv.Smartenv();
|
|
238
|
-
smartenvInstance.isBrowser
|
|
239
|
-
? (globalThis.tapbundleDeferred = plugins.smartpromise.defer())
|
|
240
|
-
: null;
|
|
241
|
-
// Initialize path helpers for Node.js environment
|
|
242
|
-
if (!smartenvInstance.isBrowser) {
|
|
243
|
-
try {
|
|
244
|
-
const { initializePathHelpers } = await import('../ts_tapbundle_node/classes.pathinject.js');
|
|
245
|
-
initializePathHelpers();
|
|
246
|
-
}
|
|
247
|
-
catch (error) {
|
|
248
|
-
// tapbundle_node not available in browser environment
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
// lets continue with running the tests
|
|
252
|
-
const promiseArray = [];
|
|
253
|
-
// Collect all tests including those in suites
|
|
254
|
-
let allTests = [...this._tapTests];
|
|
255
|
-
for (const suite of this._rootSuites) {
|
|
256
|
-
this._collectTests(suite, allTests);
|
|
257
|
-
}
|
|
258
|
-
// safeguard against empty test array
|
|
259
|
-
if (allTests.length === 0 && this._tapTestsOnly.length === 0) {
|
|
260
|
-
console.log('no tests specified. Ending here!');
|
|
261
|
-
return;
|
|
262
|
-
}
|
|
263
|
-
// determine which tests to run
|
|
264
|
-
let concerningTests;
|
|
265
|
-
if (this._tapTestsOnly.length > 0) {
|
|
266
|
-
concerningTests = this._tapTestsOnly;
|
|
267
|
-
}
|
|
268
|
-
else {
|
|
269
|
-
concerningTests = allTests;
|
|
270
|
-
}
|
|
271
|
-
// Filter tests by tags if specified
|
|
272
|
-
if (this._filterTags.length > 0) {
|
|
273
|
-
concerningTests = concerningTests.filter(test => {
|
|
274
|
-
// Skip tests without tags when filtering is active
|
|
275
|
-
if (!test.tags || test.tags.length === 0) {
|
|
276
|
-
return false;
|
|
277
|
-
}
|
|
278
|
-
// Check if test has any of the filter tags
|
|
279
|
-
return test.tags.some(tag => this._filterTags.includes(tag));
|
|
280
|
-
});
|
|
281
|
-
}
|
|
282
|
-
// lets run the pretasks
|
|
283
|
-
for (const preTask of this._tapPreTasks) {
|
|
284
|
-
await preTask.run();
|
|
285
|
-
}
|
|
286
|
-
// Count actual tests that will be run
|
|
287
|
-
console.log(`1..${concerningTests.length}`);
|
|
288
|
-
// Run tests from suites with lifecycle hooks
|
|
289
|
-
let testKey = 0;
|
|
290
|
-
// Run all concerning tests (filtered by tags if applicable)
|
|
291
|
-
for (const currentTest of concerningTests) {
|
|
292
|
-
const testPromise = currentTest.run(testKey++);
|
|
293
|
-
if (currentTest.parallel) {
|
|
294
|
-
promiseArray.push(testPromise);
|
|
295
|
-
}
|
|
296
|
-
else {
|
|
297
|
-
await testPromise;
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
await Promise.all(promiseArray);
|
|
301
|
-
// when tests have been run and all promises are fullfilled
|
|
302
|
-
const failReasons = [];
|
|
303
|
-
const executionNotes = [];
|
|
304
|
-
// collect failed tests
|
|
305
|
-
for (const tapTest of concerningTests) {
|
|
306
|
-
if (tapTest.status !== 'success' && tapTest.status !== 'skipped') {
|
|
307
|
-
failReasons.push(`Test ${tapTest.testKey + 1} failed with status ${tapTest.status}:\n` +
|
|
308
|
-
`|| ${tapTest.description}\n` +
|
|
309
|
-
`|| for more information please take a look the logs above`);
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
// render fail Reasons
|
|
313
|
-
for (const failReason of failReasons) {
|
|
314
|
-
console.log(failReason);
|
|
315
|
-
}
|
|
316
|
-
if (optionsArg && optionsArg.throwOnError && failReasons.length > 0) {
|
|
317
|
-
if (!smartenvInstance.isBrowser)
|
|
318
|
-
process.exit(1);
|
|
319
|
-
}
|
|
320
|
-
if (smartenvInstance.isBrowser) {
|
|
321
|
-
globalThis.tapbundleDeferred.resolve();
|
|
322
|
-
}
|
|
323
|
-
}
|
|
324
|
-
/**
|
|
325
|
-
* Run tests in a suite with lifecycle hooks
|
|
326
|
-
*/
|
|
327
|
-
async _runSuite(parentSuite, suites, promiseArray, context) {
|
|
328
|
-
for (const suite of suites) {
|
|
329
|
-
// Run beforeEach from parent suites
|
|
330
|
-
const beforeEachFunctions = [];
|
|
331
|
-
let currentSuite = suite;
|
|
332
|
-
while (currentSuite) {
|
|
333
|
-
if (currentSuite.beforeEach) {
|
|
334
|
-
beforeEachFunctions.unshift(currentSuite.beforeEach);
|
|
335
|
-
}
|
|
336
|
-
currentSuite = currentSuite.parent || null;
|
|
337
|
-
}
|
|
338
|
-
// Run tests in this suite
|
|
339
|
-
for (const test of suite.tests) {
|
|
340
|
-
// Create wrapper test function that includes lifecycle hooks
|
|
341
|
-
const originalFunction = test.testFunction;
|
|
342
|
-
test.testFunction = async (tapTools) => {
|
|
343
|
-
// Run all beforeEach hooks
|
|
344
|
-
for (const beforeEach of beforeEachFunctions) {
|
|
345
|
-
await beforeEach(tapTools);
|
|
346
|
-
}
|
|
347
|
-
// Run the actual test
|
|
348
|
-
const result = await originalFunction(tapTools);
|
|
349
|
-
// Run afterEach hooks in reverse order
|
|
350
|
-
const afterEachFunctions = [];
|
|
351
|
-
currentSuite = suite;
|
|
352
|
-
while (currentSuite) {
|
|
353
|
-
if (currentSuite.afterEach) {
|
|
354
|
-
afterEachFunctions.push(currentSuite.afterEach);
|
|
355
|
-
}
|
|
356
|
-
currentSuite = currentSuite.parent || null;
|
|
357
|
-
}
|
|
358
|
-
for (const afterEach of afterEachFunctions) {
|
|
359
|
-
await afterEach(tapTools);
|
|
360
|
-
}
|
|
361
|
-
return result;
|
|
362
|
-
};
|
|
363
|
-
const testPromise = test.run(context.testKey++);
|
|
364
|
-
if (test.parallel) {
|
|
365
|
-
promiseArray.push(testPromise);
|
|
366
|
-
}
|
|
367
|
-
else {
|
|
368
|
-
await testPromise;
|
|
369
|
-
}
|
|
370
|
-
}
|
|
371
|
-
// Recursively run child suites
|
|
372
|
-
await this._runSuite(suite, suite.children, promiseArray, context);
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
async stopForcefully(codeArg = 0, directArg = false) {
|
|
376
|
-
console.log(`tap stopping forcefully! Code: ${codeArg} / Direct: ${directArg}`);
|
|
377
|
-
if (directArg) {
|
|
378
|
-
process.exit(codeArg);
|
|
379
|
-
}
|
|
380
|
-
else {
|
|
381
|
-
setTimeout(() => {
|
|
382
|
-
process.exit(codeArg);
|
|
383
|
-
}, 10);
|
|
384
|
-
}
|
|
385
|
-
}
|
|
386
|
-
/**
|
|
387
|
-
* handle errors
|
|
388
|
-
*/
|
|
389
|
-
threw(err) {
|
|
390
|
-
console.log(err);
|
|
391
|
-
}
|
|
392
|
-
/**
|
|
393
|
-
* Explicitly fail the current test with a custom message
|
|
394
|
-
* @param message - The failure message to display
|
|
395
|
-
*/
|
|
396
|
-
fail(message = 'Test failed') {
|
|
397
|
-
throw new Error(message);
|
|
398
|
-
}
|
|
399
|
-
}
|
|
400
|
-
export const tap = new Tap();
|
|
401
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tapbundle.classes.tap.js","sourceRoot":"","sources":["../../ts_tapbundle/tapbundle.classes.tap.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { TapTools } from './tapbundle.classes.taptools.js';
|
|
2
|
-
import { HrtMeasurement } from '@push.rocks/smarttime';
|
|
3
|
-
export type TTestStatus = 'success' | 'error' | 'pending' | 'errorAfterSuccess' | 'timeout' | 'skipped';
|
|
4
|
-
export interface ITestFunction<T> {
|
|
5
|
-
(tapTools?: TapTools): Promise<T>;
|
|
6
|
-
}
|
|
7
|
-
export declare class TapTest<T = unknown> {
|
|
8
|
-
description: string;
|
|
9
|
-
failureAllowed: boolean;
|
|
10
|
-
hrtMeasurement: HrtMeasurement;
|
|
11
|
-
parallel: boolean;
|
|
12
|
-
status: TTestStatus;
|
|
13
|
-
tapTools: TapTools;
|
|
14
|
-
testFunction: ITestFunction<T>;
|
|
15
|
-
testKey: number;
|
|
16
|
-
timeoutMs?: number;
|
|
17
|
-
isTodo: boolean;
|
|
18
|
-
todoReason?: string;
|
|
19
|
-
tags: string[];
|
|
20
|
-
priority: 'high' | 'medium' | 'low';
|
|
21
|
-
fileName?: string;
|
|
22
|
-
private testDeferred;
|
|
23
|
-
testPromise: Promise<TapTest<T>>;
|
|
24
|
-
private testResultDeferred;
|
|
25
|
-
testResultPromise: Promise<T>;
|
|
26
|
-
/**
|
|
27
|
-
* constructor
|
|
28
|
-
*/
|
|
29
|
-
constructor(optionsArg: {
|
|
30
|
-
description: string;
|
|
31
|
-
testFunction: ITestFunction<T>;
|
|
32
|
-
parallel: boolean;
|
|
33
|
-
});
|
|
34
|
-
/**
|
|
35
|
-
* run the test
|
|
36
|
-
*/
|
|
37
|
-
run(testKeyArg: number): Promise<void>;
|
|
38
|
-
}
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
-
import { tapCreator } from './tapbundle.tapcreator.js';
|
|
3
|
-
import { TapTools, SkipError } from './tapbundle.classes.taptools.js';
|
|
4
|
-
// imported interfaces
|
|
5
|
-
import { Deferred } from '@push.rocks/smartpromise';
|
|
6
|
-
import { HrtMeasurement } from '@push.rocks/smarttime';
|
|
7
|
-
export class TapTest {
|
|
8
|
-
/**
|
|
9
|
-
* constructor
|
|
10
|
-
*/
|
|
11
|
-
constructor(optionsArg) {
|
|
12
|
-
this.isTodo = false;
|
|
13
|
-
this.tags = [];
|
|
14
|
-
this.priority = 'medium';
|
|
15
|
-
this.testDeferred = plugins.smartpromise.defer();
|
|
16
|
-
this.testPromise = this.testDeferred.promise;
|
|
17
|
-
this.testResultDeferred = plugins.smartpromise.defer();
|
|
18
|
-
this.testResultPromise = this.testResultDeferred.promise;
|
|
19
|
-
this.description = optionsArg.description;
|
|
20
|
-
this.hrtMeasurement = new HrtMeasurement();
|
|
21
|
-
this.parallel = optionsArg.parallel;
|
|
22
|
-
this.status = 'pending';
|
|
23
|
-
this.tapTools = new TapTools(this);
|
|
24
|
-
this.testFunction = optionsArg.testFunction;
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* run the test
|
|
28
|
-
*/
|
|
29
|
-
async run(testKeyArg) {
|
|
30
|
-
this.testKey = testKeyArg;
|
|
31
|
-
const testNumber = testKeyArg + 1;
|
|
32
|
-
// Handle todo tests
|
|
33
|
-
if (this.isTodo) {
|
|
34
|
-
const todoText = this.todoReason ? `# TODO ${this.todoReason}` : '# TODO';
|
|
35
|
-
console.log(`ok ${testNumber} - ${this.description} ${todoText}`);
|
|
36
|
-
this.status = 'success';
|
|
37
|
-
this.testDeferred.resolve(this);
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
// Run test with retries
|
|
41
|
-
let lastError;
|
|
42
|
-
const maxRetries = this.tapTools.maxRetries;
|
|
43
|
-
for (let attempt = 0; attempt <= maxRetries; attempt++) {
|
|
44
|
-
this.hrtMeasurement.start();
|
|
45
|
-
try {
|
|
46
|
-
// Set up timeout if specified
|
|
47
|
-
let timeoutHandle;
|
|
48
|
-
let timeoutPromise = null;
|
|
49
|
-
if (this.timeoutMs) {
|
|
50
|
-
timeoutPromise = new Promise((_, reject) => {
|
|
51
|
-
timeoutHandle = setTimeout(() => {
|
|
52
|
-
this.status = 'timeout';
|
|
53
|
-
reject(new Error(`Test timed out after ${this.timeoutMs}ms`));
|
|
54
|
-
}, this.timeoutMs);
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
// Run the test function with potential timeout
|
|
58
|
-
const testPromise = this.testFunction(this.tapTools);
|
|
59
|
-
const testReturnValue = timeoutPromise
|
|
60
|
-
? await Promise.race([testPromise, timeoutPromise])
|
|
61
|
-
: await testPromise;
|
|
62
|
-
// Clear timeout if test completed
|
|
63
|
-
if (timeoutHandle) {
|
|
64
|
-
clearTimeout(timeoutHandle);
|
|
65
|
-
}
|
|
66
|
-
this.hrtMeasurement.stop();
|
|
67
|
-
console.log(`ok ${testNumber} - ${this.description} # time=${this.hrtMeasurement.milliSeconds}ms`);
|
|
68
|
-
this.status = 'success';
|
|
69
|
-
this.testDeferred.resolve(this);
|
|
70
|
-
this.testResultDeferred.resolve(testReturnValue);
|
|
71
|
-
return; // Success, exit retry loop
|
|
72
|
-
}
|
|
73
|
-
catch (err) {
|
|
74
|
-
this.hrtMeasurement.stop();
|
|
75
|
-
// Handle skip
|
|
76
|
-
if (err instanceof SkipError || err.name === 'SkipError') {
|
|
77
|
-
console.log(`ok ${testNumber} - ${this.description} # SKIP ${err.message.replace('Skipped: ', '')}`);
|
|
78
|
-
this.status = 'skipped';
|
|
79
|
-
this.testDeferred.resolve(this);
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
lastError = err;
|
|
83
|
-
// If we have retries left, try again
|
|
84
|
-
if (attempt < maxRetries) {
|
|
85
|
-
console.log(`# Retry ${attempt + 1}/${maxRetries} for test: ${this.description}`);
|
|
86
|
-
this.tapTools._incrementRetryCount();
|
|
87
|
-
continue;
|
|
88
|
-
}
|
|
89
|
-
// Final failure
|
|
90
|
-
console.log(`not ok ${testNumber} - ${this.description} # time=${this.hrtMeasurement.milliSeconds}ms`);
|
|
91
|
-
this.testDeferred.resolve(this);
|
|
92
|
-
this.testResultDeferred.resolve(err);
|
|
93
|
-
// if the test has already succeeded before
|
|
94
|
-
if (this.status === 'success') {
|
|
95
|
-
this.status = 'errorAfterSuccess';
|
|
96
|
-
console.log('!!! ALERT !!!: weird behaviour, since test has been already successfull');
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
this.status = 'error';
|
|
100
|
-
}
|
|
101
|
-
// if the test is allowed to fail
|
|
102
|
-
if (this.failureAllowed) {
|
|
103
|
-
console.log(`please note: failure allowed!`);
|
|
104
|
-
}
|
|
105
|
-
console.log(err);
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFwYnVuZGxlLmNsYXNzZXMudGFwdGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzX3RhcGJ1bmRsZS90YXBidW5kbGUuY2xhc3Nlcy50YXB0ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sd0JBQXdCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFdEUsc0JBQXNCO0FBQ3RCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFTdkQsTUFBTSxPQUFPLE9BQU87SUFtQmxCOztPQUVHO0lBQ0gsWUFBWSxVQUlYO1FBaEJNLFdBQU0sR0FBWSxLQUFLLENBQUM7UUFFeEIsU0FBSSxHQUFhLEVBQUUsQ0FBQztRQUNwQixhQUFRLEdBQThCLFFBQVEsQ0FBQztRQUU5QyxpQkFBWSxHQUF5QixPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ25FLGdCQUFXLEdBQXdCLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDO1FBQzVELHVCQUFrQixHQUFnQixPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2hFLHNCQUFpQixHQUFlLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUM7UUFTckUsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUMsV0FBVyxDQUFDO1FBQzFDLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxjQUFjLEVBQUUsQ0FBQztRQUMzQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUM7UUFDcEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxTQUFTLENBQUM7UUFDeEIsSUFB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
|