@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.
Files changed (94) hide show
  1. package/dist_ts/00_commitinfo_data.js +1 -1
  2. package/dist_ts/index.js +9 -2
  3. package/dist_ts/tstest.classes.tap.parser.d.ts +4 -0
  4. package/dist_ts/tstest.classes.tap.parser.js +114 -24
  5. package/dist_ts/tstest.classes.testdirectory.d.ts +10 -0
  6. package/dist_ts/tstest.classes.testdirectory.js +31 -1
  7. package/dist_ts/tstest.classes.tstest.d.ts +3 -1
  8. package/dist_ts/tstest.classes.tstest.js +52 -27
  9. package/dist_ts/tstest.plugins.d.ts +1 -1
  10. package/dist_ts/tstest.plugins.js +2 -2
  11. package/dist_ts_tapbundle/00_commitinfo_data.d.ts +8 -0
  12. package/dist_ts_tapbundle/00_commitinfo_data.js +9 -0
  13. package/dist_ts_tapbundle/index.d.ts +6 -0
  14. package/dist_ts_tapbundle/index.js +7 -0
  15. package/dist_ts_tapbundle/tapbundle.classes.pretask.d.ts +10 -0
  16. package/dist_ts_tapbundle/tapbundle.classes.pretask.js +13 -0
  17. package/dist_ts_tapbundle/tapbundle.classes.tap.d.ts +104 -0
  18. package/dist_ts_tapbundle/tapbundle.classes.tap.js +418 -0
  19. package/dist_ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
  20. package/dist_ts_tapbundle/tapbundle.classes.taptest.js +110 -0
  21. package/dist_ts_tapbundle/tapbundle.classes.taptools.d.ts +107 -0
  22. package/dist_ts_tapbundle/tapbundle.classes.taptools.js +229 -0
  23. package/dist_ts_tapbundle/tapbundle.classes.tapwrap.d.ts +8 -0
  24. package/dist_ts_tapbundle/tapbundle.classes.tapwrap.js +7 -0
  25. package/dist_ts_tapbundle/tapbundle.plugins.d.ts +7 -0
  26. package/dist_ts_tapbundle/tapbundle.plugins.js +9 -0
  27. package/dist_ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
  28. package/dist_ts_tapbundle/tapbundle.tapcreator.js +5 -0
  29. package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.d.ts +8 -0
  30. package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.js +9 -0
  31. package/dist_ts_tapbundle/ts_tapbundle/index.d.ts +6 -0
  32. package/dist_ts_tapbundle/ts_tapbundle/index.js +7 -0
  33. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.d.ts +10 -0
  34. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.js +13 -0
  35. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.d.ts +104 -0
  36. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.js +401 -0
  37. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
  38. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.js +110 -0
  39. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.d.ts +109 -0
  40. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.js +241 -0
  41. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.d.ts +8 -0
  42. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.js +7 -0
  43. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.d.ts +8 -0
  44. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.js +10 -0
  45. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
  46. package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.js +5 -0
  47. package/dist_ts_tapbundle/ts_tapbundle/webhelpers.d.ts +7 -0
  48. package/dist_ts_tapbundle/ts_tapbundle/webhelpers.js +35 -0
  49. package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.d.ts +5 -0
  50. package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.js +13 -0
  51. package/dist_ts_tapbundle/ts_tapbundle_node/plugins.d.ts +11 -0
  52. package/dist_ts_tapbundle/ts_tapbundle_node/plugins.js +14 -0
  53. package/dist_ts_tapbundle/webhelpers.d.ts +7 -0
  54. package/dist_ts_tapbundle/webhelpers.js +35 -0
  55. package/dist_ts_tapbundle_node/classes.tapnodetools.d.ts +25 -0
  56. package/dist_ts_tapbundle_node/classes.tapnodetools.js +81 -0
  57. package/dist_ts_tapbundle_node/classes.testfileprovider.d.ts +6 -0
  58. package/dist_ts_tapbundle_node/classes.testfileprovider.js +16 -0
  59. package/dist_ts_tapbundle_node/index.d.ts +1 -0
  60. package/dist_ts_tapbundle_node/index.js +2 -0
  61. package/dist_ts_tapbundle_node/paths.d.ts +2 -0
  62. package/dist_ts_tapbundle_node/paths.js +4 -0
  63. package/dist_ts_tapbundle_node/plugins.d.ts +11 -0
  64. package/dist_ts_tapbundle_node/plugins.js +14 -0
  65. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
  66. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptest.js +110 -0
  67. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptools.d.ts +109 -0
  68. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptools.js +241 -0
  69. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.plugins.d.ts +8 -0
  70. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.plugins.js +10 -0
  71. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
  72. package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.tapcreator.js +5 -0
  73. package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.pathinject.d.ts +5 -0
  74. package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.pathinject.js +13 -0
  75. package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.tapnodetools.d.ts +25 -0
  76. package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.tapnodetools.js +81 -0
  77. package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.testfileprovider.d.ts +6 -0
  78. package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.testfileprovider.js +16 -0
  79. package/dist_ts_tapbundle_node/ts_tapbundle_node/index.d.ts +2 -0
  80. package/dist_ts_tapbundle_node/ts_tapbundle_node/index.js +3 -0
  81. package/dist_ts_tapbundle_node/ts_tapbundle_node/paths.d.ts +2 -0
  82. package/dist_ts_tapbundle_node/ts_tapbundle_node/paths.js +4 -0
  83. package/dist_ts_tapbundle_node/ts_tapbundle_node/plugins.d.ts +11 -0
  84. package/dist_ts_tapbundle_node/ts_tapbundle_node/plugins.js +14 -0
  85. package/package.json +23 -10
  86. package/readme.hints.md +62 -0
  87. package/readme.plan.md +253 -30
  88. package/ts/00_commitinfo_data.ts +1 -1
  89. package/ts/index.ts +8 -1
  90. package/ts/tspublish.json +3 -0
  91. package/ts/tstest.classes.tap.parser.ts +111 -25
  92. package/ts/tstest.classes.testdirectory.ts +39 -0
  93. package/ts/tstest.classes.tstest.ts +61 -27
  94. 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,3 @@
