@git.zone/tstest 1.4.0 → 1.7.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_ts/00_commitinfo_data.js +1 -1
- package/dist_ts/index.js +9 -2
- package/dist_ts/tstest.classes.tap.parser.d.ts +4 -0
- package/dist_ts/tstest.classes.tap.parser.js +114 -24
- package/dist_ts/tstest.classes.testdirectory.d.ts +10 -0
- package/dist_ts/tstest.classes.testdirectory.js +31 -1
- package/dist_ts/tstest.classes.tstest.d.ts +3 -1
- package/dist_ts/tstest.classes.tstest.js +52 -27
- package/dist_ts/tstest.plugins.d.ts +1 -1
- package/dist_ts/tstest.plugins.js +2 -2
- package/dist_ts_tapbundle/00_commitinfo_data.d.ts +8 -0
- package/dist_ts_tapbundle/00_commitinfo_data.js +9 -0
- package/dist_ts_tapbundle/index.d.ts +6 -0
- package/dist_ts_tapbundle/index.js +7 -0
- package/dist_ts_tapbundle/tapbundle.classes.pretask.d.ts +10 -0
- package/dist_ts_tapbundle/tapbundle.classes.pretask.js +13 -0
- package/dist_ts_tapbundle/tapbundle.classes.tap.d.ts +104 -0
- package/dist_ts_tapbundle/tapbundle.classes.tap.js +418 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptest.js +110 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptools.d.ts +107 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptools.js +229 -0
- package/dist_ts_tapbundle/tapbundle.classes.tapwrap.d.ts +8 -0
- package/dist_ts_tapbundle/tapbundle.classes.tapwrap.js +7 -0
- package/dist_ts_tapbundle/tapbundle.plugins.d.ts +7 -0
- package/dist_ts_tapbundle/tapbundle.plugins.js +9 -0
- package/dist_ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
- package/dist_ts_tapbundle/tapbundle.tapcreator.js +5 -0
- package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.d.ts +8 -0
- package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.js +9 -0
- package/dist_ts_tapbundle/ts_tapbundle/index.d.ts +6 -0
- package/dist_ts_tapbundle/ts_tapbundle/index.js +7 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.d.ts +10 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.js +13 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.d.ts +104 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.js +401 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.js +110 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.d.ts +109 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.js +241 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.d.ts +8 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.js +7 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.d.ts +8 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.js +10 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.js +5 -0
- package/dist_ts_tapbundle/ts_tapbundle/webhelpers.d.ts +7 -0
- package/dist_ts_tapbundle/ts_tapbundle/webhelpers.js +35 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.d.ts +5 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.js +13 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/plugins.d.ts +11 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/plugins.js +14 -0
- package/dist_ts_tapbundle/webhelpers.d.ts +7 -0
- package/dist_ts_tapbundle/webhelpers.js +35 -0
- package/dist_ts_tapbundle_node/classes.tapnodetools.d.ts +25 -0
- package/dist_ts_tapbundle_node/classes.tapnodetools.js +81 -0
- package/dist_ts_tapbundle_node/classes.testfileprovider.d.ts +6 -0
- package/dist_ts_tapbundle_node/classes.testfileprovider.js +16 -0
- package/dist_ts_tapbundle_node/index.d.ts +1 -0
- package/dist_ts_tapbundle_node/index.js +2 -0
- package/dist_ts_tapbundle_node/paths.d.ts +2 -0
- package/dist_ts_tapbundle_node/paths.js +4 -0
- package/dist_ts_tapbundle_node/plugins.d.ts +11 -0
- package/dist_ts_tapbundle_node/plugins.js +14 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptest.js +110 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptools.d.ts +109 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptools.js +241 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.plugins.d.ts +8 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.plugins.js +10 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.tapcreator.js +5 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.pathinject.d.ts +5 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.pathinject.js +13 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.tapnodetools.d.ts +25 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.tapnodetools.js +81 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.testfileprovider.d.ts +6 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.testfileprovider.js +16 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/index.d.ts +2 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/index.js +3 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/paths.d.ts +2 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/paths.js +4 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/plugins.d.ts +11 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/plugins.js +14 -0
- package/package.json +23 -10
- package/readme.hints.md +62 -0
- package/readme.plan.md +253 -30
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/index.ts +8 -1
- package/ts/tspublish.json +3 -0
- package/ts/tstest.classes.tap.parser.ts +111 -25
- package/ts/tstest.classes.testdirectory.ts +39 -0
- package/ts/tstest.classes.tstest.ts +61 -27
- package/ts/tstest.plugins.ts +1 -1
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
+
import { TapTest } from './tapbundle.classes.taptest.js';
|
|
3
|
+
export class SkipError extends Error {
|
|
4
|
+
constructor(message) {
|
|
5
|
+
super(message);
|
|
6
|
+
this.name = 'SkipError';
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
export class TapTools {
|
|
10
|
+
static { this._sharedContext = new Map(); }
|
|
11
|
+
static { this._pathHelpers = null; }
|
|
12
|
+
static setPathHelpers(helpers) {
|
|
13
|
+
TapTools._pathHelpers = helpers;
|
|
14
|
+
}
|
|
15
|
+
constructor(TapTestArg) {
|
|
16
|
+
this._retries = 0;
|
|
17
|
+
this._retryCount = 0;
|
|
18
|
+
this.testData = {};
|
|
19
|
+
this._snapshotPath = '';
|
|
20
|
+
this.smartjson = plugins.smartjson;
|
|
21
|
+
/**
|
|
22
|
+
* shared context for data sharing between tests
|
|
23
|
+
*/
|
|
24
|
+
this.context = {
|
|
25
|
+
get: (key) => {
|
|
26
|
+
return TapTools._sharedContext.get(key);
|
|
27
|
+
},
|
|
28
|
+
set: (key, value) => {
|
|
29
|
+
TapTools._sharedContext.set(key, value);
|
|
30
|
+
},
|
|
31
|
+
delete: (key) => {
|
|
32
|
+
return TapTools._sharedContext.delete(key);
|
|
33
|
+
},
|
|
34
|
+
clear: () => {
|
|
35
|
+
TapTools._sharedContext.clear();
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
this._tapTest = TapTestArg;
|
|
39
|
+
// Generate snapshot path based on test file and test name
|
|
40
|
+
// Snapshot path will be set by Node.js environment if available
|
|
41
|
+
if (TapTools._pathHelpers && typeof process !== 'undefined' && process.cwd) {
|
|
42
|
+
const testFile = TapTestArg.fileName || 'unknown';
|
|
43
|
+
const testName = TapTestArg.description.replace(/[^a-zA-Z0-9]/g, '_');
|
|
44
|
+
this._snapshotPath = TapTools._pathHelpers.join(process.cwd(), '.nogit', 'test_snapshots', testFile, `${testName}.snap`);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* allow failure
|
|
49
|
+
*/
|
|
50
|
+
allowFailure() {
|
|
51
|
+
this._tapTest.failureAllowed = true;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* skip the rest of the test
|
|
55
|
+
*/
|
|
56
|
+
skip(reason) {
|
|
57
|
+
const skipMessage = reason ? `Skipped: ${reason}` : 'Skipped';
|
|
58
|
+
throw new SkipError(skipMessage);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* conditionally skip the rest of the test
|
|
62
|
+
*/
|
|
63
|
+
skipIf(condition, reason) {
|
|
64
|
+
if (condition) {
|
|
65
|
+
this.skip(reason);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* mark test as todo
|
|
70
|
+
*/
|
|
71
|
+
todo(reason) {
|
|
72
|
+
this._tapTest.isTodo = true;
|
|
73
|
+
this._tapTest.todoReason = reason;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* set the number of retries for this test
|
|
77
|
+
*/
|
|
78
|
+
retry(count) {
|
|
79
|
+
this._retries = count;
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* get the current retry count
|
|
83
|
+
*/
|
|
84
|
+
get retryCount() {
|
|
85
|
+
return this._retryCount;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* internal: increment retry count
|
|
89
|
+
*/
|
|
90
|
+
_incrementRetryCount() {
|
|
91
|
+
this._retryCount++;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* get the maximum retries
|
|
95
|
+
*/
|
|
96
|
+
get maxRetries() {
|
|
97
|
+
return this._retries;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* async/await delay method
|
|
101
|
+
*/
|
|
102
|
+
async delayFor(timeMilliArg) {
|
|
103
|
+
await plugins.smartdelay.delayFor(timeMilliArg);
|
|
104
|
+
}
|
|
105
|
+
async delayForRandom(timeMilliMinArg, timeMilliMaxArg) {
|
|
106
|
+
await plugins.smartdelay.delayForRandom(timeMilliMinArg, timeMilliMaxArg);
|
|
107
|
+
}
|
|
108
|
+
async coloredString(...args) {
|
|
109
|
+
return plugins.consolecolor.coloredString(...args);
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* set a timeout for the test
|
|
113
|
+
*/
|
|
114
|
+
timeout(timeMilliArg) {
|
|
115
|
+
this._tapTest.timeoutMs = timeMilliArg;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* wait for a timeout (used internally)
|
|
119
|
+
*/
|
|
120
|
+
async waitForTimeout(timeMilliArg) {
|
|
121
|
+
const timeout = new plugins.smartdelay.Timeout(timeMilliArg);
|
|
122
|
+
timeout.makeUnrefed();
|
|
123
|
+
await timeout.promise;
|
|
124
|
+
if (this._tapTest.status === 'pending') {
|
|
125
|
+
this._tapTest.status = 'timeout';
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
async returnError(throwingFuncArg) {
|
|
129
|
+
let funcErr;
|
|
130
|
+
try {
|
|
131
|
+
await throwingFuncArg();
|
|
132
|
+
}
|
|
133
|
+
catch (err) {
|
|
134
|
+
funcErr = err;
|
|
135
|
+
}
|
|
136
|
+
return funcErr;
|
|
137
|
+
}
|
|
138
|
+
defer() {
|
|
139
|
+
return plugins.smartpromise.defer();
|
|
140
|
+
}
|
|
141
|
+
cumulativeDefer() {
|
|
142
|
+
return plugins.smartpromise.cumulativeDefer();
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Snapshot testing - compares output with saved snapshot
|
|
146
|
+
*/
|
|
147
|
+
async matchSnapshot(value, snapshotName) {
|
|
148
|
+
if (!this._snapshotPath || !TapTools._pathHelpers) {
|
|
149
|
+
console.log('Snapshot testing is only available in Node.js environment');
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
const snapshotPath = snapshotName
|
|
153
|
+
? this._snapshotPath.replace('.snap', `_${snapshotName}.snap`)
|
|
154
|
+
: this._snapshotPath;
|
|
155
|
+
const serializedValue = typeof value === 'string'
|
|
156
|
+
? value
|
|
157
|
+
: JSON.stringify(value, null, 2);
|
|
158
|
+
try {
|
|
159
|
+
// Try to read existing snapshot
|
|
160
|
+
const existingSnapshot = await plugins.smartfile.fs.toStringSync(snapshotPath);
|
|
161
|
+
if (existingSnapshot !== serializedValue) {
|
|
162
|
+
// Check if we should update snapshots
|
|
163
|
+
if (process.env.UPDATE_SNAPSHOTS === 'true') {
|
|
164
|
+
await plugins.smartfile.fs.ensureDir(TapTools._pathHelpers.dirname(snapshotPath));
|
|
165
|
+
await plugins.smartfile.memory.toFs(serializedValue, snapshotPath);
|
|
166
|
+
console.log(`Snapshot updated: ${snapshotPath}`);
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
throw new Error(`Snapshot mismatch for ${snapshotPath}\n\nExpected:\n${existingSnapshot}\n\nReceived:\n${serializedValue}`);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
catch (error) {
|
|
174
|
+
if (error.code === 'ENOENT') {
|
|
175
|
+
// Snapshot doesn't exist yet, create it
|
|
176
|
+
await plugins.smartfile.fs.ensureDir(TapTools._pathHelpers.dirname(snapshotPath));
|
|
177
|
+
await plugins.smartfile.memory.toFs(serializedValue, snapshotPath);
|
|
178
|
+
console.log(`Snapshot created: ${snapshotPath}`);
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
throw error;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Test fixtures - create test data instances
|
|
187
|
+
*/
|
|
188
|
+
static { this._fixtureData = new Map(); }
|
|
189
|
+
static { this._fixtureFactories = new Map(); }
|
|
190
|
+
/**
|
|
191
|
+
* Define a fixture factory
|
|
192
|
+
*/
|
|
193
|
+
static defineFixture(name, factory) {
|
|
194
|
+
this._fixtureFactories.set(name, factory);
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Create a fixture instance
|
|
198
|
+
*/
|
|
199
|
+
async fixture(name, data) {
|
|
200
|
+
const factory = TapTools._fixtureFactories.get(name);
|
|
201
|
+
if (!factory) {
|
|
202
|
+
throw new Error(`Fixture '${name}' not found. Define it with TapTools.defineFixture()`);
|
|
203
|
+
}
|
|
204
|
+
const instance = await factory(data);
|
|
205
|
+
// Store the fixture for cleanup
|
|
206
|
+
if (!TapTools._fixtureData.has(name)) {
|
|
207
|
+
TapTools._fixtureData.set(name, []);
|
|
208
|
+
}
|
|
209
|
+
TapTools._fixtureData.get(name).push(instance);
|
|
210
|
+
return instance;
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Factory pattern for creating multiple fixtures
|
|
214
|
+
*/
|
|
215
|
+
factory(name) {
|
|
216
|
+
return {
|
|
217
|
+
create: async (data) => {
|
|
218
|
+
return this.fixture(name, data);
|
|
219
|
+
},
|
|
220
|
+
createMany: async (count, dataOverrides) => {
|
|
221
|
+
const results = [];
|
|
222
|
+
for (let i = 0; i < count; i++) {
|
|
223
|
+
const data = Array.isArray(dataOverrides)
|
|
224
|
+
? dataOverrides[i]
|
|
225
|
+
: typeof dataOverrides === 'function'
|
|
226
|
+
? dataOverrides(i)
|
|
227
|
+
: dataOverrides;
|
|
228
|
+
results.push(await this.fixture(name, data));
|
|
229
|
+
}
|
|
230
|
+
return results;
|
|
231
|
+
}
|
|
232
|
+
};
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Clear all fixtures (typically called in afterEach)
|
|
236
|
+
*/
|
|
237
|
+
static async cleanupFixtures() {
|
|
238
|
+
TapTools._fixtureData.clear();
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFwYnVuZGxlLmNsYXNzZXMudGFwdG9vbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c190YXBidW5kbGUvdGFwYnVuZGxlLmNsYXNzZXMudGFwdG9vbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSx3QkFBd0IsQ0FBQztBQUNsRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFNekQsTUFBTSxPQUFPLFNBQVUsU0FBUSxLQUFLO0lBQ2xDLFlBQVksT0FBZTtRQUN6QixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDZixJQUFJLENBQUMsSUFBSSxHQUFHLFdBQVcsQ0FBQztJQUMxQixDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sUUFBUTthQVFKLG1CQUFjLEdBQUcsSUFBSSxHQUFHLEVBQWUsQUFBekIsQ0FBMEI7YUFFeEMsaUJBQVksR0FHaEIsSUFBSSxBQUhZLENBR1g7SUFFaEIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFxQztRQUN6RCxRQUFRLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQztJQUNsQyxDQUFDO0lBRUQsWUFBWSxVQUF3QjtRQWQ1QixhQUFRLEdBQUcsQ0FBQyxDQUFDO1FBQ2IsZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFDakIsYUFBUSxHQUFRLEVBQUUsQ0FBQztRQUVsQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQTJJNUIsY0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUM7UUFFckM7O1dBRUc7UUFDSSxZQUFPLEdBQUc7WUFDZixHQUFHLEVBQUUsQ0FBQyxHQUFXLEVBQUUsRUFBRTtnQkFDbkIsT0FBTyxRQUFRLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUMxQyxDQUFDO1lBQ0QsR0FBRyxFQUFFLENBQUMsR0FBVyxFQUFFLEtBQVUsRUFBRSxFQUFFO2dCQUMvQixRQUFRLENBQUMsY0FBYyxDQUFDLEdB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
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as consolecolor from '@push.rocks/consolecolor';
|
|
2
|
+
import * as smartdelay from '@push.rocks/smartdelay';
|
|
3
|
+
import * as smartenv from '@push.rocks/smartenv';
|
|
4
|
+
import * as smartexpect from '@push.rocks/smartexpect';
|
|
5
|
+
import * as smartfile from '@push.rocks/smartfile';
|
|
6
|
+
import * as smartjson from '@push.rocks/smartjson';
|
|
7
|
+
import * as smartpromise from '@push.rocks/smartpromise';
|
|
8
|
+
export { consolecolor, smartdelay, smartenv, smartexpect, smartfile, smartjson, smartpromise };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// pushrocks
|
|
2
|
+
import * as consolecolor from '@push.rocks/consolecolor';
|
|
3
|
+
import * as smartdelay from '@push.rocks/smartdelay';
|
|
4
|
+
import * as smartenv from '@push.rocks/smartenv';
|
|
5
|
+
import * as smartexpect from '@push.rocks/smartexpect';
|
|
6
|
+
import * as smartfile from '@push.rocks/smartfile';
|
|
7
|
+
import * as smartjson from '@push.rocks/smartjson';
|
|
8
|
+
import * as smartpromise from '@push.rocks/smartpromise';
|
|
9
|
+
export { consolecolor, smartdelay, smartenv, smartexpect, smartfile, smartjson, smartpromise };
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFwYnVuZGxlLnBsdWdpbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c190YXBidW5kbGUvdGFwYnVuZGxlLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsWUFBWTtBQUNaLE9BQU8sS0FBSyxZQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxLQUFLLFVBQVUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEtBQUssUUFBUSxNQUFNLHNCQUFzQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxXQUFXLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxLQUFLLFNBQVMsTUFBTSx1QkFBdUIsQ0FBQztBQUNuRCxPQUFPLEtBQUssU0FBUyxNQUFNLHVCQUF1QixDQUFDO0FBQ25ELE9BQU8sS0FBSyxZQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFFekQsT0FBTyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxDQUFDIn0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
+
export class TapCreator {
|
|
3
|
+
}
|
|
4
|
+
export let tapCreator = new TapCreator();
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFwYnVuZGxlLnRhcGNyZWF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c190YXBidW5kbGUvdGFwYnVuZGxlLnRhcGNyZWF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSx3QkFBd0IsQ0FBQztBQUVsRCxNQUFNLE9BQU8sVUFBVTtDQUV0QjtBQUVELE1BQU0sQ0FBQyxJQUFJLFVBQVUsR0FBRyxJQUFJLFVBQVUsRUFBRSxDQUFDIn0=
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import * as plugins from './plugins.js';
|
|
2
|
+
import { TapTools } from '../ts_tapbundle/tapbundle.classes.taptools.js';
|
|
3
|
+
/**
|
|
4
|
+
* Initialize path helpers for the TapTools class
|
|
5
|
+
* This provides Node.js-specific path operations to the browser-compatible tapbundle
|
|
6
|
+
*/
|
|
7
|
+
export const initializePathHelpers = () => {
|
|
8
|
+
TapTools.setPathHelpers({
|
|
9
|
+
join: (...args) => plugins.path.join(...args),
|
|
10
|
+
dirname: (path) => plugins.path.dirname(path)
|
|
11
|
+
});
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3Nlcy5wYXRoaW5qZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHNfdGFwYnVuZGxlX25vZGUvY2xhc3Nlcy5wYXRoaW5qZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUV6RTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxHQUFHLEVBQUU7SUFDeEMsUUFBUSxDQUFDLGNBQWMsQ0FBQztRQUN0QixJQUFJLEVBQUUsQ0FBQyxHQUFHLElBQWMsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDdkQsT0FBTyxFQUFFLENBQUMsSUFBWSxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7S0FDdEQsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDIn0=
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { TestFileProvider } from './classes.testfileprovider.js';
|
|
2
|
+
import * as plugins from './plugins.js';
|
|
3
|
+
declare class TapNodeTools {
|
|
4
|
+
private smartshellInstance;
|
|
5
|
+
testFileProvider: TestFileProvider;
|
|
6
|
+
constructor();
|
|
7
|
+
private qenv;
|
|
8
|
+
getQenv(): Promise<plugins.qenv.Qenv>;
|
|
9
|
+
getEnvVarOnDemand(envVarNameArg: string): Promise<string>;
|
|
10
|
+
runCommand(commandArg: string): Promise<any>;
|
|
11
|
+
createHttpsCert(commonName?: string, allowSelfSigned?: boolean): Promise<{
|
|
12
|
+
key: string;
|
|
13
|
+
cert: string;
|
|
14
|
+
}>;
|
|
15
|
+
/**
|
|
16
|
+
* create and return a smartmongo instance
|
|
17
|
+
*/
|
|
18
|
+
createSmartmongo(): Promise<import("@push.rocks/smartmongo").SmartMongo>;
|
|
19
|
+
/**
|
|
20
|
+
* create and return a smarts3 instance
|
|
21
|
+
*/
|
|
22
|
+
createSmarts3(): Promise<import("@push.rocks/smarts3").Smarts3>;
|
|
23
|
+
}
|
|
24
|
+
export declare const tapNodeTools: TapNodeTools;
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { TestFileProvider } from './classes.testfileprovider.js';
|
|
2
|
+
import * as plugins from './plugins.js';
|
|
3
|
+
class TapNodeTools {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.testFileProvider = new TestFileProvider();
|
|
6
|
+
}
|
|
7
|
+
async getQenv() {
|
|
8
|
+
this.qenv = this.qenv || new plugins.qenv.Qenv('./', '.nogit/');
|
|
9
|
+
return this.qenv;
|
|
10
|
+
}
|
|
11
|
+
async getEnvVarOnDemand(envVarNameArg) {
|
|
12
|
+
const qenv = await this.getQenv();
|
|
13
|
+
return qenv.getEnvVarOnDemand(envVarNameArg);
|
|
14
|
+
}
|
|
15
|
+
async runCommand(commandArg) {
|
|
16
|
+
if (!this.smartshellInstance) {
|
|
17
|
+
this.smartshellInstance = new plugins.smartshell.Smartshell({
|
|
18
|
+
executor: 'bash',
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
const result = await this.smartshellInstance.exec(commandArg);
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
async createHttpsCert(commonName = 'localhost', allowSelfSigned = true) {
|
|
25
|
+
if (allowSelfSigned) {
|
|
26
|
+
// set node to allow self-signed certificates
|
|
27
|
+
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
|
|
28
|
+
}
|
|
29
|
+
// Generate a key pair
|
|
30
|
+
const keys = plugins.smartcrypto.nodeForge.pki.rsa.generateKeyPair(2048);
|
|
31
|
+
// Create a self-signed certificate
|
|
32
|
+
const cert = plugins.smartcrypto.nodeForge.pki.createCertificate();
|
|
33
|
+
cert.publicKey = keys.publicKey;
|
|
34
|
+
cert.serialNumber = '01';
|
|
35
|
+
cert.validity.notBefore = new Date();
|
|
36
|
+
cert.validity.notAfter = new Date();
|
|
37
|
+
cert.validity.notAfter.setFullYear(cert.validity.notBefore.getFullYear() + 1);
|
|
38
|
+
const attrs = [
|
|
39
|
+
{ name: 'commonName', value: commonName },
|
|
40
|
+
{ name: 'countryName', value: 'US' },
|
|
41
|
+
{ shortName: 'ST', value: 'California' },
|
|
42
|
+
{ name: 'localityName', value: 'San Francisco' },
|
|
43
|
+
{ name: 'organizationName', value: 'My Company' },
|
|
44
|
+
{ shortName: 'OU', value: 'Dev' },
|
|
45
|
+
];
|
|
46
|
+
cert.setSubject(attrs);
|
|
47
|
+
cert.setIssuer(attrs);
|
|
48
|
+
// Sign the certificate with its own private key (self-signed)
|
|
49
|
+
cert.sign(keys.privateKey, plugins.smartcrypto.nodeForge.md.sha256.create());
|
|
50
|
+
// PEM encode the private key and certificate
|
|
51
|
+
const pemKey = plugins.smartcrypto.nodeForge.pki.privateKeyToPem(keys.privateKey);
|
|
52
|
+
const pemCert = plugins.smartcrypto.nodeForge.pki.certificateToPem(cert);
|
|
53
|
+
return {
|
|
54
|
+
key: pemKey,
|
|
55
|
+
cert: pemCert,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* create and return a smartmongo instance
|
|
60
|
+
*/
|
|
61
|
+
async createSmartmongo() {
|
|
62
|
+
const smartmongoMod = await import('@push.rocks/smartmongo');
|
|
63
|
+
const smartmongoInstance = new smartmongoMod.SmartMongo();
|
|
64
|
+
await smartmongoInstance.start();
|
|
65
|
+
return smartmongoInstance;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* create and return a smarts3 instance
|
|
69
|
+
*/
|
|
70
|
+
async createSmarts3() {
|
|
71
|
+
const smarts3Mod = await import('@push.rocks/smarts3');
|
|
72
|
+
const smarts3Instance = new smarts3Mod.Smarts3({
|
|
73
|
+
port: 3003,
|
|
74
|
+
cleanSlate: true,
|
|
75
|
+
});
|
|
76
|
+
await smarts3Instance.start();
|
|
77
|
+
return smarts3Instance;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
export const tapNodeTools = new TapNodeTools();
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3Nlcy50YXBub2RldG9vbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c190YXBidW5kbGVfbm9kZS9jbGFzc2VzLnRhcG5vZGV0b29scy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNqRSxPQUFPLEtBQUssT0FBTyxNQUFNLGNBQWMsQ0FBQztBQUV4QyxNQUFNLFlBQVk7SUFJaEI7UUFGTyxxQkFBZ0IsR0FBRyxJQUFJLGdCQUFnQixFQUFFLENBQUM7SUFFbEMsQ0FBQztJQUdULEtBQUssQ0FBQyxPQUFPO1FBQ2xCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNoRSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUNNLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxhQUFxQjtRQUNsRCxNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRU0sS0FBSyxDQUFDLFVBQVUsQ0FBQyxVQUFrQjtRQUN4QyxJQUFJLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDN0IsSUFBSSxDQUFDLGtCQUFrQixHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUM7Z0JBQzFELFFBQVEsRUFBRSxNQUFNO2FBQ2pCLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRCxNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDOUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJ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
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as plugins from './plugins.js';
|
|
2
|
+
import * as paths from './paths.js';
|
|
3
|
+
export const fileUrls = {
|
|
4
|
+
dockerAlpineImage: 'https://code.foss.global/testassets/docker/raw/branch/main/alpine.tar',
|
|
5
|
+
};
|
|
6
|
+
export class TestFileProvider {
|
|
7
|
+
async getDockerAlpineImageAsLocalTarball() {
|
|
8
|
+
const filePath = plugins.path.join(paths.testFilesDir, 'alpine.tar');
|
|
9
|
+
// fetch the docker alpine image
|
|
10
|
+
const response = await plugins.smartrequest.getBinary(fileUrls.dockerAlpineImage);
|
|
11
|
+
await plugins.smartfile.fs.ensureDir(paths.testFilesDir);
|
|
12
|
+
await plugins.smartfile.memory.toFs(response.body, filePath);
|
|
13
|
+
return filePath;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3Nlcy50ZXN0ZmlsZXByb3ZpZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHNfdGFwYnVuZGxlX25vZGUvY2xhc3Nlcy50ZXN0ZmlsZXByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sS0FBSyxLQUFLLE1BQU0sWUFBWSxDQUFDO0FBRXBDLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRztJQUN0QixpQkFBaUIsRUFBRSx1RUFBdUU7Q0FDM0YsQ0FBQTtBQUVELE1BQU0sT0FBTyxnQkFBZ0I7SUFDcEIsS0FBSyxDQUFDLGtDQUFrQztRQUM3QyxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQyxDQUFBO1FBQ3BFLGdDQUFnQztRQUNoQyxNQUFNLFFBQVEsR0FBRyxNQUFNLE9BQU8sQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBQ2xGLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN6RCxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQzdELE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7Q0FDRiJ9
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './classes.tapnodetools.js';
|
|
2
|
+
export * from './classes.pathinject.js';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c190YXBidW5kbGVfbm9kZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUMifQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import * as plugins from './plugins.js';
|
|
2
|
+
export const cwd = process.cwd();
|
|
3
|
+
export const testFilesDir = plugins.path.join(cwd, './.nogit/testfiles/');
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c190YXBidW5kbGVfbm9kZS9wYXRocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLGNBQWMsQ0FBQztBQUV4QyxNQUFNLENBQUMsTUFBTSxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQ2pDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUscUJBQXFCLENBQUMsQ0FBQyJ9
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as crypto from 'crypto';
|
|
2
|
+
import * as fs from 'fs';
|
|
3
|
+
import * as path from 'path';
|
|
4
|
+
export { crypto, fs, path, };
|
|
5
|
+
import * as qenv from '@push.rocks/qenv';
|
|
6
|
+
import * as smartcrypto from '@push.rocks/smartcrypto';
|
|
7
|
+
import * as smartfile from '@push.rocks/smartfile';
|
|
8
|
+
import * as smartpath from '@push.rocks/smartpath';
|
|
9
|
+
import * as smartrequest from '@push.rocks/smartrequest';
|
|
10
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
11
|
+
export { qenv, smartcrypto, smartfile, smartpath, smartrequest, smartshell, };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
// node native
|
|
2
|
+
import * as crypto from 'crypto';
|
|
3
|
+
import * as fs from 'fs';
|
|
4
|
+
import * as path from 'path';
|
|
5
|
+
export { crypto, fs, path, };
|
|
6
|
+
// @push.rocks scope
|
|
7
|
+
import * as qenv from '@push.rocks/qenv';
|
|
8
|
+
import * as smartcrypto from '@push.rocks/smartcrypto';
|
|
9
|
+
import * as smartfile from '@push.rocks/smartfile';
|
|
10
|
+
import * as smartpath from '@push.rocks/smartpath';
|
|
11
|
+
import * as smartrequest from '@push.rocks/smartrequest';
|
|
12
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
13
|
+
export { qenv, smartcrypto, smartfile, smartpath, smartrequest, smartshell, };
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzX3RhcGJ1bmRsZV9ub2RlL3BsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYztBQUNkLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBQ2pDLE9BQU8sS0FBSyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBQ3pCLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBRSxNQUFNLEVBQUMsRUFBRSxFQUFFLElBQUksR0FBRyxDQUFDO0FBRTVCLG9CQUFvQjtBQUNwQixPQUFPLEtBQUssSUFBSSxNQUFNLGtCQUFrQixDQUFDO0FBQ3pDLE9BQU8sS0FBSyxXQUFXLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxLQUFLLFNBQVMsTUFBTSx1QkFBdUIsQ0FBQztBQUNuRCxPQUFPLEtBQUssU0FBUyxNQUFNLHVCQUF1QixDQUFDO0FBQ25ELE9BQU8sS0FBSyxZQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxLQUFLLFVBQVUsTUFBTSx3QkFBd0IsQ0FBQztBQUVyRCxPQUFPLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEdBQUcsQ0FBQyJ9
|
package/package.json
CHANGED
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@git.zone/tstest",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.7.0",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "a test utility to run tests that match test/**/*.ts",
|
|
6
|
-
"
|
|
7
|
-
|
|
6
|
+
"exports": {
|
|
7
|
+
".": "./dist_ts/index.js",
|
|
8
|
+
"./tapbundle": "./dist_ts_tapbundle/index.js",
|
|
9
|
+
"./tapbundle_node": "./dist_ts_tapbundle_node/index.js"
|
|
10
|
+
},
|
|
8
11
|
"type": "module",
|
|
9
12
|
"author": "Lossless GmbH",
|
|
10
13
|
"license": "MIT",
|
|
@@ -20,13 +23,22 @@
|
|
|
20
23
|
"@git.zone/tsbundle": "^2.2.5",
|
|
21
24
|
"@git.zone/tsrun": "^1.3.3",
|
|
22
25
|
"@push.rocks/consolecolor": "^2.0.2",
|
|
26
|
+
"@push.rocks/qenv": "^6.1.0",
|
|
23
27
|
"@push.rocks/smartbrowser": "^2.0.8",
|
|
28
|
+
"@push.rocks/smartcrypto": "^2.0.4",
|
|
24
29
|
"@push.rocks/smartdelay": "^3.0.5",
|
|
30
|
+
"@push.rocks/smartenv": "^5.0.12",
|
|
31
|
+
"@push.rocks/smartexpect": "^2.4.2",
|
|
25
32
|
"@push.rocks/smartfile": "^11.2.0",
|
|
26
|
-
"@push.rocks/
|
|
33
|
+
"@push.rocks/smartjson": "^5.0.20",
|
|
34
|
+
"@push.rocks/smartlog": "^3.1.1",
|
|
35
|
+
"@push.rocks/smartmongo": "^2.0.12",
|
|
36
|
+
"@push.rocks/smartpath": "^5.0.18",
|
|
27
37
|
"@push.rocks/smartpromise": "^4.2.3",
|
|
38
|
+
"@push.rocks/smartrequest": "^2.1.0",
|
|
39
|
+
"@push.rocks/smarts3": "^2.2.5",
|
|
28
40
|
"@push.rocks/smartshell": "^3.2.3",
|
|
29
|
-
"@push.rocks/
|
|
41
|
+
"@push.rocks/smarttime": "^4.1.1",
|
|
30
42
|
"@types/ws": "^8.18.1",
|
|
31
43
|
"figures": "^6.1.0",
|
|
32
44
|
"ws": "^8.18.2"
|
|
@@ -47,11 +59,12 @@
|
|
|
47
59
|
"last 1 chrome versions"
|
|
48
60
|
],
|
|
49
61
|
"scripts": {
|
|
50
|
-
"test": "
|
|
51
|
-
"
|
|
52
|
-
"
|
|
53
|
-
"
|
|
54
|
-
"
|
|
62
|
+
"test": "pnpm run build && pnpm run test:tapbundle:verbose && pnpm run test:tstest:verbose",
|
|
63
|
+
"test:tapbundle": "tsx ./cli.child.ts \"test/tapbundle/**/*.ts\"",
|
|
64
|
+
"test:tapbundle:verbose": "tsx ./cli.child.ts \"test/tapbundle/**/*.ts\" --verbose",
|
|
65
|
+
"test:tstest": "tsx ./cli.child.ts \"test/tstest/**/*.ts\"",
|
|
66
|
+
"test:tstest:verbose": "tsx ./cli.child.ts \"test/tstest/**/*.ts\" --verbose",
|
|
67
|
+
"build": "(tsbuild tsfolders)",
|
|
55
68
|
"buildDocs": "tsdoc"
|
|
56
69
|
}
|
|
57
70
|
}
|
package/readme.hints.md
CHANGED
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
# Architecture Overview
|
|
2
|
+
|
|
3
|
+
## Project Structure
|
|
4
|
+
|
|
5
|
+
This project integrates tstest with tapbundle through a modular architecture:
|
|
6
|
+
|
|
7
|
+
1. **tstest** (`/ts/`) - The test runner that discovers and executes test files
|
|
8
|
+
2. **tapbundle** (`/ts_tapbundle/`) - The TAP testing framework for writing tests
|
|
9
|
+
3. **tapbundle_node** (`/ts_tapbundle_node/`) - Node.js-specific testing utilities
|
|
10
|
+
|
|
11
|
+
## How Components Work Together
|
|
12
|
+
|
|
13
|
+
### Test Execution Flow
|
|
14
|
+
|
|
15
|
+
1. **CLI Entry Point** (`cli.js` � `cli.ts.js` � `cli.child.ts`)
|
|
16
|
+
- The CLI uses tsx to run TypeScript files directly
|
|
17
|
+
- Accepts glob patterns to find test files
|
|
18
|
+
- Supports options like `--verbose`, `--quiet`, `--web`
|
|
19
|
+
|
|
20
|
+
2. **Test Discovery**
|
|
21
|
+
- tstest scans for test files matching the provided pattern
|
|
22
|
+
- Defaults to `test/**/*.ts` when no pattern is specified
|
|
23
|
+
- Supports both file and directory modes
|
|
24
|
+
|
|
25
|
+
3. **Test Runner**
|
|
26
|
+
- Each test file imports `tap` and `expect` from tapbundle
|
|
27
|
+
- Tests are written using `tap.test()` with async functions
|
|
28
|
+
- Browser tests are compiled with esbuild and run in Chromium via Puppeteer
|
|
29
|
+
|
|
30
|
+
### Key Integration Points
|
|
31
|
+
|
|
32
|
+
1. **Import Structure**
|
|
33
|
+
- Test files import from local tapbundle: `import { tap, expect } from '../../ts_tapbundle/index.js'`
|
|
34
|
+
- Node-specific tests also import from tapbundle_node: `import { tapNodeTools } from '../../ts_tapbundle_node/index.js'`
|
|
35
|
+
|
|
36
|
+
2. **WebHelpers**
|
|
37
|
+
- Browser tests can use webhelpers for DOM manipulation
|
|
38
|
+
- `webhelpers.html` - Template literal for creating HTML strings
|
|
39
|
+
- `webhelpers.fixture` - Creates DOM elements from HTML strings
|
|
40
|
+
- Automatically detects browser environment and only enables in browser context
|
|
41
|
+
|
|
42
|
+
3. **Build System**
|
|
43
|
+
- Uses `tsbuild tsfolders` to compile TypeScript
|
|
44
|
+
- Maintains separate output directories: `/dist_ts/`, `/dist_ts_tapbundle/`, `/dist_ts_tapbundle_node/`
|
|
45
|
+
- Compilation order is resolved automatically based on dependencies
|
|
46
|
+
|
|
47
|
+
### Test Scripts
|
|
48
|
+
|
|
49
|
+
The package.json defines several test scripts:
|
|
50
|
+
- `test` - Builds and runs all tests (tapbundle and tstest)
|
|
51
|
+
- `test:tapbundle` - Runs tapbundle framework tests
|
|
52
|
+
- `test:tstest` - Runs tstest's own tests
|
|
53
|
+
- Both support `:verbose` variants for detailed output
|
|
54
|
+
|
|
55
|
+
### Environment Detection
|
|
56
|
+
|
|
57
|
+
The framework automatically detects the runtime environment:
|
|
58
|
+
- Node.js tests run directly via tsx
|
|
59
|
+
- Browser tests are compiled and served via a local server
|
|
60
|
+
- WebHelpers are only enabled in browser environment
|
|
61
|
+
|
|
62
|
+
This architecture allows for seamless testing across both Node.js and browser environments while maintaining a clean separation of concerns.
|