首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用@testing-library/react最简单地测试react-router的链接

使用@testing-library/react最简单地测试react-router的链接
EN

Stack Overflow用户
提问于 2020-05-18 20:45:08
回答 1查看 6.3K关注 0票数 6

我正在尝试理解如何使用@testing-library/react最好地测试react-router的行为是否符合预期。

我能想到的最简单的测试就是验证点击一个链接是否会改变URL。我知道,理想情况下,我应该测试点击一个链接会呈现一个新的组件,但这会给测试添加很多样板。

下面是我失败的例子:

代码语言:javascript
复制
import { MemoryRouter } from 'react-router-dom';
import { render } from '@testing-library/react';
import { createMemoryHistory } from 'history';

it('routes to a new route', async () => {
  const history = createMemoryHistory();
  const { getByText } = render(
    <MemoryRouter history={history}>
      <Link to="/hello">Click me</Link>
    </MemoryRouter>
  );

  fireEvent.click(getByText('Click me'));
  await waitFor(() => expect(history.location.pathname).to.equal('/hello')); // Fails
});
EN

回答 1

Stack Overflow用户

发布于 2020-05-18 22:29:39

我是这样做的:模拟history.push,然后监视它的调用。

代码语言:javascript
复制
import { MemoryRouter } from 'react-router-dom';
import { render } from '@testing-library/react';
import { createMemoryHistory } from 'history';

it('routes to a new route', async () => {
  const history = createMemoryHistory();

  // mock push function
  history.push = jest.fn();

  const { getByText } = render(
    <MemoryRouter history={history}>
      <Link to="/hello">Click me</Link>
    </MemoryRouter>
  );

  // could be userEvent.click
  // https://testing-library.com/docs/ecosystem-user-event/#clickelement-eventinit-options
  fireEvent.click(getByText('Click me'));

  // spy on push calls, assert on url (parameter)
  expect(history.push).toHaveBeenCalledWith('/hello');
});
票数 24
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61869886

复制
相关文章

相似问题

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