test,async_hooks: match test-ttywrap.readstream
Match changes made to test-ttywrap.readstream for consistency. PR-URL: https://github.com/nodejs/node/pull/13991 Fixes: https://github.com/nodejs/node/issues/13984 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Refael Ackermann <refack@gmail.com>
This commit is contained in:
parent
250d50b380
commit
3b4010be31
@ -1,64 +1,47 @@
|
||||
'use strict';
|
||||
|
||||
const common = require('../common');
|
||||
|
||||
const tty_fd = common.getTTYfd();
|
||||
if (tty_fd < 0)
|
||||
common.skip('no valid TTY fd available');
|
||||
|
||||
const assert = require('assert');
|
||||
|
||||
// general hook test setup
|
||||
const tick = require('./tick');
|
||||
const initHooks = require('./init-hooks');
|
||||
const { checkInvocations } = require('./hook-checks');
|
||||
|
||||
const ttyStream = (() => {
|
||||
try {
|
||||
return new (require('tty').WriteStream)(tty_fd);
|
||||
} catch (e) {
|
||||
return null;
|
||||
}
|
||||
})();
|
||||
if (ttyStream === null)
|
||||
common.skip('no valid TTY fd available');
|
||||
|
||||
const hooks = initHooks();
|
||||
hooks.enable();
|
||||
|
||||
const as = hooks.activitiesOfTypes('TTYWRAP');
|
||||
assert.strictEqual(as.length, 1);
|
||||
const tty = as[0];
|
||||
if (!process.stdout.isTTY)
|
||||
return common.skip('no valid writable TTY available');
|
||||
|
||||
// test specific setup
|
||||
const checkInitOpts = { init: 1 };
|
||||
const checkEndedOpts = { init: 1, before: 1, after: 1, destroy: 1 };
|
||||
|
||||
// test code
|
||||
//
|
||||
// listen to stdin except on Windows
|
||||
const activities = hooks.activitiesOfTypes('TTYWRAP');
|
||||
assert.strictEqual(activities.length, 1);
|
||||
|
||||
const tty = activities[0];
|
||||
assert.strictEqual(tty.type, 'TTYWRAP');
|
||||
assert.strictEqual(typeof tty.uid, 'number');
|
||||
assert.strictEqual(typeof tty.triggerAsyncId, 'number');
|
||||
checkInvocations(tty, { init: 1 }, 'when tty created');
|
||||
checkInvocations(tty, checkInitOpts, 'when tty created');
|
||||
|
||||
ttyStream
|
||||
.on('finish', common.mustCall(onfinish))
|
||||
.end(common.mustCall(onend));
|
||||
|
||||
checkInvocations(tty, { init: 1 }, 'when tty.end() was invoked ');
|
||||
|
||||
function onend() {
|
||||
tick(2, common.mustCall(() =>
|
||||
checkInvocations(
|
||||
tty, { init: 1, before: 1, after: 1, destroy: 1 },
|
||||
'when tty ended ')
|
||||
const delayedOnCloseHandler = common.mustCall(() => {
|
||||
checkInvocations(tty, checkEndedOpts, 'when tty ended');
|
||||
});
|
||||
process.stdout.on('error', (err) => assert.fail(err));
|
||||
process.stdout.on('close', common.mustCall(() =>
|
||||
tick(2, delayedOnCloseHandler)
|
||||
));
|
||||
}
|
||||
process.stdout.destroy();
|
||||
checkInvocations(tty, checkInitOpts, 'when tty.end() was invoked');
|
||||
|
||||
function onfinish() {
|
||||
tick(2, common.mustCall(() =>
|
||||
checkInvocations(
|
||||
tty, { init: 1, before: 1, after: 1, destroy: 1 },
|
||||
'when tty ended ')
|
||||
));
|
||||
}
|
||||
|
||||
process.on('exit', onexit);
|
||||
|
||||
function onexit() {
|
||||
process.on('exit', () => {
|
||||
hooks.disable();
|
||||
hooks.sanityCheck('TTYWRAP');
|
||||
checkInvocations(tty, { init: 1, before: 1, after: 1, destroy: 1 },
|
||||
'when process exits');
|
||||
}
|
||||
checkInvocations(tty, checkEndedOpts, 'when process exits');
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user