Nodejs mocha单元测试sqlite3回调未调用insert未执行

时间:2017-03-21 10:50:49

标签: node.js unit-testing sqlite mocha chai

我想为我的应用创建单元测试。 API通过浏览器调用时工作正常,但是当我想执行测试时,无论是使用npm测试还是mocha测试,都不会调用回调函数,也不会执行INSERT语句。我没有错。代码:

单元测试文件:

process.env.NODE_ENV = 'test';
var chai = require('chai');
var chaiHttp = require('chai-http');
var server = require('../server/server');
var Const = require("../config/const.js");
var should = chai.should();
chai.use(chaiHttp);
var assert = chai.assert;

var column1value = "1234567890123456"

describe('All', function() {
  it('Insert',function(done) {
      chai.request(server)
        .post('/' +Const.SERVER_NAME + '/insert')
        .set('content-type', 'application/x-www-form-urlencoded')
        .send({param1: column1value, param2: 'true'})
        .end(function(err, res){
            console.log(new Date().getTime() + "!1");

            res.should.have.status(200);

            done();
        });
  });
});

数据库管理器插入方法:

method.insert = function(param1, param2) {
openDb();

console.log("blabla1");
console.log("param1:" + param1 + ";param2:" + param2);

db.run("INSERT INTO mytable (column1, column2) values (?,?)",param1,param2, function(err) {

    console.log("blabla2" + this);

    if (err) {
        console.log(err);
    } else {
        console.log("Successfuly updated: " + param1);
    }
});

db.close();

console.log("blabla3");
};

当我运行“npm test”或“mocha test”时,我在控制台输出中获得了什么:

blabla1
参数1:1234567890123456;参数2:真实
blabla3
时间戳!1

如果我启动nodejs服务器并使用,比方说postman,调用调用insert的API,将数据插入数据库并显示blabla2日志。 我缺少什么?

更新
问题与Alexandru Olaru编写的内容有关,但更具体地说,我在index.js中做了什么(我的路线在哪里)

function insertOrUpdateData(req, res) {
    databaseManager.insert(req.body.param1, req.body.param2);
    res.end();
    return;
};

但我需要这样做:

function insertOrUpdateData(req, res) {
    databaseManager.insert(req.body.param1, req.body.param2, function (err) {
        logger.log("*-*-router insert callback");
        res.end();
        return;
    });
}

相关的原因问题仅在单元测试中可重现,我现在理解的是因为异步任务毕竟在节点中执行,但在单元测试中则不然。为什么它不在单元测试中,我还不太确定(可能与单元测试生命周期或与节点实例的交互有关)。

1 个答案:

答案 0 :(得分:1)

重构您的代码以使用回调或承诺:

method.insert = function (param1, param2) {
  return new Promise((resolve, reject) => {
    openDb();
    db.run('INSERT INTO mytable (column1, column2) values (?,?)', param1, param2, (err) => {
      db.close();
      if (err) {
        reject(err);
      } else {
        resolve();
      }
    });
  });
};

handler.insert(param1, param2)
  .then(() => { // the stuff after })
  .catch((err) => { // handler error });

问题在于您没有为异步部件设置回调。