使用虚拟数据库在自己的环境中测试express.js应用程序

时间:2012-09-19 19:21:13

标签: node.js express mongoose mocha

我的网络应用程序有以下结构

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();
    });
  });
});

一切正常,但我不想测试我的生产数据库。有没有人知道一个聪明的方法来使用虚拟/不同的数据库只是为了测试?也许使用不同的环境?我有点卡住了!

1 个答案:

答案 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)