Jest Mockgoose - Jest 在测试运行完成后一秒钟没有退出



我有一个猫鼬模型:

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( 未处理的承诺拒绝警告:未处理的承诺 拒绝(拒绝 ID:1(:引用错误:未定义完成 (节点:2199([DEP0018]弃用警告:未处理的承诺拒绝 已弃用。将来,承诺拒绝未处理的 将使用非零退出代码终止 Node.js 进程。

然后单元测试通过,然后我收到以下错误消息:

Jest 在测试运行完成后一秒钟没有退出。

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

获得正确结果后如何终止测试?

错误的意思正是它所说的,done没有定义,但它被使用了。而且在使用承诺的情况下不需要它。Jest 支持承诺,应该从块中返回一个承诺才能正确处理:

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

如果像这个问题中那样打开句柄有问题,猫鼬可以显式断开:

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

最初的测试有一些问题。

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

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

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

相关内容

最新更新