5
benim kodudur i için aynı hatayı alırdım Res.status'u test yönteminden kaldırırsam, 'status'. Bu fonksiyonu test ederkenTypeError: Cannot call method 'json' of undefined
res.status(404).json(error);
i 'json' ne dereceye kadar belirler
yüzden bir istisna atılan olsun yok.
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 chainable yöntemleri için
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' ve. https://github.com/strongloop/express/blob/master/lib/response.js#L222 – Chris
Sanırım haklısınız - 'statü' yöntemi gerçekten zincirlenebilir olmak için gereken tek şey. Cevabımı güncelledim. –
Bu dönüş hakkında sinon dökümanından bahsetmiştim. durumu gibi bir şey yapabilmeliyiz: sinon.stub(). ReturnThis() –