我有一段代码:
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,我该怎么做呢?
发布于 2016-09-01 01:52:46
我认为你需要一个不同的设置:
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()返回的对象继承自EventEmitter,因此这就是存根将返回的内容。添加额外的close函数只是为了防止在调用它时出现错误。
您不能直接返回由getMsg返回的promise,因为这不会让您有机会发出SIGINT“信号”(实际上只是一个事件,但出于测试目的,它会工作得很好)。所以承诺已经被储存起来了。
测试应该失败,调用"fulfilled“处理程序,这必须显式完成,否则Mocha会认为测试通过了。
接下来,发送SIGINT (这将按预期触发拒绝处理程序),并返回promise。
https://stackoverflow.com/questions/39255593
复制相似问题