2

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

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

应用程序.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();
    });
  });
});

一切正常,但我不想针对我的生产数据库进行测试。有谁知道使用虚拟/不同数据库进行测试的聪明方法?也许使用不同的环境?我有点卡住了!

4

1 回答 1

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)
于 2012-09-20T04:13:51.357 回答