@git.zone/tstest 2.3.7 → 2.4.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/tstest.classes.migration.d.ts +104 -0
- package/dist_ts/tstest.classes.migration.js +200 -0
- package/dist_ts/tstest.classes.runtime.adapter.d.ts +172 -0
- package/dist_ts/tstest.classes.runtime.adapter.js +85 -0
- package/dist_ts/tstest.classes.runtime.bun.d.ts +30 -0
- package/dist_ts/tstest.classes.runtime.bun.js +184 -0
- package/dist_ts/tstest.classes.runtime.chromium.d.ts +36 -0
- package/dist_ts/tstest.classes.runtime.chromium.js +256 -0
- package/dist_ts/tstest.classes.runtime.deno.d.ts +34 -0
- package/dist_ts/tstest.classes.runtime.deno.js +205 -0
- package/dist_ts/tstest.classes.runtime.node.d.ts +30 -0
- package/dist_ts/tstest.classes.runtime.node.js +188 -0
- package/dist_ts/tstest.classes.runtime.parser.d.ts +37 -0
- package/dist_ts/tstest.classes.runtime.parser.js +159 -0
- package/dist_ts/tstest.classes.tstest.d.ts +2 -0
- package/dist_ts/tstest.classes.tstest.js +61 -31
- package/package.json +2 -2
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/tstest.classes.migration.ts +316 -0
- package/ts/tstest.classes.runtime.adapter.ts +245 -0
- package/ts/tstest.classes.runtime.bun.ts +219 -0
- package/ts/tstest.classes.runtime.chromium.ts +293 -0
- package/ts/tstest.classes.runtime.deno.ts +244 -0
- package/ts/tstest.classes.runtime.node.ts +222 -0
- package/ts/tstest.classes.runtime.parser.ts +211 -0
- package/ts/tstest.classes.tstest.ts +75 -31
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import * as plugins from './tstest.plugins.js';
|
|
2
|
+
import { coloredString as cs } from '@push.rocks/consolecolor';
|
|
3
|
+
import { RuntimeAdapter, } from './tstest.classes.runtime.adapter.js';
|
|
4
|
+
import { TapParser } from './tstest.classes.tap.parser.js';
|
|
5
|
+
import { TsTestLogger } from './tstest.logging.js';
|
|
6
|
+
/**
|
|
7
|
+
* Bun runtime adapter
|
|
8
|
+
* Executes tests using the Bun runtime with native TypeScript support
|
|
9
|
+
*/
|
|
10
|
+
export class BunRuntimeAdapter extends RuntimeAdapter {
|
|
11
|
+
constructor(logger, smartshellInstance, // SmartShell instance from @push.rocks/smartshell
|
|
12
|
+
timeoutSeconds, filterTags) {
|
|
13
|
+
super();
|
|
14
|
+
this.logger = logger;
|
|
15
|
+
this.smartshellInstance = smartshellInstance;
|
|
16
|
+
this.timeoutSeconds = timeoutSeconds;
|
|
17
|
+
this.filterTags = filterTags;
|
|
18
|
+
this.id = 'bun';
|
|
19
|
+
this.displayName = 'Bun';
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Check if Bun is available
|
|
23
|
+
*/
|
|
24
|
+
async checkAvailable() {
|
|
25
|
+
try {
|
|
26
|
+
const result = await this.smartshellInstance.exec('bun --version', {
|
|
27
|
+
cwd: process.cwd(),
|
|
28
|
+
onError: () => {
|
|
29
|
+
// Ignore error
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
if (result.exitCode !== 0) {
|
|
33
|
+
return {
|
|
34
|
+
available: false,
|
|
35
|
+
error: 'Bun not found. Install from: https://bun.sh/',
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
// Bun version is just the version number
|
|
39
|
+
const version = result.stdout.trim();
|
|
40
|
+
return {
|
|
41
|
+
available: true,
|
|
42
|
+
version: `Bun ${version}`,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
return {
|
|
47
|
+
available: false,
|
|
48
|
+
error: error.message,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Create command configuration for Bun test execution
|
|
54
|
+
*/
|
|
55
|
+
createCommand(testFile, options) {
|
|
56
|
+
const mergedOptions = this.mergeOptions(options);
|
|
57
|
+
const args = ['run'];
|
|
58
|
+
// Add extra args
|
|
59
|
+
if (mergedOptions.extraArgs && mergedOptions.extraArgs.length > 0) {
|
|
60
|
+
args.push(...mergedOptions.extraArgs);
|
|
61
|
+
}
|
|
62
|
+
// Add test file
|
|
63
|
+
args.push(testFile);
|
|
64
|
+
// Set environment variables
|
|
65
|
+
const env = { ...mergedOptions.env };
|
|
66
|
+
if (this.filterTags.length > 0) {
|
|
67
|
+
env.TSTEST_FILTER_TAGS = this.filterTags.join(',');
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
command: 'bun',
|
|
71
|
+
args,
|
|
72
|
+
env,
|
|
73
|
+
cwd: mergedOptions.cwd,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Execute a test file in Bun
|
|
78
|
+
*/
|
|
79
|
+
async run(testFile, index, total, options) {
|
|
80
|
+
this.logger.testFileStart(testFile, this.displayName, index, total);
|
|
81
|
+
const tapParser = new TapParser(testFile + ':bun', this.logger);
|
|
82
|
+
const mergedOptions = this.mergeOptions(options);
|
|
83
|
+
// Build Bun command
|
|
84
|
+
const command = this.createCommand(testFile, mergedOptions);
|
|
85
|
+
const fullCommand = `${command.command} ${command.args.join(' ')}`;
|
|
86
|
+
// Set filter tags as environment variable
|
|
87
|
+
if (this.filterTags.length > 0) {
|
|
88
|
+
process.env.TSTEST_FILTER_TAGS = this.filterTags.join(',');
|
|
89
|
+
}
|
|
90
|
+
// Check for 00init.ts file in test directory
|
|
91
|
+
const testDir = plugins.path.dirname(testFile);
|
|
92
|
+
const initFile = plugins.path.join(testDir, '00init.ts');
|
|
93
|
+
const initFileExists = await plugins.smartfile.fs.fileExists(initFile);
|
|
94
|
+
let runCommand = fullCommand;
|
|
95
|
+
let loaderPath = null;
|
|
96
|
+
// If 00init.ts exists, create a loader file
|
|
97
|
+
if (initFileExists) {
|
|
98
|
+
const absoluteInitFile = plugins.path.resolve(initFile);
|
|
99
|
+
const absoluteTestFile = plugins.path.resolve(testFile);
|
|
100
|
+
const loaderContent = `
|
|
101
|
+
import '${absoluteInitFile.replace(/\\/g, '/')}';
|
|
102
|
+
import '${absoluteTestFile.replace(/\\/g, '/')}';
|
|
103
|
+
`;
|
|
104
|
+
loaderPath = plugins.path.join(testDir, `.loader_${plugins.path.basename(testFile)}`);
|
|
105
|
+
await plugins.smartfile.memory.toFs(loaderContent, loaderPath);
|
|
106
|
+
// Rebuild command with loader file
|
|
107
|
+
const loaderCommand = this.createCommand(loaderPath, mergedOptions);
|
|
108
|
+
runCommand = `${loaderCommand.command} ${loaderCommand.args.join(' ')}`;
|
|
109
|
+
}
|
|
110
|
+
const execResultStreaming = await this.smartshellInstance.execStreamingSilent(runCommand);
|
|
111
|
+
// If we created a loader file, clean it up after test execution
|
|
112
|
+
if (loaderPath) {
|
|
113
|
+
const cleanup = () => {
|
|
114
|
+
try {
|
|
115
|
+
if (plugins.smartfile.fs.fileExistsSync(loaderPath)) {
|
|
116
|
+
plugins.smartfile.fs.removeSync(loaderPath);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
catch (e) {
|
|
120
|
+
// Ignore cleanup errors
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
execResultStreaming.childProcess.on('exit', cleanup);
|
|
124
|
+
execResultStreaming.childProcess.on('error', cleanup);
|
|
125
|
+
}
|
|
126
|
+
// Start warning timer if no timeout was specified
|
|
127
|
+
let warningTimer = null;
|
|
128
|
+
if (this.timeoutSeconds === null) {
|
|
129
|
+
warningTimer = setTimeout(() => {
|
|
130
|
+
console.error('');
|
|
131
|
+
console.error(cs('⚠️ WARNING: Test file is running for more than 1 minute', 'orange'));
|
|
132
|
+
console.error(cs(` File: ${testFile}`, 'orange'));
|
|
133
|
+
console.error(cs(' Consider using --timeout option to set a timeout for test files.', 'orange'));
|
|
134
|
+
console.error(cs(' Example: tstest test --timeout=300 (for 5 minutes)', 'orange'));
|
|
135
|
+
console.error('');
|
|
136
|
+
}, 60000); // 1 minute
|
|
137
|
+
}
|
|
138
|
+
// Handle timeout if specified
|
|
139
|
+
if (this.timeoutSeconds !== null) {
|
|
140
|
+
const timeoutMs = this.timeoutSeconds * 1000;
|
|
141
|
+
let timeoutId;
|
|
142
|
+
const timeoutPromise = new Promise((_resolve, reject) => {
|
|
143
|
+
timeoutId = setTimeout(async () => {
|
|
144
|
+
// Use smartshell's terminate() to kill entire process tree
|
|
145
|
+
await execResultStreaming.terminate();
|
|
146
|
+
reject(new Error(`Test file timed out after ${this.timeoutSeconds} seconds`));
|
|
147
|
+
}, timeoutMs);
|
|
148
|
+
});
|
|
149
|
+
try {
|
|
150
|
+
await Promise.race([
|
|
151
|
+
tapParser.handleTapProcess(execResultStreaming.childProcess),
|
|
152
|
+
timeoutPromise
|
|
153
|
+
]);
|
|
154
|
+
// Clear timeout if test completed successfully
|
|
155
|
+
clearTimeout(timeoutId);
|
|
156
|
+
}
|
|
157
|
+
catch (error) {
|
|
158
|
+
// Clear warning timer if it was set
|
|
159
|
+
if (warningTimer) {
|
|
160
|
+
clearTimeout(warningTimer);
|
|
161
|
+
}
|
|
162
|
+
// Handle timeout error
|
|
163
|
+
tapParser.handleTimeout(this.timeoutSeconds);
|
|
164
|
+
// Ensure entire process tree is killed if still running
|
|
165
|
+
try {
|
|
166
|
+
await execResultStreaming.kill(); // This kills the entire process tree with SIGKILL
|
|
167
|
+
}
|
|
168
|
+
catch (killError) {
|
|
169
|
+
// Process tree might already be dead
|
|
170
|
+
}
|
|
171
|
+
await tapParser.evaluateFinalResult();
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
await tapParser.handleTapProcess(execResultStreaming.childProcess);
|
|
176
|
+
}
|
|
177
|
+
// Clear warning timer if it was set
|
|
178
|
+
if (warningTimer) {
|
|
179
|
+
clearTimeout(warningTimer);
|
|
180
|
+
}
|
|
181
|
+
return tapParser;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN0ZXN0LmNsYXNzZXMucnVudGltZS5idW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c3Rlc3QuY2xhc3Nlcy5ydW50aW1lLmJ1bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLElBQUksRUFBRSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUNMLGNBQWMsR0FJZixNQUFNLHFDQUFxQyxDQUFDO0FBQzdDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMzRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFHbkQ7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLGlCQUFrQixTQUFRLGNBQWM7SUFJbkQsWUFDVSxNQUFvQixFQUNwQixrQkFBdUIsRUFBRSxrREFBa0Q7SUFDM0UsY0FBNkIsRUFDN0IsVUFBb0I7UUFFNUIsS0FBSyxFQUFFLENBQUM7UUFMQSxXQUFNLEdBQU4sTUFBTSxDQUFjO1FBQ3BCLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBSztRQUN2QixtQkFBYyxHQUFkLGNBQWMsQ0FBZTtRQUM3QixlQUFVLEdBQVYsVUFBVSxDQUFVO1FBUHJCLE9BQUUsR0FBWSxLQUFLLENBQUM7UUFDcEIsZ0JBQVcsR0FBVyxLQUFLLENBQUM7SUFTckMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxDQUFDLGNBQWM7UUFDbEIsSUFBSSxDQUFDO1lBQ0gsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRTtnQkFDakUsR0FBRyxFQUFFLE9BQU8sQ0FBQyxHQUFHLEVBQUU7Z0JBQ2xCLE9BQU8sRUFBRSxHQUFHLEVBQUU7b0JBQ1osZUFBZTtnQkFDakIsQ0FBQzthQUNGLENBQUMsQ0FBQztZQUVILElBQUksTUFBTSxDQUFD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
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { RuntimeAdapter, type ChromiumOptions, type RuntimeCommand, type RuntimeAvailability } from './tstest.classes.runtime.adapter.js';
|
|
2
|
+
import { TapParser } from './tstest.classes.tap.parser.js';
|
|
3
|
+
import { TsTestLogger } from './tstest.logging.js';
|
|
4
|
+
import type { Runtime } from './tstest.classes.runtime.parser.js';
|
|
5
|
+
/**
|
|
6
|
+
* Chromium runtime adapter
|
|
7
|
+
* Executes tests in a headless Chromium browser
|
|
8
|
+
*/
|
|
9
|
+
export declare class ChromiumRuntimeAdapter extends RuntimeAdapter {
|
|
10
|
+
private logger;
|
|
11
|
+
private tsbundleInstance;
|
|
12
|
+
private smartbrowserInstance;
|
|
13
|
+
private timeoutSeconds;
|
|
14
|
+
readonly id: Runtime;
|
|
15
|
+
readonly displayName: string;
|
|
16
|
+
constructor(logger: TsTestLogger, tsbundleInstance: any, // TsBundle instance from @push.rocks/tsbundle
|
|
17
|
+
smartbrowserInstance: any, // SmartBrowser instance from @push.rocks/smartbrowser
|
|
18
|
+
timeoutSeconds: number | null);
|
|
19
|
+
/**
|
|
20
|
+
* Check if Chromium is available
|
|
21
|
+
*/
|
|
22
|
+
checkAvailable(): Promise<RuntimeAvailability>;
|
|
23
|
+
/**
|
|
24
|
+
* Create command configuration for Chromium test execution
|
|
25
|
+
* Note: Chromium tests don't use a traditional command, but this satisfies the interface
|
|
26
|
+
*/
|
|
27
|
+
createCommand(testFile: string, options?: ChromiumOptions): RuntimeCommand;
|
|
28
|
+
/**
|
|
29
|
+
* Find free ports for HTTP server and WebSocket
|
|
30
|
+
*/
|
|
31
|
+
private findFreePorts;
|
|
32
|
+
/**
|
|
33
|
+
* Execute a test file in Chromium browser
|
|
34
|
+
*/
|
|
35
|
+
run(testFile: string, index: number, total: number, options?: ChromiumOptions): Promise<TapParser>;
|
|
36
|
+
}
|
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
import * as plugins from './tstest.plugins.js';
|
|
2
|
+
import * as paths from './tstest.paths.js';
|
|
3
|
+
import { coloredString as cs } from '@push.rocks/consolecolor';
|
|
4
|
+
import { RuntimeAdapter, } from './tstest.classes.runtime.adapter.js';
|
|
5
|
+
import { TapParser } from './tstest.classes.tap.parser.js';
|
|
6
|
+
import { TsTestLogger } from './tstest.logging.js';
|
|
7
|
+
/**
|
|
8
|
+
* Chromium runtime adapter
|
|
9
|
+
* Executes tests in a headless Chromium browser
|
|
10
|
+
*/
|
|
11
|
+
export class ChromiumRuntimeAdapter extends RuntimeAdapter {
|
|
12
|
+
constructor(logger, tsbundleInstance, // TsBundle instance from @push.rocks/tsbundle
|
|
13
|
+
smartbrowserInstance, // SmartBrowser instance from @push.rocks/smartbrowser
|
|
14
|
+
timeoutSeconds) {
|
|
15
|
+
super();
|
|
16
|
+
this.logger = logger;
|
|
17
|
+
this.tsbundleInstance = tsbundleInstance;
|
|
18
|
+
this.smartbrowserInstance = smartbrowserInstance;
|
|
19
|
+
this.timeoutSeconds = timeoutSeconds;
|
|
20
|
+
this.id = 'chromium';
|
|
21
|
+
this.displayName = 'Chromium';
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Check if Chromium is available
|
|
25
|
+
*/
|
|
26
|
+
async checkAvailable() {
|
|
27
|
+
try {
|
|
28
|
+
// Check if smartbrowser is available and can start
|
|
29
|
+
// The browser binary is usually handled by @push.rocks/smartbrowser
|
|
30
|
+
return {
|
|
31
|
+
available: true,
|
|
32
|
+
version: 'Chromium (via smartbrowser)',
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
return {
|
|
37
|
+
available: false,
|
|
38
|
+
error: error.message || 'Chromium not available',
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Create command configuration for Chromium test execution
|
|
44
|
+
* Note: Chromium tests don't use a traditional command, but this satisfies the interface
|
|
45
|
+
*/
|
|
46
|
+
createCommand(testFile, options) {
|
|
47
|
+
const mergedOptions = this.mergeOptions(options);
|
|
48
|
+
return {
|
|
49
|
+
command: 'chromium',
|
|
50
|
+
args: [],
|
|
51
|
+
env: mergedOptions.env,
|
|
52
|
+
cwd: mergedOptions.cwd,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Find free ports for HTTP server and WebSocket
|
|
57
|
+
*/
|
|
58
|
+
async findFreePorts() {
|
|
59
|
+
const smartnetwork = new plugins.smartnetwork.SmartNetwork();
|
|
60
|
+
// Find random free HTTP port in range 30000-40000 to minimize collision chance
|
|
61
|
+
const httpPort = await smartnetwork.findFreePort(30000, 40000, { randomize: true });
|
|
62
|
+
if (!httpPort) {
|
|
63
|
+
throw new Error('Could not find a free HTTP port in range 30000-40000');
|
|
64
|
+
}
|
|
65
|
+
// Find random free WebSocket port, excluding the HTTP port to ensure they're different
|
|
66
|
+
const wsPort = await smartnetwork.findFreePort(30000, 40000, {
|
|
67
|
+
randomize: true,
|
|
68
|
+
exclude: [httpPort]
|
|
69
|
+
});
|
|
70
|
+
if (!wsPort) {
|
|
71
|
+
throw new Error('Could not find a free WebSocket port in range 30000-40000');
|
|
72
|
+
}
|
|
73
|
+
// Log selected ports for debugging
|
|
74
|
+
if (!this.logger.options.quiet) {
|
|
75
|
+
console.log(`Selected ports - HTTP: ${httpPort}, WebSocket: ${wsPort}`);
|
|
76
|
+
}
|
|
77
|
+
return { httpPort, wsPort };
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Execute a test file in Chromium browser
|
|
81
|
+
*/
|
|
82
|
+
async run(testFile, index, total, options) {
|
|
83
|
+
this.logger.testFileStart(testFile, this.displayName, index, total);
|
|
84
|
+
// lets get all our paths sorted
|
|
85
|
+
const tsbundleCacheDirPath = plugins.path.join(paths.cwd, './.nogit/tstest_cache');
|
|
86
|
+
const bundleFileName = testFile.replace('/', '__') + '.js';
|
|
87
|
+
const bundleFilePath = plugins.path.join(tsbundleCacheDirPath, bundleFileName);
|
|
88
|
+
// lets bundle the test
|
|
89
|
+
await plugins.smartfile.fs.ensureEmptyDir(tsbundleCacheDirPath);
|
|
90
|
+
await this.tsbundleInstance.build(process.cwd(), testFile, bundleFilePath, {
|
|
91
|
+
bundler: 'esbuild',
|
|
92
|
+
});
|
|
93
|
+
// Find free ports for HTTP and WebSocket
|
|
94
|
+
const { httpPort, wsPort } = await this.findFreePorts();
|
|
95
|
+
// lets create a server
|
|
96
|
+
const server = new plugins.typedserver.servertools.Server({
|
|
97
|
+
cors: true,
|
|
98
|
+
port: httpPort,
|
|
99
|
+
});
|
|
100
|
+
server.addRoute('/test', new plugins.typedserver.servertools.Handler('GET', async (_req, res) => {
|
|
101
|
+
res.type('.html');
|
|
102
|
+
res.write(`
|
|
103
|
+
<html>
|
|
104
|
+
<head>
|
|
105
|
+
<script>
|
|
106
|
+
globalThis.testdom = true;
|
|
107
|
+
globalThis.wsPort = ${wsPort};
|
|
108
|
+
</script>
|
|
109
|
+
</head>
|
|
110
|
+
<body></body>
|
|
111
|
+
</html>
|
|
112
|
+
`);
|
|
113
|
+
res.end();
|
|
114
|
+
}));
|
|
115
|
+
server.addRoute('/*splat', new plugins.typedserver.servertools.HandlerStatic(tsbundleCacheDirPath));
|
|
116
|
+
await server.start();
|
|
117
|
+
// lets handle realtime comms
|
|
118
|
+
const tapParser = new TapParser(testFile + ':chrome', this.logger);
|
|
119
|
+
const wss = new plugins.ws.WebSocketServer({ port: wsPort });
|
|
120
|
+
wss.on('connection', (ws) => {
|
|
121
|
+
ws.on('message', (message) => {
|
|
122
|
+
const messageStr = message.toString();
|
|
123
|
+
if (messageStr.startsWith('console:')) {
|
|
124
|
+
const [, level, ...messageParts] = messageStr.split(':');
|
|
125
|
+
this.logger.browserConsole(messageParts.join(':'), level);
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
tapParser.handleTapLog(messageStr);
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
// lets do the browser bit with timeout handling
|
|
133
|
+
await this.smartbrowserInstance.start();
|
|
134
|
+
const evaluatePromise = this.smartbrowserInstance.evaluateOnPage(`http://localhost:${httpPort}/test?bundleName=${bundleFileName}`, async () => {
|
|
135
|
+
// lets enable real time comms
|
|
136
|
+
const ws = new WebSocket(`ws://localhost:${globalThis.wsPort}`);
|
|
137
|
+
await new Promise((resolve) => (ws.onopen = resolve));
|
|
138
|
+
// Ensure this function is declared with 'async'
|
|
139
|
+
const logStore = [];
|
|
140
|
+
const originalLog = console.log;
|
|
141
|
+
const originalError = console.error;
|
|
142
|
+
// Override console methods to capture the logs
|
|
143
|
+
console.log = (...args) => {
|
|
144
|
+
logStore.push(args.join(' '));
|
|
145
|
+
ws.send(args.join(' '));
|
|
146
|
+
originalLog(...args);
|
|
147
|
+
};
|
|
148
|
+
console.error = (...args) => {
|
|
149
|
+
logStore.push(args.join(' '));
|
|
150
|
+
ws.send(args.join(' '));
|
|
151
|
+
originalError(...args);
|
|
152
|
+
};
|
|
153
|
+
const bundleName = new URLSearchParams(window.location.search).get('bundleName');
|
|
154
|
+
originalLog(`::TSTEST IN CHROMIUM:: Relevant Script name is: ${bundleName}`);
|
|
155
|
+
try {
|
|
156
|
+
// Dynamically import the test module
|
|
157
|
+
const testModule = await import(`/${bundleName}`);
|
|
158
|
+
if (testModule && testModule.default && testModule.default instanceof Promise) {
|
|
159
|
+
// Execute the exported test function
|
|
160
|
+
await testModule.default;
|
|
161
|
+
}
|
|
162
|
+
else if (testModule && testModule.default && typeof testModule.default.then === 'function') {
|
|
163
|
+
console.log('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!');
|
|
164
|
+
console.log('Test module default export is just promiselike: Something might be messing with your Promise implementation.');
|
|
165
|
+
console.log('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!');
|
|
166
|
+
await testModule.default;
|
|
167
|
+
}
|
|
168
|
+
else if (globalThis.tapPromise && typeof globalThis.tapPromise.then === 'function') {
|
|
169
|
+
console.log('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!');
|
|
170
|
+
console.log('Using globalThis.tapPromise');
|
|
171
|
+
console.log('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!');
|
|
172
|
+
await testModule.default;
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
console.error('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!');
|
|
176
|
+
console.error('Test module does not export a default promise.');
|
|
177
|
+
console.error('!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!');
|
|
178
|
+
console.log(`We got: ${JSON.stringify(testModule)}`);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
catch (err) {
|
|
182
|
+
console.error(err);
|
|
183
|
+
}
|
|
184
|
+
return logStore.join('\n');
|
|
185
|
+
});
|
|
186
|
+
// Start warning timer if no timeout was specified
|
|
187
|
+
let warningTimer = null;
|
|
188
|
+
if (this.timeoutSeconds === null) {
|
|
189
|
+
warningTimer = setTimeout(() => {
|
|
190
|
+
console.error('');
|
|
191
|
+
console.error(cs('⚠️ WARNING: Test file is running for more than 1 minute', 'orange'));
|
|
192
|
+
console.error(cs(` File: ${testFile}`, 'orange'));
|
|
193
|
+
console.error(cs(' Consider using --timeout option to set a timeout for test files.', 'orange'));
|
|
194
|
+
console.error(cs(' Example: tstest test --timeout=300 (for 5 minutes)', 'orange'));
|
|
195
|
+
console.error('');
|
|
196
|
+
}, 60000); // 1 minute
|
|
197
|
+
}
|
|
198
|
+
// Handle timeout if specified
|
|
199
|
+
if (this.timeoutSeconds !== null) {
|
|
200
|
+
const timeoutMs = this.timeoutSeconds * 1000;
|
|
201
|
+
let timeoutId;
|
|
202
|
+
const timeoutPromise = new Promise((_resolve, reject) => {
|
|
203
|
+
timeoutId = setTimeout(() => {
|
|
204
|
+
reject(new Error(`Test file timed out after ${this.timeoutSeconds} seconds`));
|
|
205
|
+
}, timeoutMs);
|
|
206
|
+
});
|
|
207
|
+
try {
|
|
208
|
+
await Promise.race([
|
|
209
|
+
evaluatePromise,
|
|
210
|
+
timeoutPromise
|
|
211
|
+
]);
|
|
212
|
+
// Clear timeout if test completed successfully
|
|
213
|
+
clearTimeout(timeoutId);
|
|
214
|
+
}
|
|
215
|
+
catch (error) {
|
|
216
|
+
// Clear warning timer if it was set
|
|
217
|
+
if (warningTimer) {
|
|
218
|
+
clearTimeout(warningTimer);
|
|
219
|
+
}
|
|
220
|
+
// Handle timeout error
|
|
221
|
+
tapParser.handleTimeout(this.timeoutSeconds);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
await evaluatePromise;
|
|
226
|
+
}
|
|
227
|
+
// Clear warning timer if it was set
|
|
228
|
+
if (warningTimer) {
|
|
229
|
+
clearTimeout(warningTimer);
|
|
230
|
+
}
|
|
231
|
+
// Always clean up resources, even on timeout
|
|
232
|
+
try {
|
|
233
|
+
await this.smartbrowserInstance.stop();
|
|
234
|
+
}
|
|
235
|
+
catch (error) {
|
|
236
|
+
// Browser might already be stopped
|
|
237
|
+
}
|
|
238
|
+
try {
|
|
239
|
+
await server.stop();
|
|
240
|
+
}
|
|
241
|
+
catch (error) {
|
|
242
|
+
// Server might already be stopped
|
|
243
|
+
}
|
|
244
|
+
try {
|
|
245
|
+
wss.close();
|
|
246
|
+
}
|
|
247
|
+
catch (error) {
|
|
248
|
+
// WebSocket server might already be closed
|
|
249
|
+
}
|
|
250
|
+
console.log(`${cs('=> ', 'blue')} Stopped ${cs(testFile, 'orange')} chromium instance and server.`);
|
|
251
|
+
// Always evaluate final result (handleTimeout just sets up the test state)
|
|
252
|
+
await tapParser.evaluateFinalResult();
|
|
253
|
+
return tapParser;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tstest.classes.runtime.chromium.js","sourceRoot":"","sources":["../ts/tstest.classes.runtime.chromium.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,qBAAqB,CAAC;AAC/C,OAAO,KAAK,KAAK,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,aAAa,IAAI,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EACL,cAAc,GAIf,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGnD;;;GAGG;AACH,MAAM,OAAO,sBAAuB,SAAQ,cAAc;IAIxD,YACU,MAAoB,EACpB,gBAAqB,EAAE,8CAA8C;IACrE,oBAAyB,EAAE,sDAAsD;IACjF,cAA6B;QAErC,KAAK,EAAE,CAAC;QALA,WAAM,GAAN,MAAM,CAAc;QACpB,qBAAgB,GAAhB,gBAAgB,CAAK;QACrB,yBAAoB,GAApB,oBAAoB,CAAK;QACzB,mBAAc,GAAd,cAAc,CAAe;QAP9B,OAAE,GAAY,UAAU,CAAC;QACzB,gBAAW,GAAW,UAAU,CAAC;IAS1C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,cAAc;QAClB,IAAI,CAAC;YACH,mDAAmD;YACnD,oEAAoE;YACpE,OAAO;gBACL,SAAS,EAAE,IAAI;gBACf,OAAO,EAAE,6BAA6B;aACvC,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO;gBACL,SAAS,EAAE,KAAK;gBAChB,KAAK,EAAE,KAAK,CAAC,OAAO,IAAI,wBAAwB;aACjD,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,QAAgB,EAAE,OAAyB;QACvD,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAEjD,OAAO;YACL,OAAO,EAAE,UAAU;YACnB,IAAI,EAAE,EAAE;YACR,GAAG,EAAE,aAAa,CAAC,GAAG;YACtB,GAAG,EAAE,aAAa,CAAC,GAAG;SACvB,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,aAAa;QACzB,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;QAE7D,+EAA+E;QAC/E,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACpF,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QAED,uFAAuF;QACvF,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE;YAC3D,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,CAAC,QAAQ,CAAC;SACpB,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC;QAC/E,CAAC;QAED,mCAAmC;QACnC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAC/B,OAAO,CAAC,GAAG,CAAC,0BAA0B,QAAQ,gBAAgB,MAAM,EAAE,CAAC,CAAC;QAC1E,CAAC;QACD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,GAAG,CACP,QAAgB,EAChB,KAAa,EACb,KAAa,EACb,OAAyB;QAEzB,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAEpE,gCAAgC;QAChC,MAAM,oBAAoB,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,uBAAuB,CAAC,CAAC;QACnF,MAAM,cAAc,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,KAAK,CAAC;QAC3D,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,cAAc,CAAC,CAAC;QAE/E,uBAAuB;QACvB,MAAM,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC;QAChE,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,EAAE,cAAc,EAAE;YACzE,OAAO,EAAE,SAAS;SACnB,CAAC,CAAC;QAEH,yCAAyC;QACzC,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;QAExD,uBAAuB;QACvB,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAAC;YACxD,IAAI,EAAE,IAAI;YACV,IAAI,EAAE,QAAQ;SACf,CAAC,CAAC;QACH,MAAM,CAAC,QAAQ,CACb,OAAO,EACP,IAAI,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE;YACrE,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAClB,GAAG,CAAC,KAAK,CAAC;;;;;oCAKkB,MAAM;;;;;OAKnC,CAAC,CAAC;YACD,GAAG,CAAC,GAAG,EAAE,CAAC;QACZ,CAAC,CAAC,CACH,CAAC;QACF,MAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACpG,MAAM,MAAM,CAAC,KAAK,EAAE,CAAC;QAErB,6BAA6B;QAC7B,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,QAAQ,GAAG,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACnE,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,EAAE,CAAC,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QAC7D,GAAG,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,EAAE,EAAE,EAAE;YAC1B,EAAE,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;gBAC3B,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACtC,IAAI,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;oBACtC,MAAM,CAAC,EAAE,KAAK,EAAE,GAAG,YAAY,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACzD,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;gBAC5D,CAAC;qBAAM,CAAC;oBACN,SAAS,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;gBACrC,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,gDAAgD;QAChD,MAAM,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC;QAExC,MAAM,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAC9D,oBAAoB,QAAQ,oBAAoB,cAAc,EAAE,EAChE,KAAK,IAAI,EAAE;YACT,8BAA8B;YAC9B,MAAM,EAAE,GAAG,IAAI,SAAS,CAAC,kBAAkB,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;YAChE,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC;YAEtD,gDAAgD;YAChD,MAAM,QAAQ,GAAG,EAAE,CAAC;YACpB,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC;YAChC,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC;YAEpC,+CAA+C;YAC/C,OAAO,CAAC,GAAG,GAAG,CAAC,GAAG,IAAW,EAAE,EAAE;gBAC/B,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC9B,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBACxB,WAAW,CAAC,GAAG,IAAI,CAAC,CAAC;YACvB,CAAC,CAAC;YACF,OAAO,CAAC,KAAK,GAAG,CAAC,GAAG,IAAW,EAAE,EAAE;gBACjC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC9B,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBACxB,aAAa,CAAC,GAAG,IAAI,CAAC,CAAC;YACzB,CAAC,CAAC;YAEF,MAAM,UAAU,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;YACjF,WAAW,CAAC,mDAAmD,UAAU,EAAE,CAAC,CAAC;YAE7E,IAAI,CAAC;gBACH,qCAAqC;gBACrC,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC,CAAC;gBAClD,IAAI,UAAU,IAAI,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,OAAO,YAAY,OAAO,EAAE,CAAC;oBAC9E,qCAAqC;oBACrC,MAAM,UAAU,CAAC,OAAO,CAAC;gBAC3B,CAAC;qBAAM,IAAI,UAAU,IAAI,UAAU,CAAC,OAAO,IAAI,OAAO,UAAU,CAAC,OAAO,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;oBAC7F,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;oBAC7D,OAAO,CAAC,GAAG,CAAC,8GAA8G,CAAC,CAAC;oBAC5H,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;oBAC7D,MAAM,UAAU,CAAC,OAAO,CAAC;gBAC3B,CAAC;qBAAM,IAAI,UAAU,CAAC,UAAU,IAAI,OAAO,UAAU,CAAC,UAAU,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;oBACrF,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;oBAC7D,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;oBAC3C,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;oBAC7D,MAAM,UAAU,CAAC,OAAO,CAAC;gBAC3B,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;oBAC/D,OAAO,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAC;oBAChE,OAAO,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;oBAC/D,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;gBACvD,CAAC;YACH,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACrB,CAAC;YAED,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC,CACF,CAAC;QAEF,kDAAkD;QAClD,IAAI,YAAY,GAA0B,IAAI,CAAC;QAC/C,IAAI,IAAI,CAAC,cAAc,KAAK,IAAI,EAAE,CAAC;YACjC,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC7B,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBAClB,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,0DAA0D,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACxF,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,QAAQ,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACpD,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,qEAAqE,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACnG,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,uDAAuD,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACrF,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpB,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,WAAW;QACxB,CAAC;QAED,8BAA8B;QAC9B,IAAI,IAAI,CAAC,cAAc,KAAK,IAAI,EAAE,CAAC;YACjC,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC7C,IAAI,SAAyB,CAAC;YAE9B,MAAM,cAAc,GAAG,IAAI,OAAO,CAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE;gBAC5D,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;oBAC1B,MAAM,CAAC,IAAI,KAAK,CAAC,6BAA6B,IAAI,CAAC,cAAc,UAAU,CAAC,CAAC,CAAC;gBAChF,CAAC,EAAE,SAAS,CAAC,CAAC;YAChB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC;gBACH,MAAM,OAAO,CAAC,IAAI,CAAC;oBACjB,eAAe;oBACf,cAAc;iBACf,CAAC,CAAC;gBACH,+CAA+C;gBAC/C,YAAY,CAAC,SAAS,CAAC,CAAC;YAC1B,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,oCAAoC;gBACpC,IAAI,YAAY,EAAE,CAAC;oBACjB,YAAY,CAAC,YAAY,CAAC,CAAC;gBAC7B,CAAC;gBACD,uBAAuB;gBACvB,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC/C,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,eAAe,CAAC;QACxB,CAAC;QAED,oCAAoC;QACpC,IAAI,YAAY,EAAE,CAAC;YACjB,YAAY,CAAC,YAAY,CAAC,CAAC;QAC7B,CAAC;QAED,6CAA6C;QAC7C,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC;QACzC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,mCAAmC;QACrC,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC;QACtB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,kCAAkC;QACpC,CAAC;QAED,IAAI,CAAC;YACH,GAAG,CAAC,KAAK,EAAE,CAAC;QACd,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,2CAA2C;QAC7C,CAAC;QAED,OAAO,CAAC,GAAG,CACT,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,YAAY,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,gCAAgC,CACvF,CAAC;QACF,2EAA2E;QAC3E,MAAM,SAAS,CAAC,mBAAmB,EAAE,CAAC;QACtC,OAAO,SAAS,CAAC;IACnB,CAAC;CACF"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { RuntimeAdapter, type DenoOptions, type RuntimeCommand, type RuntimeAvailability } from './tstest.classes.runtime.adapter.js';
|
|
2
|
+
import { TapParser } from './tstest.classes.tap.parser.js';
|
|
3
|
+
import { TsTestLogger } from './tstest.logging.js';
|
|
4
|
+
import type { Runtime } from './tstest.classes.runtime.parser.js';
|
|
5
|
+
/**
|
|
6
|
+
* Deno runtime adapter
|
|
7
|
+
* Executes tests using the Deno runtime
|
|
8
|
+
*/
|
|
9
|
+
export declare class DenoRuntimeAdapter extends RuntimeAdapter {
|
|
10
|
+
private logger;
|
|
11
|
+
private smartshellInstance;
|
|
12
|
+
private timeoutSeconds;
|
|
13
|
+
private filterTags;
|
|
14
|
+
readonly id: Runtime;
|
|
15
|
+
readonly displayName: string;
|
|
16
|
+
constructor(logger: TsTestLogger, smartshellInstance: any, // SmartShell instance from @push.rocks/smartshell
|
|
17
|
+
timeoutSeconds: number | null, filterTags: string[]);
|
|
18
|
+
/**
|
|
19
|
+
* Get default Deno options
|
|
20
|
+
*/
|
|
21
|
+
protected getDefaultOptions(): DenoOptions;
|
|
22
|
+
/**
|
|
23
|
+
* Check if Deno is available
|
|
24
|
+
*/
|
|
25
|
+
checkAvailable(): Promise<RuntimeAvailability>;
|
|
26
|
+
/**
|
|
27
|
+
* Create command configuration for Deno test execution
|
|
28
|
+
*/
|
|
29
|
+
createCommand(testFile: string, options?: DenoOptions): RuntimeCommand;
|
|
30
|
+
/**
|
|
31
|
+
* Execute a test file in Deno
|
|
32
|
+
*/
|
|
33
|
+
run(testFile: string, index: number, total: number, options?: DenoOptions): Promise<TapParser>;
|
|
34
|
+
}
|