首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在next.js中使用supertest测试express服务器?

如何在next.js中使用supertest测试express服务器?
EN

Stack Overflow用户
提问于 2020-05-07 00:58:17
回答 1查看 517关注 0票数 2

我已经用next.js建立了我的投资组合网页,现在我需要测试它。为了测试express服务器,我使用了supertest。但问题是我需要重构express才能使用它。因为supertest在监听之前需要访问app()。

我开始了我以前在node.js应用中实现的方式。将快速代码放在app.js中,并在index.js中调用它。

代码语言:javascript
运行
复制
const express = require("express");
const server = express();
const authService = require("./services/auth");
const bodyParser = require("body-parser");
//put all the middlewares here

module.exports = server;

然后在index.js中

代码语言:javascript
运行
复制
const server = require("express")();
// const { parse } = require("url");
const next = require("next");
const routes = require("../routes");

const path = require("path");
require("./mongodb");

const dev = process.env.NODE_ENV !== "production";
const app = next({ dev });
// const handle = app.getRequestHandler(); //this is built in next route handler
const handle = routes.getRequestHandler(app);


app
  .prepare()
  .then(() => {
     const server = require("./app");
     //I required this outside too but it did not solve the issue


    server.listen(3000, (err) => {
      if (err) throw err;
      console.log("> Ready on http://localhost:3000");
    });
  })
  .catch((ex) => {
    console.error(ex.stack);
    process.exit(1);
  });

有了这个设置,express正在监听,我可以连接到mongodb,在启动过程中没有问题。

当我请求localhost:3000时,没有来自localhost的响应,它一直旋转到超时

EN

回答 1

Stack Overflow用户

发布于 2021-06-03 02:20:21

创建测试客户端:

代码语言:javascript
运行
复制
// test-client.ts

import { createServer, RequestListener } from "http";
import { NextApiHandler } from "next";
import { apiResolver } from "next/dist/next-server/server/api-utils";
import request from "supertest";

export const testClient = (handler: NextApiHandler) => {
  const listener: RequestListener = (req, res) => {
    return apiResolver(
      req,
      res,
      undefined,
      handler,
      {
        previewModeEncryptionKey: "",
        previewModeId: "",
        previewModeSigningKey: "",
      },
      false
    );
  };

  return request(createServer(listener));
};

使用以下工具测试您的API:

代码语言:javascript
运行
复制
// user.test.ts

import viewerApiHandler from "../api/user";
import { testClient } from "../utils/test-client";

const request = testClient(viewerApiHandler);

describe("/user", () => {
  it("should return current user", async () => {
    const res = await request.get("/user");
    expect(res.status).toBe(200);
    expect(res.body).toStrictEqual({ name: "Jane Doe" });
  });
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61640829

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档