Skip to content

Commit

Permalink
feature: supertape: add ability to use console.log in worker mode
Browse files Browse the repository at this point in the history
  • Loading branch information
coderaiser committed Jun 4, 2024
1 parent 188ab81 commit dcb4dfb
Show file tree
Hide file tree
Showing 7 changed files with 302 additions and 2 deletions.
3 changes: 3 additions & 0 deletions packages/supertape/bin/communication.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,14 @@ import {EventEmitter} from 'node:events';
import {parentPort, workerData} from 'node:worker_threads';

const {assign} = Object;
const returns = (a) => () => a;

export const createCommunication = (argv) => {
if (parentPort)
return {
parentPort,
workerData,
isMaster: returns(false),
};

const {newWorker, newParentPort} = fakeWorkers();
Expand All @@ -16,6 +18,7 @@ export const createCommunication = (argv) => {
worker: newWorker,
parentPort: newParentPort,
workerData: argv,
isMaster: returns(true),
};
};

Expand Down
30 changes: 30 additions & 0 deletions packages/supertape/bin/subscribe.mjs
Original file line number Diff line number Diff line change
@@ -1,5 +1,13 @@
import keyPress from '@putout/cli-keypress';
import harnessCreator from '../lib/formatter/harness.js';
import {parse} from 'flatted';
import {
SPLITTER,
CONSOLE_LOG,
CONSOLE_ERROR,
} from '../lib/worker/create-console-log.js';

const one = (fn) => (a) => fn(a);

const {createHarness} = harnessCreator;
const resolveFormatter = async (name) => await import(`@supertape/formatter-${name}`);
Expand All @@ -15,6 +23,12 @@ export async function subscribe({name, exit, worker, stdout}) {
});

