otrzymuję następujący błąd podczas próby przetestować metodę:Węzeł ekspresowe testowania mock res.status (status) .json (obj)
TypeError: Cannot call method 'json' of undefined
poniżej jest mój kod, to bym się na ten sam błąd "status", jeśli usunę res.status z metody testowej.
Jak mogę zdefiniować „json” tak ja nie otrzymuję wyjątek rzucony na:
res.status(404).json(error);
podczas testowania tej funkcji.
stores.js
{ //the get function declared above (removed to ease of reading)
// using a queryBuilder
var query = Stores.find();
query.sort('storeName');
query.exec(function (err, results) {
if (err)
res.send(err);
if (_.isEmpty(results)) {
var error = {
message: "No Results",
errorKey: "XXX"
}
res.status(404).json(error);
return;
}
return res.json(results);
});
}
storesTest.js
it('should on get call of stores, return a error', function() {
var mockFind = {
sort: function(sortOrder) {
return this;
},
exec: function (callback) {
callback('Error');
}
};
Stores.get.should.be.a["function"];
// Set up variables
var req,res;
req = {query: function(){}};
res = {
send: function(){},
json: function(err){
console.log("\n : " + err);
},
status: function(responseStatus) {
assert.equal(responseStatus, 404);
}
};
StoresModel.find = sinon.stub().returns(mockFind);
Stores.get(req,res);
'send' i' json' nie są przenośne, więc może to prowadzić do fałszywych pozytywnych testów, jeśli je zdefiniujesz. https://github.com/strongloop/express/blob/master/lib/response.js#L222 – Chris
Zgaduję, że masz rację - metoda "status" to jedyna rzecz, która naprawdę musi być przenośna. Zaktualizowałem swoją odpowiedź. –
Zauważyłem, że dokumentacja sinonowa wspomina o tym, że to powróciło. Powinniśmy być w stanie zrobić coś w rodzaju: status: sinon.stub(). ReturnThis() –