- 
                Notifications
    You must be signed in to change notification settings 
- Fork 29
Test Framework ‐ Jest React Testing Framework
        Harsh Deep edited this page Feb 17, 2025 
        ·
        10 revisions
      
    The project follows the industry standards with Jest for component testing which is paired with React Testing Library (@testing-library/react) for nice UI selectors that work with React. The tests are run on the CI before merge, and it's a good idea to have new tests for any new functionality we add. We also use @testing-library/user-event for simulating realistic user events.
- 
NewEPubModal.test.jsis a good example to look at if you're starting with test cases. It has an example of mocking, varying props, selectors and checking for UI components. Originally introduced in PR #802.
- 
InstructorList.test.jscovers user-event based interactions based on keyboard typing and mouse clicks that refresh the screen
- https://jestjs.io/docs/using-matchers - jest basics
- https://blog.logrocket.com/testing-react-apps-jest-react-testing-library/ - intro tutorial on jest + react testing library
- https://robertmarshall.dev/blog/react-component-props-passed-to-child-jest-unit-test/ - how to mock child components (only if needed, but sometimes it can get quite complicated to test child components)
- https://testing-library.com/docs/queries/about/ - different types of queries within react testing library
- https://redux.js.org/usage/writing-tests - redux docs on testing
- https://testing-library.com/docs/dom-testing-library/api-accessibility - tests for accessibility features
- https://testing-library.com/docs/user-event/intro - simulating realistic user interactions instead of just firing DOM interactions
- https://jestjs.io/docs/asynchronous - async tests
- https://stackoverflow.com/a/62765143 - where to keep test files
- https://kentcdodds.com/blog/testing-implementation-details - Testing overall behavior and content over testing integration details (helped a lot by React Testing Library)
- https://kentcdodds.com/blog/common-mistakes-with-react-testing-library#using-get-variants-as-assertions - tips from the library creator