worker.on('message', ([type, a]) => {
if (type === CONSOLE_LOG)
return consoleLog(a);

if (type === CONSOLE_ERROR)
return consoleError(a);

harness.write({
type,
...a,
Expand All @@ -24,3 +38,19 @@ export async function subscribe({name, exit, worker, stdout}) {
worker.postMessage(['stop']);
});
}

function consoleLog({message}) {
const messages = message
.split(SPLITTER)
.map(one(parse));

console.log(...messages);
}

function consoleError({message}) {
const messages = message
.split(SPLITTER)
.map(one(parse));

console.error(...messages);
}
16 changes: 15 additions & 1 deletion packages/supertape/bin/supertape.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,16 @@ import {createIsStop} from './is-stop.mjs';
import {createFormatter} from './formatter.mjs';
import {parseArgs} from '../lib/cli/parse-args.js';
import cli from '../lib/cli.js';
import {
overrideConsoleError,
overrideConsoleLog,
} from '../lib/worker/create-console-log.js';

const {
worker,
parentPort,
workerData,
isMaster,
} = createCommunication(process.argv);

const args = parseArgs(process.argv.slice(2));
Expand All @@ -23,13 +28,22 @@ const {
const workerFormatter = createFormatter(parentPort);
const isStop = createIsStop(parentPort);

if (worker)
if (isMaster()) {
subscribe({
name: args.format,
exit,
worker,
stdout,
});
} else {
overrideConsoleLog(parentPort, {
console,
});

overrideConsoleError(parentPort, {
console,
});
}

export default await cli({
stdout,
Expand Down
1 change: 1 addition & 0 deletions packages/supertape/lib/formatter/harness.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
'use strict';

const {Transform: _Transform} = require('node:stream');

const {assign} = Object;

module.exports.createHarness = (reporter, {Transform = _Transform} = {}) => {
Expand Down
47 changes: 47 additions & 0 deletions packages/supertape/lib/worker/create-console-log.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
'use strict';

const {stringify} = require('flatted');
const SPLITTER = '>[supertape-splitter]<';
const CONSOLE_LOG = 'console:log';
const CONSOLE_ERROR = 'console:error';

module.exports.CONSOLE_ERROR = CONSOLE_ERROR;
module.exports.CONSOLE_LOG = CONSOLE_LOG;
module.exports.SPLITTER = SPLITTER;

module.exports.overrideConsoleLog = (parentPort, {console = global.console} = {}) => {
const {log} = console;

console.log = createConsoleMethod(CONSOLE_LOG, parentPort);
return {
getBackConsoleLog: () => {
console.log = log;
},
};
};

module.exports.overrideConsoleError = (parentPort, {console = global.console} = {}) => {
const {error} = console;

console.error = createConsoleMethod(CONSOLE_ERROR, parentPort);
return {
getBackConsoleError: () => {
console.error = error;
},
};
};

const createConsoleMethod = (type, parentPort) => (...messages) => {
const prepared = [];

for (const message of messages)
prepared.push(stringify(message));

parentPort.postMessage([
type, {
message: prepared.join(SPLITTER),
},
]);
};

module.exports._createConsoleLog = createConsoleMethod;
204 changes: 204 additions & 0 deletions packages/supertape/lib/worker/create-console-log.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,204 @@
'use strict';

const {test, stub} = require('supertape');
const {
overrideConsoleLog,
CONSOLE_LOG,
overrideConsoleError,
} = require('./create-console-log');

const {stringify} = require('flatted');

test('supertape: worker: create-console-log', (t) => {
const log = stub();
const consoleStub = {
log,
};

const parentPort = {
postMessage: stub(),
};

overrideConsoleLog(parentPort, {
console: consoleStub,
});

consoleStub.log('hello');

t.notCalled(log);
t.end();
});

test('supertape: worker: create-console-log: get back', (t) => {
const log = stub();
const consoleStub = {
log,
};

const parentPort = {
postMessage: stub(),
};

const {getBackConsoleLog} = overrideConsoleLog(parentPort, {
console: consoleStub,
});

consoleStub.log('hello');

getBackConsoleLog();

consoleStub.log('world');

t.calledWith(log, ['world']);
t.end();
});

test('supertape: worker: create-console-log: get back: consoleError', (t) => {
const error = stub();
const consoleStub = {
error,
};

const parentPort = {
postMessage: stub(),
};

const {getBackConsoleError} = overrideConsoleError(parentPort, {
console: consoleStub,
});

consoleStub.error('hello');

getBackConsoleError();

consoleStub.error('world');

t.calledWith(error, ['world']);
t.end();
});

test('supertape: worker: create-console-log: postMessage', (t) => {
const log = stub();
const consoleStub = {
log,
};

const postMessage = stub();

const parentPort = {
postMessage,
};

overrideConsoleLog(parentPort, {
console: consoleStub,
});

consoleStub.log('hello');

const arg = [
CONSOLE_LOG, {
message: '["hello"]',
},
];

t.calledWith(postMessage, [arg]);
t.end();
});

test('supertape: worker: create-console-log: postMessage: array', (t) => {
const log = stub();
const consoleStub = {
log,
};

const postMessage = stub();

const parentPort = {
postMessage,
};

const {getBackConsoleLog} = overrideConsoleLog(parentPort, {
console: consoleStub,
});

consoleStub.log([1, 2]);

getBackConsoleLog();

const arg = [
CONSOLE_LOG, {
message: '[[1,2]]',
},
];

t.calledWith(postMessage, [arg]);
t.end();
});

test('supertape: worker: create-console-log: postMessage: object', (t) => {
const log = stub();
const consoleStub = {
log,
};

const postMessage = stub();

const parentPort = {
postMessage,
};

overrideConsoleLog(parentPort, {
console: consoleStub,
});

const objectB = {};

const objectA = {
objectB,
};

objectA.objectB = {
objectA,
};

consoleStub.log(objectA);

const arg = [
CONSOLE_LOG, {
message: stringify(objectA),
},
];

t.calledWith(postMessage, [arg]);
t.end();
});

test('supertape: worker: create-console-log: postMessage: simple object', (t) => {
const log = stub();
const consoleStub = {
log,
};

const postMessage = stub();

const parentPort = {
postMessage,
};

overrideConsoleLog(parentPort, {
console: consoleStub,
});

consoleStub.log({
hello: 'world',
});

const arg = [
CONSOLE_LOG, {
message: '[{"hello":"1"},"world"]',
},
];

t.calledWith(postMessage, [arg]);
t.end();
});
3 changes: 2 additions & 1 deletion packages/supertape/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@
"@supertape/formatter-time": "^1.0.0",
"@supertape/operator-stub": "^3.0.0",
"cli-progress": "^3.8.2",
"flatted": "^3.3.1",
"fullstore": "^3.0.0",
"glob": "^10.3.10",
"jest-diff": "^29.0.1",
Expand Down Expand Up @@ -88,7 +89,7 @@
"pullout": "^5.0.1",
"putout": "^35.0.0",
"runsome": "^1.0.0",
"try-catch": "^3.0.0",
"try-catch": "^3.0.1",
"typescript": "^5.1.6"
},
"license": "MIT",
Expand Down

0 comments on commit dcb4dfb

Please sign in to comment.