如何在我的 node.js 应用程序中模拟数据库,在这种情况下,它使用 mongodb
作为博客 REST API 的后端?
当然,我可以将数据库设置为特定的 testing
-database,但我仍然会保存数据而不是只测试我的代码,还要测试数据库,所以我实际上并没有进行单元测试但是集成测试。
那么一个人应该怎么做呢?创建数据库包装器作为应用程序和数据库之间的中间层并在测试时替换 DAL?
// app.js
var express = require('express');
app = express(),
mongo = require('mongoskin'),
db = mongo.db('localhost:27017/test?auto_reconnect');
app.get('/posts/:slug', function(req, res){
db.collection('posts').findOne({slug: req.params.slug}, function (err, post) {
res.send(JSON.stringify(post), 200);
});
});
app.listen(3000);
// test.js
r = require('requestah')(3000);
describe("Does some testing", function() {
it("Fetches a blogpost by slug", function(done) {
r.get("/posts/aslug", function(res) {
expect(res.statusCode).to.equal(200);
expect(JSON.parse(res.body)["title"]).to.not.equal(null);
return done();
});
});
));
最佳答案
如果不使用数据库软件进行测试,我认为无法正确测试与数据库相关的代码。那是因为您要测试的代码不仅是 javascript,而且是数据库查询字符串。即使在您的情况下,查询看起来很简单,您也不能永远依赖它。
所以任何数据库模拟层都必须实现整个数据库(也许减去磁盘存储)。到那时,您最终会使用数据库模拟器进行集成测试,即使您将其称为单元测试。另一个缺点是,与数据库相比,数据库模拟器最终可能会出现一组不同的错误,并且您最终可能不得不为数据库模拟器和数据库编写代码(有点像 IE、Firefox 和 Chrome 等的情况。 )。
因此,在我看来,正确测试代码的唯一方法是将其与真实数据库进行交互。
https://stackoverflow.com/questions/12526160/