Comando getBy en React Testing Library

| Última modificación: 6 de junio de 2024 | Tiempo de Lectura: 3 minutos

Algunos de nuestros reconocimientos:

Premios KeepCoding

En el emocionante mundo del desarrollo web, React se ha convertido en una de las bibliotecas más populares para la creación de interfaces de usuario interactivas y dinámicas. Cuando se trata de probar tus componentes React, la React Testing Library es una herramienta esencial en tu caja de herramientas. En este artículo, exploraremos en profundidad el comando getBy en React Testing Library y cómo puedes aprovecharlo para mejorar tus pruebas unitarias y funcionales.

getBy en React

Introducción al comando getBy en React

getBy en React es uno de los métodos más poderosos en la React Testing Library. Con este comando, puedes seleccionar elementos del DOM en función de su contenido o atributos. Esto es especialmente útil cuando deseas acceder a un elemento específico y verificar su comportamiento o contenido.

Sintaxis básica

La sintaxis básica del comando getBy en React se ve así:

//getBy en React
const element = screen.getBy([selector]);

En esta línea de código, [selector] es el valor que utilizas para seleccionar el elemento que estás buscando. Puede ser una cadena de texto, una expresión regular o una función que filtra los elementos.

Cómo utilizar getBy en React en tus pruebas

Ahora que tienes una idea de la sintaxis básica, veamos algunos ejemplos de cómo puedes utilizar getBy en React en tus pruebas de React.

Selección por texto

Supongamos que tienes un componente Button y deseas probar si se muestra correctamente el texto “Clic aquí”:

import { render, screen } from '@testing-library/react';
import Button from './Button';

test('El botón muestra el texto correcto', () => {
  render(<Button />);
  const buttonElement = screen.getByText('Clic aquí');
  expect(buttonElement).toBeInTheDocument();
});

Selección por atributo

Imagina que tienes una lista de elementos y deseas asegurarte de que el elemento con un atributo data-testid específico esté presente:

import { render, screen } from '@testing-library/react';
import ItemList from './ItemList';

test('Un elemento de la lista tiene el data-testid correcto', () => {
  render(<ItemList />);
  const elementWithTestId = screen.getByTestId('element-id');
  expect(elementWithTestId).toBeInTheDocument();
});

Mejores prácticas para usar getBy en React

Aquí hay algunas mejores prácticas que debes tener en cuenta al utilizar el comando getBy en React Testing Library:

  • Escribe pruebas enfocadas en el comportamiento del usuario: en lugar de probar implementaciones internas, concéntrate en cómo los usuarios interactuarán con tus componentes.
  • Combina getBy en React con otros comandos: a menudo, necesitarás una combinación de comandos para probar completamente un componente. Utiliza getBy en React en conjunto con otros métodos, como queryBy, findBy, etc.
  • Mantén tus pruebas independientes: asegúrate de que tus pruebas sean independientes unas de otras. No confíes en el orden de ejecución de las pruebas.
  • Actualiza tus pruebas regularmente: a medida que tu código evoluciona, tus pruebas también deben hacerlo. Actualiza y ajusta tus pruebas para reflejar los cambios en tus componentes.

El comando getBy en React Testing Library es una herramienta esencial para escribir pruebas efectivas y realistas para tus componentes React. Al enfocarse en la interacción del usuario y seleccionar elementos en función de su contenido o atributos, puedes crear pruebas más confiables y significativas.

Si estás emocionado por aprender más sobre desarrollo web y explorar herramientas como React Testing Library, considera unirte al Desarrollo Web Full Stack Bootcamp de KeepCoding. Este bootcamp te brindará las habilidades y el conocimiento necesario para ingresar al apasionante sector de tecnología en poco tiempo.

¡No pierdas esta oportunidad de cambiar tu vida! Inscríbete hoy mismo y comienza tu camino hacia una carrera emocionante en el mundo del desarrollo web. ¡Tu futuro te está esperando!

Alberto Casero

Alberto Casero es CTO en Watium, Fundador de Kas Factory & Coordinador del Bootcamp en Desarrollo Web.

Posts más leídos

¡CONVOCATORIA ABIERTA!

Desarrollo Web

Full Stack Bootcamp

Clases en Directo | Profesores en Activo | Temario 100% actualizado