gpt4 book ai didi

react-native - 使用 react-navigation 中的 useRoute 进行 Jest 单元测试

转载 作者:行者123 更新时间:2023-12-04 08:43:01 28 4
gpt4 key购买 nike

我们最近将我们的 React Native 代码库升级到 React Navigation 的第 5 版,并且在此过程中我们将几个组件从类组件重构为功能组件。这意味着我们正在使用像 useNavigation() 和 useRoute() 这样的钩子(Hook)。
我很难弄清楚如何解决我在进行单元测试时面临的问题。看起来导航和路线 Prop 的状态在运行时对测试不可用。例如,我从 Jest 收到以下错误:

● <EULA /> › Rendering › should match to snapshot

TypeError: Cannot read property 'name' of undefined

27 | const route = useRoute();
28 | const authContext = useContext(AuthContext);
> 29 | const isAcceptPP: boolean = route.name === "AcceptEULA";
| ^
这个错误让我相信当第 27 行在单元测试的上下文中运行时,它实际上并没有从 useRoute() 返回一个路由对象。这个错误出现在我对该文件的所有测试中。
这就是当前测试的样子,我尝试模拟 useRoute 并只是将 route 作为 props 的一部分,但这些似乎并没有做任何事情:
import React from "react";
import { render, fireEvent, waitFor } from "@testing-library/react-native";
import { WebView } from "react-native-webview";
import { Alert } from "react-native";

import EULA from "../src/screens/EULA";
import { alertSpy } from "../src/jest/spies";

describe("<EULA />", () => {
let props;
let useRoute: jest.Mock;
beforeEach(() => {
useRoute = jest.fn();
props = { navigation: { state: { routeName: "AcceptEULA" }, navigate: navigate }, route: { name: "AcceptEULA" } };
});

describe("Rendering", () => {
it("should match to snapshot when accept EULA", async () => {
const { toJSON, getByType } = render(<EULA {...props} />);
await waitFor(() => getByType(WebView));
expect(toJSON()).toMatchSnapshot();
});
我对 Jest 还是有点陌生​​,我不确定我应该怎么做,因为路线不再是导航 Prop 的一部分,但我可能只是想多了。

最佳答案

我认为问题在于您将模拟路线传递为 prop ,而您的测试尝试使用 hook 捕获路线.
我认为这可以帮助你:

import { useRoute } from "@react-navigation/core";
jest.mock("@react-navigation/core");
import EULA from "../src/screens/EULA";

describe("Rendering", () => {
it("should match to snapshot when accept EULA", async () => {
useRoute.mockReturnValue({
name: "AcceptEULA"
});
const { toJSON, getByType } = render(<EULA />);
...
});
});

关于react-native - 使用 react-navigation 中的 useRoute 进行 Jest 单元测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64470657/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com