1
+ export declare class TapCreator {
2
+ }
3
+ export declare let tapCreator: TapCreator;
@@ -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,5 @@
1
+ /**
2
+ * Initialize path helpers for the TapTools class
3
+ * This provides Node.js-specific path operations to the browser-compatible tapbundle
4
+ */
5
+ export declare const initializePathHelpers: () => void;
@@ -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,6 @@
1
+ export declare const fileUrls: {
2
+ dockerAlpineImage: string;
3
+ };
4
+ export declare class TestFileProvider {
5
+ getDockerAlpineImageAsLocalTarball(): Promise<string>;
6
+ }
@@ -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,2 @@
1
+ export * from './classes.tapnodetools.js';
2
+ export * from './classes.pathinject.js';
@@ -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,2 @@
1
+ export declare const cwd: string;
2
+ export declare const testFilesDir: string;
@@ -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.4.0",
3
+ "version": "1.7.0",
4
4
  "private": false,
5
5
  "description": "a test utility to run tests that match test/**/*.ts",
6
- "main": "dist_ts/index.js",
7
- "typings": "dist_ts/index.d.ts",
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/smartlog": "^3.0.9",
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/tapbundle": "^6.0.3",
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": "(npm run cleanUp && npm run prepareTest && npm run tstest)",
51
- "prepareTest": "git clone https://gitlab.com/sandboxzone/sandbox-npmts.git .nogit/sandbox-npmts && cd .nogit/sandbox-npmts && npm install",
52
- "tstest": "cd .nogit/sandbox-npmts && node ../../cli.ts.js test/ --web",
53
- "cleanUp": "rm -rf .nogit/sandbox-npmts",
54
- "build": "(tsbuild --web --allowimplicitany --skiplibcheck)",
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.