• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

414
Vistas
Biblioteca de pruebas de reacción: cuándo usar userEvent.click y cuándo usar fireEvent

Actualmente estoy aprendiendo React-Testing-Library.

Me gustaría probar la interacción del mouse con un elemento. Actualmente, no me queda claro la diferencia entre userEvent.click (elemento) y fireEvent.click (elemento). ¿Se recomienda el uso de ambos y, en el siguiente ejemplo, se implementan correctamente?

 const mockFunction = jest.fn(() => console.info('button clicked')); const { getByTestId } = render(<MyAwesomeButton onClick={mockFunction} />); const myAwesomeButton = getByTestId('my-awesome-button'); // Solution A fireEvent(myAwesomeButton) expect(mockFunction.toHaveBeenCalledTimes(1); // Solution B userEvent.click(myAwesomeButton); expect(mockFunction).toHaveBeenCalledTimes(1);

Gracias de antemano por cualquier claridad.

about 3 years ago · Santiago Trujillo
2 Respuestas
Responde la pregunta

0

Detrás de escena, userEvent usa fireEvent . Puede considerar que fireEvent es la API de bajo nivel, mientras que userEvent establece un flujo de acciones.

Aquí está el código para userEvent.click

Puede ver que, según el elemento en el que intente hacer clic, userEvent realizará un conjunto de acciones diferentes (por ejemplo, si es una etiqueta o una casilla de verificación).

about 3 years ago · Santiago Trujillo Denunciar

0

De acuerdo con Docs , debe usar user-event para probar la interacción con sus componentes.

fireEvent envía exactamente los eventos que le indicas y solo esos, incluso si esos eventos exactos nunca se han enviado en una interacción real en un navegador.

User-event por otro lado, distribuye los eventos como sucederían si un usuario interactuara con el documento. Eso podría conducir a los mismos eventos que envió anteriormente por fireEvent directamente, pero también podría detectar errores que hagan imposible que un usuario active dichos eventos.

about 3 years ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda