繁体   English   中英

忽略expect()函数的玩笑异步测试

[英]jest asynchronous test ignoring expect() function

server.js 是一个使用 jwt 令牌的简单 express.js 文件。 我目前想测试一个简单的路由,它只会返回字符串“Hello World”,如下所示

app.get("/", (req, res) => {
  res.send("Hello World");
});

下面的代码是我的玩笑文件,它使用 supertest 将请求与有效的 jwt 令牌一起发送

const supertest = require("supertest");

let server, request;
const serverStart = new Promise(resolve => {
  server = require("../server.js");
  request = supertest(server);
  server.on("app_started", () => {
    resolve();
  });
});

beforeAll(async () => {
  await serverStart;
});

afterAll(() => {
  server.close();
});

describe("When testing the server.js", () => {
  it("Should connect successfully and be able to return a response", async () => {
    const response = await request
      .get("/")
      .set("Authorization", `bearer ${process.env.AUTHTOKEN}`);

    expect(response.text).toBe("Hello World");
    console.log(response.text);
  });
});

当运行这个玩笑时(在它超时 5 秒之后)说Timeout - Async callback was not invoked within the 5000ms timeout specified但是,我在 expect 函数输出“Hello World”到控制台后添加的 console.log 意味着请求被制作并返回一个值,但它与代码一起运行,但只是跳过了expect函数

我也用done()then()尝试过这个,但两次都遇到了同样的错误,我在控制台记录了调用前后的时间,发现它只需要几毫秒就可以返回一个值,那么为什么期望似乎没有完成测试?

很确定您的问题是您正在收听的app_started事件。 我不知道该事件记录在哪里。 我认为你应该使用listening来代替。 我将对你的server.js文件做一些假设。

以下测试通过。 我认为您的测试从未真正开始,因为您正在侦听永远不会被触发的事件。

这是我正在测试的server.js文件:

const http = require("http");
const express = require("express");

const app = express();

app.get("/", (req, res) => {
    res.send("hello");
});

const server = http.createServer(app);

server.listen(8081);

module.exports = server;

这是我的测试文件server.test.js

const supertest = require("supertest");

let server, request;

const serverStart = new Promise(resolve => {
    server = require("./server.js");
    request = supertest(server);
    server.on("listening", () => resolve());
});

beforeAll(async () => {
    await serverStart;
});

afterAll(() => {
    server.close();
});

describe("server", () => {
    it("should get hello", async () => {
        const response = await request.get("/");
        expect(response.text).toBe("hello");
    });
});

用户 zero298 指出测试在beforeAll()函数期间失败,因为server.on()没有返回任何内容。 最后我在server.js 中写了 promise,它在它启动后解析,然后导出这个 promise。

let server;
const serverStart = new Promise(resolve => {
  server = app.listen(port, err => {
    if (err) {
      console.log(err);
    }
    console.log("Listening on port " + port);
    resolve();
  });
});

module.exports = app;
module.exports.close = () => server.close();
module.exports.serverStart = serverStart;

server.test.js 中beforeAll()现在看起来像

const server = require("../server.js");
let request;

beforeAll(async () => {
  await server.serverStart;
  request = supertest(server);
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM