开玩笑的嘲笑-测试运行完成后,开玩笑一秒钟没有退出

时间:2018-06-29 14:38:05

标签: javascript node.js mongoose jestjs mockgoose

我有一个猫鼬模型:

var mongoose = require("mongoose");

var transactionSchema = mongoose.Schema({
  category: { type: String, required: [true, "Category is required."] },
  amount: Number,
  comment: String,
  tags: Array,
  currency: String
});

var Transaction = mongoose.model("Transaction", transactionSchema);

module.exports = Transaction;

以及使用mockgoosejest的简单单元测试:

var { Mockgoose } = require("mockgoose");
var mongoose = require("mongoose");
var Transaction = require("./transaction");

var mockgoose = new Mockgoose(mongoose);

describe("transaction", function() {
  afterEach(function() {
    mockgoose.helper.reset().then(() => {
      done();
    });
  });

  it("category is required", function() {
    mockgoose.prepareStorage().then(() => {
      mongoose.connect("mongodb://foobar/baz");
      mongoose.connection.on("connected", () => {
        var mockTransaction = new Transaction({
          category: "Transportation",
          amount: 25,
          comment: "Gas money, Petrol.",
          tags: ["Gas", "Car", "Transport"],
          currency: "EUR"
        });
        mockTransaction.save(function(err, savedTransaction) {
          if (err) return console.error(err);
          expect(savedTransaction).toEqual(mockTransaction);
        });
      });
    });
  });
});

现在,当我运行测试时,会收到以下两个警告:

  

(节点:2199)UnhandledPromiseRejectionWarning:未处理的承诺   拒绝(拒绝ID:1):ReferenceError:未定义完成   (节点:2199)[DEP0018] DeprecationWarning:未处理的承诺拒绝   不推荐使用。将来,未处理的承诺拒绝   将使用非零退出代码终止Node.js进程。

然后单元测试通过,然后出现以下错误消息:

  

测试运行一秒钟后,Jest没有退出。

     

这通常意味着有些异步操作不是   在测试中停止了。考虑使用   --detectOpenHandles来解决此问题。

一旦获得正确的结果,如何终止测试?

2 个答案:

答案 0 :(得分:3)

该错误表示done的确切含义,但已被使用。如果使用了诺言,则不需要它。 Jest支持诺言,应从一个块中返回一个诺言以便正确处理:

afterEach(() => mockgoose.helper.reset());

如果this question中的打开句柄出现问题,可以用以下方法显式断开Mongoose的连接:

afterAll(() => mongoose.disconnect());

答案 1 :(得分:2)

初始测试存在一些问题。

第一个由@estus指出,使用jest测试时需要返回promises。 导致问题标题出错的第二个问题是由于测试后未正确关闭数据库连接引起的。

这是所有代码按预期运行的最终代码:

var { Mockgoose } = require("mockgoose");
var mongoose = require("mongoose");
var Transaction = require("./transaction");

var mockgoose = new Mockgoose(mongoose);

describe("transaction", function() {
  afterEach(function() {
    return mockgoose.helper.reset();
  });

  afterAll(function() {
    const { connections } = mongoose;
    const { childProcess } = mockgoose.mongodHelper.mongoBin;
    // kill mongod
    childProcess.kill();
    // close all connections
    for (const con of connections) {
      return con.close();
    }
    return mongoose.disconnect();
  });

  it("category is required", function() {
    expect.assertions(1);
    return mockgoose.prepareStorage().then(function() {
      mongoose.connect("mongodb://foobar/baz");
      return mongoose.connection.on("connected", function() {
        var mockTransaction = new Transaction({
          amount: 25,
          comment: "Gas money, Petrol.",
          tags: ["Gas", "Car", "Transport"],
          currency: "EUR"
        });
        return mockTransaction.save(function(err, savedTransaction) {
          console.log(err.errors.category.properties.message);
          expect(err.errors.category.properties.message).toBe(
            "Category is required."
          );
        });
      });
    });
  });
});