Configuración de Gemas en Proyectos Rails: Arspec, Factory Bot y Database Cleaner

Clase 5 de 33Curso de Creación de APIs con Ruby on Rails

Resumen

Pon a punto un entorno de pruebas sólido en Rails con RSpec Rails, shutdown matchers, Database Cleaner y Factory Bot. Con una configuración correcta y verificaciones constantes con bundle exec rspec, aseguras estabilidad desde el inicio y evitas errores difíciles de rastrear.

¿Cómo instalar y validar RSpec Rails en un proyecto?

Primero, ve a GitHub de RSpec Rails y sigue las instrucciones. La gema debe estar en los grupos de development y test. Después, ejecuta la instalación y genera los archivos necesarios para que RSpec funcione.

  • Ejecuta la instalación de gemas.
bundle install
  • Genera los archivos base de RSpec según las instrucciones del repositorio.
  • Verifica el set de pruebas con el comando estándar.
bundle exec rspec

Si aún no hay pruebas configuradas, verás que se ejecuta con éxito indicando cero ejemplos y cero fallos. Este será el comando de uso frecuente para correr el conjunto de pruebas.

¿Qué comando usar para correr las pruebas con RSpec?

  • Usa bundle exec rspec para ejecutar todo el set de pruebas.
  • Úsalo también tras cada cambio de configuración para validar que todo siga funcionando.

¿Qué esperar si no hay pruebas aún?

  • Salida con 0 ejemplos y 0 fallos.
  • Confirmación de que RSpec quedó operativo.

¿Cómo configurar shutdown matchers en Rails Helper?

Desde el Getting started del repositorio, añade la configuración en Rails Helper y omite las líneas indicadas por la guía. Es clave respetar el punto a partir del cual Rails ya está cargado.

# Add additional requires below this line
  • Añade los "requires" después de esa línea: ahí Rails ya está listo.
  • Elimina dependencias de minitest y test unit: usarás solo RSpec.
  • Conserva ActiveRecord, ActiveModel, Action Controller y la librería Rails.

Estos módulos permiten que shutdown matchers agregue matchers específicos para Rails: ActiveRecord/ActiveModel integran con la base de datos y Action Controller gestiona los controladores HTTP.

Tras guardar, ejecuta nuevamente bundle exec rspec. Si algo falla, el error señalará la línea correspondiente en Rails Helper para corregir rápido.

¿Por qué importar después de la línea indicada?

  • Antes de ese punto, Rails no está completamente cargado.
  • Cargar matchers y dependencias después evita errores de inicialización.

¿Cómo preparar Database Cleaner y Factory Bot con RSpec?

Ve al repositorio de Database Cleaner y copia la configuración de RSpec dentro del bloque RSpec.configure (en el ejemplo, estaba en la línea 47). Define la estrategia y la limpieza antes de la suite y alrededor de cada example.

  • Antes de cada suite: estrategia de transacción y limpieza por truncado.
  • Alrededor de cada example: aplica la estrategia y ejecuta el ejemplo.

Para Factory Bot, incluye su configuración dentro del mismo bloque de RSpec.configure, antes de la configuración de Database Cleaner. Esto habilita el uso de sus métodos directamente en los archivos de RSpec.

Al terminar, valida con:

bundle exec rspec

Si RSpec corre sin errores, la configuración quedó bien.

¿Qué hace la estrategia por transacción y truncado?

  • Transacción: abre una transacción por prueba y la revierte al finalizar.
  • Truncado: limpia la base antes de la suite para empezar en blanco.
  • Beneficio inmediato: datos aislados y repetibles en cada ejecución.

¿Cómo habilitar métodos de Factory Bot en las pruebas?

  • Incluye su módulo en RSpec.configure.
  • Luego puedes llamar sus métodos sin importar manualmente la librería.

¿Qué conceptos y habilidades aplicas en esta configuración?

  • RSpec Rails: gemas y comandos para pruebas en Rails.
  • bundle install: instalación de dependencias.
  • bundle exec rspec: ejecución del set de pruebas.
  • Rails Helper: archivo central de configuración de pruebas.
  • shutdown matchers: matchers adicionales integrados con Rails.
  • ActiveRecord/ActiveModel: integración con la base de datos.
  • Action Controller: controladores y respuestas HTTP.
  • Database Cleaner: estrategias de limpieza por transacción y truncado; configuración en la suite y cada example.
  • Factory Bot: helpers para generar datos de prueba.
  • GitHub: fuente de instrucciones y fragmentos de configuración.

¿Quieres que revisemos tu configuración o un error específico de Rails Helper o RSpec? Deja un comentario con el mensaje de error y lo vemos juntos.

      Configuración de Gemas en Proyectos Rails: Arspec, Factory Bot y Database Cleaner