我的网络应用程序有以下结构
db.js:
mongoose = require('mongoose');
db = mongoose.createConnection("...");
playerSchema = new mongoose.Schema({
// my schema stuff
});
exports.Player = db.model("player", playerSchema);
我将所有路由都放在一个自己的文件中(route / index.js):
db = require('../db');
exports.createPlayer = function(req, res) {
player = new db.Player();
player.name = req.body.player_name;
player.save(function(err) {
if (err) {
log(err);
}
res.redirect("/");
});
};
app.js
routes = require('./routes');
app.post("/start", routes.createPlayer);
我使用mocha测试应用程序,应该和supertest一样,如下例
should = require('should');
supertest = require('supertest');
app = require('../app');
describe("POST /start", function() {
it("should redirect", function(done) {
supertest(app)
.post("/start")
.send({
player_name: "John Wayne"
}).end(function(err, res) {
should.not.exist(err);
done();
});
});
});
一切正常,但我不想测试我的生产数据库。有没有人知道一个聪明的方法来使用虚拟/不同的数据库只是为了测试?也许使用不同的环境?我有点卡住了!
答案 0 :(得分:3)
我有一个common.js文件,它是我在测试文件中包含的第一个文件。最重要的是:
process.env.NODE_ENV = 'test'
process.env.MONGOHQ_URL = 'mongodb://localhost/project-testing'
当我进行数据库连接时,我会这样:
var dbUri = process.env.MONGOHQ_URL || 'mongodb://localhost/project'
var db = mongoose.connect(dbUri)