fix(core): update

This commit is contained in:
Philipp Kunz 2023-11-09 19:00:53 +01:00
parent ac5e036967
commit 3c62129e02
5 changed files with 72 additions and 66 deletions

View File

@ -35,7 +35,9 @@
"@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.15", "@push.rocks/tapbundle": "^5.0.15",
"figures": "^6.0.1" "@types/ws": "^8.5.9",
"figures": "^6.0.1",
"ws": "^8.14.2"
}, },
"files": [ "files": [
"ts/**/*", "ts/**/*",

25
pnpm-lock.yaml generated
View File

@ -38,9 +38,15 @@ dependencies:
'@push.rocks/tapbundle': '@push.rocks/tapbundle':
specifier: ^5.0.15 specifier: ^5.0.15
version: 5.0.15(sinon@17.0.1) version: 5.0.15(sinon@17.0.1)
'@types/ws':
specifier: ^8.5.9
version: 8.5.9
figures: figures:
specifier: ^6.0.1 specifier: ^6.0.1
version: 6.0.1 version: 6.0.1
ws:
specifier: ^8.14.2
version: 8.14.2
devDependencies: devDependencies:
'@git.zone/tsbuild': '@git.zone/tsbuild':
@ -1678,6 +1684,12 @@ packages:
'@types/node': 20.9.0 '@types/node': 20.9.0
dev: false dev: false
/@types/ws@8.5.9:
resolution: {integrity: sha512-jbdrY0a8lxfdTp/+r7Z4CkycbOFN8WX+IOchLJr3juT/xzbJ8URyTVSJ/hvNdadTgM1mnedb47n+Y31GsFnQlg==}
dependencies:
'@types/node': 20.9.0
dev: false
/@types/yauzl@2.10.3: /@types/yauzl@2.10.3:
resolution: {integrity: sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==} resolution: {integrity: sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==}
requiresBuild: true requiresBuild: true
@ -5445,6 +5457,19 @@ packages:
optional: true optional: true
dev: false dev: false
/ws@8.14.2:
resolution: {integrity: sha512-wEBG1ftX4jcglPxgFCMJmZ2PLtSbJ2Peg6TmpJFTbe9GZYOQCDPdMYu/Tm0/bGZkw8paZnJY45J4K2PZrLYq8g==}
engines: {node: '>=10.0.0'}
peerDependencies:
bufferutil: ^4.0.1
utf-8-validate: '>=5.0.2'
peerDependenciesMeta:
bufferutil:
optional: true
utf-8-validate:
optional: true
dev: false
/ws@8.8.0: /ws@8.8.0:
resolution: {integrity: sha512-JDAgSYQ1ksuwqfChJusw1LSJ8BizJ2e/vVu5Lxjq3YvNJNlROv1ui4i+c/kUUrPheBvQl4c5UbERhTwKa6QBJQ==} resolution: {integrity: sha512-JDAgSYQ1ksuwqfChJusw1LSJ8BizJ2e/vVu5Lxjq3YvNJNlROv1ui4i+c/kUUrPheBvQl4c5UbERhTwKa6QBJQ==}
engines: {node: '>=10.0.0'} engines: {node: '>=10.0.0'}

View File

@ -3,6 +3,6 @@
*/ */
export const commitinfo = { export const commitinfo = {
name: '@git.zone/tstest', name: '@git.zone/tstest',
version: '1.0.82', 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'
} }

View File

@ -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.`
); );

View File

@ -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
}