reactjs - React 测试库 : Do I need a new test with new selectors for each test key?

标签 reactjs tdd jestjs react-testing-library react-test-renderer

我正在使用 React 测试库构建一个带有 TDD 的 React 应用程序。

TLDR:选择器(例如toBeInTheDocument())似乎只在渲染之后工作一次。是这样吗?

我使用 CRA 制作了应用程序,这是我的 src/setupTests.js:

// react-testing-library renders your components to document.body,
// this will ensure they're removed after each test.
import "react-testing-library/cleanup-after-each";
// this adds jest-dom's custom assertions
import "jest-dom/extend-expect";

这是我编写的测试:

import { pluck } from "ramda";
import React from "react";
import { render } from "react-testing-library";
import ContactList from "../components/ContactList";
import { contacts } from "../fixtures";

describe("Contact List", () => {
  describe("given no contacts", () => {
    const { getByText } = render(<ContactList />);

    it("displays 'First Name' in the header", () => {
      const actual = getByText(/first name/i);
      expect(actual).toBeInTheDocument();
    });

    it("displays 'Last Name' in the header", () => {
      const actual = getByText(/last name/i);
      expect(actual).toBeInTheDocument();
    });

    it("displays 'No Contacts'", () => {
      const actual = getByText(/no contacts/i);
      expect(actual).toBeInTheDocument();
    });
  });

  describe("given a list of contacts", () => {
    const props = { contacts };

    const { getAllByTestId } = render(<ContactList {...props} />);

    it("displays the first name of all contacts", () => {
      const actual = pluck("textContent")(getAllByTestId("contact-first-name"));
      const expected = pluck("firstName")(contacts);
      expect(actual).toEqual(expected);
    });

    it("displays the last name of all contacts", () => {
      const actual = pluck("textContent")(getAllByTestId("contact-last-name"));
      const expected = pluck("lastName")(contacts);
      expect(actual).toEqual(expected);
    });
  });
});

这是我编写的组件:

import React from "react";
import PropTypes from "prop-types";
import Table from "@material-ui/core/Table";
import TableBody from "@material-ui/core/TableBody";
import TableCell from "@material-ui/core/TableCell";
import TableHead from "@material-ui/core/TableHead";
import TableRow from "@material-ui/core/TableRow";
import withStyles from "@material-ui/core/styles/withStyles";
import strings from "../strings";

function ContactList({ contacts }) {
  const renderContact = ({ firstName = "N/A", lastName = "N/A", id }) => (
    <TableRow key={id}>
      <TableCell data-testid="contact-first-name">{firstName}</TableCell>
      <TableCell data-testid="contact-last-name">{lastName}</TableCell>
    </TableRow>
  );
  return (
    <Table>
      <TableHead>
        <TableRow>
          <TableCell>{strings.firstName}</TableCell>
          <TableCell>{strings.lastName}</TableCell>
        </TableRow>
      </TableHead>
      <TableBody>
        {contacts.length > 0 ? (
          contacts.map(renderContact)
        ) : (
          <TableRow>
            <TableCell>{strings.noContacts}</TableCell>
          </TableRow>
        )}
      </TableBody>
    </Table>
  );
}

ContactList.propTypes = {
  classes: PropTypes.object.isRequired,
  contacts: PropTypes.arrayOf(
    PropTypes.shape({
      firstName: PropTypes.string.isRequired,
      lastName: PropTypes.string.isRequired
    })
  ).isRequired
};

ContactList.defaultProps = {
  contacts: []
};

const styles = {};

export default withStyles(styles)(ContactList);

现在,如果我运行这些测试,则只有每个 describe block 各自的前两次通过。

例如,如果我给任何一个 it 测试 .only 它会通过。

这是怎么回事?我是否无法对多个断言重复使用相同的测试设置?我是否必须为每个调用render

最佳答案

您正在导入react-testing-library/cleanup-after-each,它会在每次测试后删除渲染的组件。这是正确的方法,但是您应该在每个 it block 中渲染该组件。

关于reactjs - React 测试库 : Do I need a new test with new selectors for each test key?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54621331/

相关文章:

javascript - 使用 jest 模拟 moment() 和 moment().format

javascript - 在 Jest 的函数内部模拟函数调用

reactjs - 如何在React Router中使用 map 功能?

mongodb - 如何在meteor中建立单独的测试和开发数据库

ruby-on-rails - 无法运行 Minitest - 在 MiniTest::Unit::TestCase 中获取未定义的类变量

unit-testing - TDD 中的重构细节

javascript - 使用换行符解析 json 并显示为 HTML

reactjs - Material UI 日期选择器在左上角打开

javascript - React.js 搜索栏始终获取相同的内容

reactjs - 如何在enzyme中调用多个setProps?