首页 > 解决方案 > Jestjs - 在 beforeEach 块中创建的数据库连接在测试块中变得未定义

问题描述

我已经设置了我的项目,以便一旦建立数据库连接就会发出一个事件。该应用程序在此之后启动。

单元测试时,我设置了一个局部变量,在内部创建数据库连接beforeEach并将连接保存到局部变量。

在这个beforeEach块中,我可以看到数据库已连接。但是,如果我在test块内检查,则局部变量返回undefined. 什么是正确的方法?

- db.config.ts -
export async function connectToDatabase(mediator: EventEmitter) {
  const connectionOptions = await getConnectionOptions();

  const dbConnection = await createConnection(connectionOptions);

  mediator.emit('db.ready', dbConnection);
}

- index.ts -
const mediator = new EventEmitter();

connectToDatabase(mediator);

mediator.on('db.ready', (db: Connection) => {
  app.listen(3000);
  console.log('app started');
});

测试

describe('Jest Tests', () => {
    const mediator = new EventEmitter();
    let dbConnection: Connection;

    beforeEach(async () => {
        connectToDatabase(mediator);

        mediator.on('db.ready', (db: Connection) => {
           dbConnection = db;
           console.log(dbConnection.isConnected); // **returns TRUE**
        }
    }

    test('Testing db connection', () => {
        console.log(dbConnection.isConnected); // **dbConnection undefined**
    }
}

我还尝试将局部变量放在describe块之外。

标签: node.jstypescriptjestjstypeorm

解决方案


beforeEach钩子回调立即返回,虽然它是async. 您需要从中显式返回一个 Promise,并仅在db.ready事件发出时履行它(或在某个超时时拒绝它)。

在伪代码中,它应该如下所示:

beforeEach(async () => {
    return new Promise(async (fulfill, reject) => {
        await connectToDatabase(mediator);
        mediator.on('db.ready', db => {
            dbConnection = db;
            fulfill();
        })
        // reject on timeout
    })
})

推荐阅读