top of page
Search

UNIT TESTING IN REACT WITH JEST: A COMPREHENSIVE GUIDE

Writer's picture: SigiloTechSigiloTech


Unit testing is an essential practice in software development that helps ensure the correctness and reliability of your code. In the world of React, Jest is a popular testing library that provides a feature-rich and easy-to-use framework for writing and running tests. In this article, we'll explore the basics of unit testing in React using Jest and walk through some code examples to help you get started.


Setting Up Jest

To begin, you'll need to have a React project set up. If you don't have one already, you can create a new project using Create React App:


npx create-react-app my-app

cd my-app

Next, install Jest and its dependencies:


npm install --save-dev jest @testing-library/react @testing-library/jest-dom


Writing Your First Test

Let's say you have a simple React component called Greeting that displays a greeting message:



To test this component, create a new file called Greeting.test.js in the src folder:




In this test, we're using the render function from @testing-library/react to render the Greeting component with the name prop set to "John". We then use the screen.getByText function to find the element containing the greeting message and expect it to be in the document.

Running Tests

To run your tests, add the following script to your package.json:



Now, you can run your tests with the following command:


npm test


Jest will automatically discover and run all test files with the .test.js or .spec.js extension.


Testing Component Interactions

Let's say you have a more complex component that involves user interactions, such as a button that toggles a message:




To test this component, you can use the fireEvent function from @testing-library/react to simulate user interactions:



In this test, we first check that the message is not initially displayed. We then simulate a button click using fireEvent.click and expect the message to be displayed. Finally, we simulate another button click and expect the message to be hidden again.


Conclusion

In this article, we've covered the basics of unit testing in React using Jest, including setting up Jest, writing and running tests, and testing component interactions. With Jest and React Testing Library, you can write robust tests for your React components, ensuring that your application works as expected and is easier to maintain.



Hope this tutorial was helpful.


For further queries or demos please comment below or contact us.




For any consultant/support work on O365/ development, contact us or visit our website www.sigilotech.com


32 views0 comments

Recent Posts

See All

Comments


bottom of page