如何模拟 readline.on('SIGINT')?
How to mock readline.on('SIGINT')?
我有这段代码:
function getMsg() {
return new Promise(function (resolve, reject) {
var input = [];
var rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
rl.on('line', function (cmd) {
if (cmd.trim()) {
input.push(cmd);
} else {
rl.close();
}
});
rl.on('close', function () {
rl.close();
resolve(input.join('\n'));
});
rl.on('SIGINT', reject);
});
}
我正在尝试测试这个功能,到目前为止,我的尝试是这样的:
it('should reject if SIGINT is sent', function () {
sandbox.stub(readline, 'createInterface', function () {
return {
on: function (action, callback) {
callback();
},
prompt: function () {},
close: function () {}
};
});
return getMsg().then(null).catch(function () {
expect(true).to.be.equal(true);
});
});
当然,这并不能模拟 SIGINT
,我该怎么做?
我认为您需要不同的设置:
const EventEmitter = require('events').EventEmitter
...
it('should reject if SIGINT is sent', function () {
let emitter = new EventEmitter();
sandbox.stub(readline, 'createInterface', function () {
emitter.close = () => {};
return emitter;
});
let promise = getMsg().then(function() {
throw Error('should not have resolved');
}, function (err) {
expect(true).to.be.equal(true);
});
emitter.emit('SIGINT');
return promise;
});
由 readline.createInterface()
编辑的对象 return 继承自 EventEmitter
,因此这就是存根 return 的内容。额外的 close
函数只是添加到它以防止调用时出错。
你不能 return return 直接由 getMsg
编辑的承诺,因为那不会给你机会发出 SIGINT
"signal"(真的只是一个事件,但出于测试目的,它会工作得很好)。所以 promise 被存储了。
测试应该失败并调用 "fulfilled" 处理程序,这必须明确完成,否则 Mocha 认为测试通过。
接下来,发送 SIGINT
(这应该会按预期触发拒绝处理程序),并且承诺 returned。
我有这段代码:
function getMsg() {
return new Promise(function (resolve, reject) {
var input = [];
var rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
rl.on('line', function (cmd) {
if (cmd.trim()) {
input.push(cmd);
} else {
rl.close();
}
});
rl.on('close', function () {
rl.close();
resolve(input.join('\n'));
});
rl.on('SIGINT', reject);
});
}
我正在尝试测试这个功能,到目前为止,我的尝试是这样的:
it('should reject if SIGINT is sent', function () {
sandbox.stub(readline, 'createInterface', function () {
return {
on: function (action, callback) {
callback();
},
prompt: function () {},
close: function () {}
};
});
return getMsg().then(null).catch(function () {
expect(true).to.be.equal(true);
});
});
当然,这并不能模拟 SIGINT
,我该怎么做?
我认为您需要不同的设置:
const EventEmitter = require('events').EventEmitter
...
it('should reject if SIGINT is sent', function () {
let emitter = new EventEmitter();
sandbox.stub(readline, 'createInterface', function () {
emitter.close = () => {};
return emitter;
});
let promise = getMsg().then(function() {
throw Error('should not have resolved');
}, function (err) {
expect(true).to.be.equal(true);
});
emitter.emit('SIGINT');
return promise;
});
由 readline.createInterface()
编辑的对象 return 继承自 EventEmitter
,因此这就是存根 return 的内容。额外的 close
函数只是添加到它以防止调用时出错。
你不能 return return 直接由 getMsg
编辑的承诺,因为那不会给你机会发出 SIGINT
"signal"(真的只是一个事件,但出于测试目的,它会工作得很好)。所以 promise 被存储了。
测试应该失败并调用 "fulfilled" 处理程序,这必须明确完成,否则 Mocha 认为测试通过。
接下来,发送 SIGINT
(这应该会按预期触发拒绝处理程序),并且承诺 returned。