为什么我的 supertest 调用不链?
Why won't my supertest calls chain?
它永远不会触发内部调用,所以 done()
没有被调用,我的 Mocha 测试超时了。这是为什么?
testUsers.forEach(function(loggedInUser) {
var describeStr;
if (loggedInUser && loggedInUser.username === 'a') {
describeStr = 'Tangos API (role: user)';
}
else if (loggedInUser && loggedInUser.username === 'admin') {
describeStr = 'Tangos API (role: admin)';
}
else {
describeStr = 'Tangos API (not logged in)';
}
describe(describeStr, function() {
var id;
beforeEach(function(done) {
if (!loggedInUser) {
return done();
}
agent
.post('/users')
.send(loggedInUser)
.end(function(err, res) {
console.log('err: ', err); // null
console.log('res.text: ', res.text); // correct
agent
.post('/tangos')
.send(testTango)
.end(function(err, result) {
console.log('inner'); // never hits here
if (err) {
return done(err);
}
return done(); // never hits here, so mocha tests time out
})
;
})
;
});
使用异步也不起作用:
async.series([
function() {
agent
.post('/users')
.send(loggedInUser)
.end(function(err, res) {
console.log('err: ', err); // null
console.log('res.text: ', res.text); // correct
})
;
}, function() {
agent
.post('/tangos')
.send(testTango)
.end(function(err, result) {
console.log('inner'); // never hits here
})
;
}
], done);
我在这里看到 2 个可能的问题。首先,您的异步系列缺少每个函数所需的回调。
async.series([
function(callback) {
agent
.post('/users')
.send(loggedInUser)
.end(function(err, res) {
console.log('err: ', err); // null
console.log('res.text: ', res.text); // correct
callback(); // Need to call the callback here.
})
;
}, function(callback) {
agent
.post('/tangos')
.send(testTango)
.end(function(err, result) {
console.log('inner'); // never hits here
callback(); // Need to call callback here too.
})
;
}
], done);
我运行这个用我自己的端点进行的精确测试它工作正常。
第一个代码片段看起来不错,对我来说工作得很好。我敢说你在它有机会完成之前就超时了。默认情况下,超时时间为 2000 毫秒。 2 API 调用没有在 2 秒内完成是有道理的。要增加超时,只需输入
this.timeout(5000);
在描述块中增加超时值。
它永远不会触发内部调用,所以 done()
没有被调用,我的 Mocha 测试超时了。这是为什么?
testUsers.forEach(function(loggedInUser) {
var describeStr;
if (loggedInUser && loggedInUser.username === 'a') {
describeStr = 'Tangos API (role: user)';
}
else if (loggedInUser && loggedInUser.username === 'admin') {
describeStr = 'Tangos API (role: admin)';
}
else {
describeStr = 'Tangos API (not logged in)';
}
describe(describeStr, function() {
var id;
beforeEach(function(done) {
if (!loggedInUser) {
return done();
}
agent
.post('/users')
.send(loggedInUser)
.end(function(err, res) {
console.log('err: ', err); // null
console.log('res.text: ', res.text); // correct
agent
.post('/tangos')
.send(testTango)
.end(function(err, result) {
console.log('inner'); // never hits here
if (err) {
return done(err);
}
return done(); // never hits here, so mocha tests time out
})
;
})
;
});
使用异步也不起作用:
async.series([
function() {
agent
.post('/users')
.send(loggedInUser)
.end(function(err, res) {
console.log('err: ', err); // null
console.log('res.text: ', res.text); // correct
})
;
}, function() {
agent
.post('/tangos')
.send(testTango)
.end(function(err, result) {
console.log('inner'); // never hits here
})
;
}
], done);
我在这里看到 2 个可能的问题。首先,您的异步系列缺少每个函数所需的回调。
async.series([
function(callback) {
agent
.post('/users')
.send(loggedInUser)
.end(function(err, res) {
console.log('err: ', err); // null
console.log('res.text: ', res.text); // correct
callback(); // Need to call the callback here.
})
;
}, function(callback) {
agent
.post('/tangos')
.send(testTango)
.end(function(err, result) {
console.log('inner'); // never hits here
callback(); // Need to call callback here too.
})
;
}
], done);
我运行这个用我自己的端点进行的精确测试它工作正常。
第一个代码片段看起来不错,对我来说工作得很好。我敢说你在它有机会完成之前就超时了。默认情况下,超时时间为 2000 毫秒。 2 API 调用没有在 2 秒内完成是有道理的。要增加超时,只需输入
this.timeout(5000);
在描述块中增加超时值。