如何使用 Jest 在 nextjs 中测试 api 路由

时间:2021-04-08 09:17:26

标签: jestjs next.js react-testing-library

我的 api 文件夹中有一个函数可以搜索服务数组并根据 slug 返回单个服务。

api函数为:

import {services} from '../../../public/data/service.js'

export default async function getSingleService (req, res) {
    const serviceId = req.query.serviceID
    const result = services.filter((each) => each.url === serviceId )
    if(result.length > 0) {
        return res.status(200).json(result[0])
    } else {
        res.status(404).json({message: 'Service not found'})
    }
}

我如何开始为此功能编写测试。我刚开始开玩笑,任何帮助都会很好。

1 个答案:

答案 0 :(得分:0)

不确定您是否仍在寻找答案,但这似乎对我有用。它适用于默认的“hello”路由。我找到了here

import { createMocks } from 'node-mocks-http';
import handler from '../../../pages/api/hello';

describe('/api/hello', () => {
    test('should returna an object with a name', async () => {
        const { req, res } = createMocks({
            method: 'GET'
        });

        await handler(req, res);
        expect(res._getStatusCode()).toBe(
            200
        );
        expect(
            JSON.parse(res._getData())
        ).toHaveProperty('name');
    });
});