Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Hands-on project for testing React components, hooks, and user flows with React Testing Library and Vitest

Notifications You must be signed in to change notification settings

NightDreams/react-testing-library-course

Repository files navigation

πŸ§ͺ React Testing Library – Advanced Testing Project - Platzi

πŸ‘€ Author Jair Neri – Frontend Developer

Learn advanced skills and tool for testing with vite and rtl in a react app. Project built while completing the React Testing Library Course (Platzi, Nov 2024).

Learning Objectives

Understand the fundamentals of testing in React and its importance in preventing critical production errors.

Write unit, integration, and end-to-end tests using Vitest + React Testing Library.

Implement TDD (Table Driven testing) in the development cycle.

Implement TDD (Test Driven Development) in the development cycle.

Test custom hooks applying SOLID principles and spies.

Simulate APIs and handle errors with Mock Service Worker.

Measure and analyze code coverage in React projects.

πŸ› οΈ Tech Stack & Tools

  • βš›οΈ React
  • πŸ§ͺ React Testing Library (RTL)
  • 🧩 Vitest
  • πŸ›‘οΈ TDT / Table Driven Testing
  • πŸ›‘οΈ TDD / Table Driven Development
  • 🌐 Mock Service Worker (MSW)
  • πŸ“Š Code Coverage Reports

πŸš€ Tests Covered in this Project

  • βœ… Unit testing componentes
  • βœ… Successful and failed login tests.
  • βœ… Dashboard user and admin role testing.
  • βœ… Testing admin-only components.
  • βœ… Refactor componentes follow SOLID Principles
  • βœ… Validating custom hooks with spies.
  • βœ… Handling 500 error responses with MSW.
  • βœ… API simulation with Mock Service Worker and Mock Hooks .
  • βœ… Code coverage setup with Vitest.
  • βœ… Setup Mocks for server

Description

This project is a task management web application developed with React and Vite.

Key features that will be used for testing demonstrations include:

  • User authentication
  • CRUD operations for tasks
  • Global state management
  • API calls (simulated with json-server)
  • Conditional rendering and error handling

Through this project, students will gain hands-on experience in writing effective tests, using mocks, and simulating user interactions, all within the context of a real and functional React application.

Main Features

  • User authentication
  • CRUD for tasks (Create, Read, Update, Delete)
  • Intuitive and responsive user interface
  • Mock API with json-server for local development

User accounts

  1. superadmin

  2. visualizer1

  3. visualizer2

  4. visualizer3

  5. visualizer4

  6. Unknown User

    • Email: awdadw
    • Password: dawwda

Technologies

  • React
  • Vite
  • SCSS Modules
  • JSON Server (para mock API)

Prerequisites

  • Node.js (version 20.10.0 or higher)
  • npm or yarn

Installation

Install dependencies:

yarn

or if you use npm:

npm install

Running the development server

To start both the development server and the mock API, run:

yarn start

or if you use npm:

npm run start

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 75.9%
  • SCSS 17.4%
  • JavaScript 5.9%
  • HTML 0.8%

AltStyle γ«γ‚ˆγ£γ¦ε€‰ζ›γ•γ‚ŒγŸγƒšγƒΌγ‚Έ (->γ‚ͺγƒͺγ‚ΈγƒŠγƒ«) /