Compare commits
14 Commits
Author | SHA1 | Date | |
---|---|---|---|
f1a0455662 | |||
3c62129e02 | |||
ac5e036967 | |||
6ccd0281b9 | |||
d0f85b026f | |||
4376cafabb | |||
1a6e449b8d | |||
6ec99e7276 | |||
e958417d47 | |||
24416c1b5c | |||
d6c8fcc1cf | |||
53bb97c6db | |||
4f35b101ec | |||
549ae53a00 |
@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/env node
|
#!/usr/bin/env node
|
||||||
process.env.CLI_CALL = 'true';
|
process.env.CLI_CALL = 'true';
|
||||||
|
|
||||||
import * as tsrun from '@gitzone/tsrun';
|
import * as tsrun from '@git.zone/tsrun';
|
||||||
tsrun.runPath('./cli.child.js', import.meta.url);
|
tsrun.runPath('./cli.child.js', import.meta.url);
|
||||||
|
26
package.json
26
package.json
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@gitzone/tstest",
|
"name": "@git.zone/tstest",
|
||||||
"version": "1.0.76",
|
"version": "1.0.83",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "a test utility to run tests that match test/**/*.ts",
|
"description": "a test utility to run tests that match test/**/*.ts",
|
||||||
"main": "dist_ts/index.js",
|
"main": "dist_ts/index.js",
|
||||||
@ -20,22 +20,24 @@
|
|||||||
"buildDocs": "tsdoc"
|
"buildDocs": "tsdoc"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@gitzone/tsbuild": "^2.1.66",
|
"@git.zone/tsbuild": "^2.1.70",
|
||||||
"@types/node": "^20.4.2"
|
"@types/node": "^20.9.0"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@apiglobal/typedserver": "^2.0.65",
|
"@api.global/typedserver": "^3.0.9",
|
||||||
"@gitzone/tsbundle": "^2.0.8",
|
"@git.zone/tsbundle": "^2.0.10",
|
||||||
"@gitzone/tsrun": "^1.2.43",
|
"@git.zone/tsrun": "^1.2.46",
|
||||||
"@push.rocks/consolecolor": "^2.0.1",
|
"@push.rocks/consolecolor": "^2.0.1",
|
||||||
"@push.rocks/smartbrowser": "^2.0.5",
|
"@push.rocks/smartbrowser": "^2.0.6",
|
||||||
"@push.rocks/smartdelay": "^3.0.2",
|
"@push.rocks/smartdelay": "^3.0.5",
|
||||||
"@push.rocks/smartfile": "^10.0.28",
|
"@push.rocks/smartfile": "^11.0.0",
|
||||||
"@push.rocks/smartlog": "^3.0.3",
|
"@push.rocks/smartlog": "^3.0.3",
|
||||||
"@push.rocks/smartpromise": "^4.0.3",
|
"@push.rocks/smartpromise": "^4.0.3",
|
||||||
"@push.rocks/smartshell": "^3.0.3",
|
"@push.rocks/smartshell": "^3.0.3",
|
||||||
"@push.rocks/tapbundle": "^5.0.12",
|
"@push.rocks/tapbundle": "^5.0.15",
|
||||||
"figures": "^5.0.0"
|
"@types/ws": "^8.5.9",
|
||||||
|
"figures": "^6.0.1",
|
||||||
|
"ws": "^8.14.2"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"ts/**/*",
|
"ts/**/*",
|
||||||
|
2788
pnpm-lock.yaml
generated
2788
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
* autocreated commitinfo by @pushrocks/commitinfo
|
* autocreated commitinfo by @pushrocks/commitinfo
|
||||||
*/
|
*/
|
||||||
export const commitinfo = {
|
export const commitinfo = {
|
||||||
name: '@gitzone/tstest',
|
name: '@git.zone/tstest',
|
||||||
version: '1.0.76',
|
version: '1.0.83',
|
||||||
description: 'a test utility to run tests that match test/**/*.ts'
|
description: 'a test utility to run tests that match test/**/*.ts'
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import * as plugins from './tstest.plugins.js';
|
import * as plugins from './tstest.plugins.js';
|
||||||
import * as paths from './tstest.paths.js';
|
import * as paths from './tstest.paths.js';
|
||||||
import { Smartfile } from '@push.rocks/smartfile';
|
import { SmartFile } from '@push.rocks/smartfile';
|
||||||
|
|
||||||
// tap related stuff
|
// tap related stuff
|
||||||
import { TapCombinator } from './tstest.classes.tap.combinator.js';
|
import { TapCombinator } from './tstest.classes.tap.combinator.js';
|
||||||
@ -26,7 +26,7 @@ export class TestDirectory {
|
|||||||
/**
|
/**
|
||||||
* an array of Smartfiles
|
* an array of Smartfiles
|
||||||
*/
|
*/
|
||||||
testfileArray: Smartfile[] = [];
|
testfileArray: SmartFile[] = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the constructor for TestDirectory
|
* the constructor for TestDirectory
|
||||||
|
@ -129,90 +129,62 @@ export class TsTest {
|
|||||||
server.addRoute('*', new plugins.typedserver.servertools.HandlerStatic(tsbundleCacheDirPath));
|
server.addRoute('*', new plugins.typedserver.servertools.HandlerStatic(tsbundleCacheDirPath));
|
||||||
await server.start();
|
await server.start();
|
||||||
|
|
||||||
|
// lets handle realtime comms
|
||||||
|
const wss = new plugins.ws.WebSocketServer({ port: 8080 });
|
||||||
|
wss.on('connection', (ws) => {
|
||||||
|
ws.on('message', (message) => {
|
||||||
|
console.log(message.toString());
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
// lets do the browser bit
|
// lets do the browser bit
|
||||||
await this.smartbrowserInstance.start();
|
await this.smartbrowserInstance.start();
|
||||||
const evaluation = await this.smartbrowserInstance.evaluateOnPage(
|
const evaluation = await this.smartbrowserInstance.evaluateOnPage(
|
||||||
`http://localhost:3007/test?bundleName=${bundleFileName}`,
|
`http://localhost:3007/test?bundleName=${bundleFileName}`,
|
||||||
async () => {
|
async () => {
|
||||||
const convertToText = (obj: any): string => {
|
// lets enable real time comms
|
||||||
// create an array that will later be joined into a string.
|
const ws = new WebSocket('ws://localhost:8080');
|
||||||
const stringArray: string[] = [];
|
await new Promise((resolve) => (ws.onopen = resolve));
|
||||||
|
|
||||||
if (typeof obj === 'object' && typeof obj.toString === 'function') {
|
// Ensure this function is declared with 'async'
|
||||||
stringArray.push(obj.toString());
|
const logStore = [];
|
||||||
} else if (typeof obj === 'object' && obj.join === undefined) {
|
const originalLog = console.log;
|
||||||
stringArray.push('{');
|
const originalError = console.error;
|
||||||
for (const prop of Object.keys(obj)) {
|
|
||||||
stringArray.push(prop, ': ', convertToText(obj[prop]), ',');
|
|
||||||
}
|
|
||||||
stringArray.push('}');
|
|
||||||
|
|
||||||
// is array
|
// Override console methods to capture the logs
|
||||||
} else if (typeof obj === 'object' && !(obj.join === undefined)) {
|
|
||||||
stringArray.push('[');
|
|
||||||
for (const prop of Object.keys(obj)) {
|
|
||||||
stringArray.push(convertToText(obj[prop]), ',');
|
|
||||||
}
|
|
||||||
stringArray.push(']');
|
|
||||||
|
|
||||||
// is function
|
|
||||||
} else if (typeof obj === 'function') {
|
|
||||||
stringArray.push(obj.toString());
|
|
||||||
|
|
||||||
// all other values can be done with JSON.stringify
|
|
||||||
} else {
|
|
||||||
stringArray.push(JSON.stringify(obj));
|
|
||||||
}
|
|
||||||
|
|
||||||
return stringArray.join('');
|
|
||||||
};
|
|
||||||
|
|
||||||
let logStore = '';
|
|
||||||
// tslint:disable-next-line: max-classes-per-file
|
|
||||||
const log = console.log.bind(console);
|
|
||||||
console.log = (...args) => {
|
console.log = (...args) => {
|
||||||
args = args.map((argument) => {
|
logStore.push(args.join(' '));
|
||||||
return typeof argument !== 'string' ? convertToText(argument) : argument;
|
ws.send(args.join(' '));
|
||||||
});
|
originalLog(...args);
|
||||||
logStore += `${args}\n`;
|
|
||||||
log(...args);
|
|
||||||
};
|
};
|
||||||
const error = console.error;
|
|
||||||
console.error = (...args) => {
|
console.error = (...args) => {
|
||||||
args = args.map((argument) => {
|
logStore.push(args.join(' '));
|
||||||
return typeof argument !== 'string' ? convertToText(argument) : argument;
|
ws.send(args.join(' '));
|
||||||
});
|
originalError(...args);
|
||||||
logStore += `${args}\n`;
|
|
||||||
error(...args);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const bundleName = new URLSearchParams(window.location.search).get('bundleName');
|
const bundleName = new URLSearchParams(window.location.search).get('bundleName');
|
||||||
console.log(`::TSTEST IN CHROMIUM:: Relevant Script name is: ${bundleName}`);
|
originalLog(`::TSTEST IN CHROMIUM:: Relevant Script name is: ${bundleName}`);
|
||||||
const bundleResponse = await fetch(`/${bundleName}`);
|
|
||||||
console.log(
|
|
||||||
`::TSTEST IN CHROMIUM:: Got ${bundleName} with STATUS ${bundleResponse.status}`
|
|
||||||
);
|
|
||||||
const bundle = await bundleResponse.text();
|
|
||||||
console.log(`::TSTEST IN CHROMIUM:: Executing ${bundleName}`);
|
|
||||||
try {
|
try {
|
||||||
// tslint:disable-next-line: no-eval
|
// Dynamically import the test module
|
||||||
eval(bundle);
|
const testModule = await import(`/${bundleName}`);
|
||||||
|
if (testModule && testModule.runTest) {
|
||||||
|
// Execute the exported test function
|
||||||
|
await testModule.runTest();
|
||||||
|
} else {
|
||||||
|
originalError('Test module does not export runTest function.');
|
||||||
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
console.error(err);
|
originalError(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (
|
return logStore.join('\n');
|
||||||
(globalThis as any).tapbundleDeferred &&
|
|
||||||
(globalThis as any).tapbundleDeferred.promise
|
|
||||||
) {
|
|
||||||
await (globalThis as any).tapbundleDeferred.promise;
|
|
||||||
} else {
|
|
||||||
console.log('Error: Could not find tapbundle Deferred');
|
|
||||||
}
|
|
||||||
return logStore;
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
await this.smartbrowserInstance.stop();
|
await this.smartbrowserInstance.stop();
|
||||||
await server.stop();
|
await server.stop();
|
||||||
|
wss.close();
|
||||||
console.log(
|
console.log(
|
||||||
`${cs('=> ', 'blue')} Stopped ${cs(fileNameArg, 'orange')} chromium instance and server.`
|
`${cs('=> ', 'blue')} Stopped ${cs(fileNameArg, 'orange')} chromium instance and server.`
|
||||||
);
|
);
|
||||||
|
@ -4,7 +4,7 @@ import * as path from 'path';
|
|||||||
export { path };
|
export { path };
|
||||||
|
|
||||||
// @apiglobal scope
|
// @apiglobal scope
|
||||||
import * as typedserver from '@apiglobal/typedserver';
|
import * as typedserver from '@api.global/typedserver';
|
||||||
|
|
||||||
export {
|
export {
|
||||||
typedserver
|
typedserver
|
||||||
@ -32,7 +32,7 @@ export {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// @gitzone scope
|
// @gitzone scope
|
||||||
import * as tsbundle from '@gitzone/tsbundle';
|
import * as tsbundle from '@git.zone/tsbundle';
|
||||||
|
|
||||||
export { tsbundle };
|
export { tsbundle };
|
||||||
|
|
||||||
@ -40,3 +40,10 @@ export { tsbundle };
|
|||||||
import figures from 'figures';
|
import figures from 'figures';
|
||||||
|
|
||||||
export { figures };
|
export { figures };
|
||||||
|
|
||||||
|
// third party
|
||||||
|
import * as ws from 'ws';
|
||||||
|
|
||||||
|
export {
|
||||||
|
ws
|
||||||
|
}
|
||||||
|
@ -3,9 +3,12 @@
|
|||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true,
|
||||||
"useDefineForClassFields": false,
|
"useDefineForClassFields": false,
|
||||||
"target": "ES2022",
|
"target": "ES2022",
|
||||||
"module": "ES2022",
|
"module": "NodeNext",
|
||||||
"moduleResolution": "nodenext",
|
"moduleResolution": "NodeNext",
|
||||||
"esModuleInterop": true,
|
"esModuleInterop": true,
|
||||||
"verbatimModuleSyntax": true,
|
"verbatimModuleSyntax": true
|
||||||
}
|
},
|
||||||
|
"exclude": [
|
||||||
|
"dist_*/**/*.d.ts"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user