Búsqueda y Filtrado de Posts por Título con TDD

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

Resumen

Implementa una búsqueda por título confiable usando TDD. Aquí verás cómo preparar datos controlados con Factory Bot, validar query params en el request y afirmar que el response solo incluya los posts esperados. Con un enfoque práctico, cada paso asegura precisión y mantiene el código comprobable.

¿Cuál es el objetivo de la búsqueda por título?

La meta es filtrar posts por coincidencias en el título y comprobar que la respuesta de la API refleje ese criterio. Se trabaja con query params en la URL para enviar el término a filtrar y con aserciones claras que validan el resultado.

¿Qué valida la prueba con query params?

  • Que el payload no sea vacío.
  • Que el tamaño sea el esperado (por ejemplo, dos resultados).
  • Que los IDs sean exactamente los de los posts que contienen la palabra buscada.
  • Que el orden no afecte la comparación al usar ordenamiento previo.

¿Cómo aislar efectos en pruebas?

  • Incluir el request solo en la prueba que lo necesita.
  • Quitar inclusiones o configuraciones globales innecesarias que afectan otras pruebas.

¿Cómo preparar datos de prueba con Factory Bot?

Para evitar aleatoriedad en el atributo de publicación, se define una factory específica que garantice un estado estable. Así, las pruebas operan con posts publicados y títulos controlados.

¿Cómo controlar el atributo publish en la factory?

  • Crear una factory nombrada, por ejemplo, published_post.
  • Especificar la clase y fijar publish en true para asegurar consistencia.
# factory de posts con una variante publicada
FactoryBot.define do
  factory :published_post, class: 'Post' do
    publish { true }
    # otros atributos según el factory base
  end
end

Luego, se crean tres registros con títulos similares y uno distinto para verificar el filtrado por coincidencia parcial:

post1 = create(:published_post, title: 'Hola mundo')
post2 = create(:published_post, title: 'Hola Rails')
post3 = create(:published_post, title: 'Curso Rails')

¿Cómo validar el filtrado con TDD?

Se agrega un query param en la URL con el término "hola" para que el request retorne solo los posts que contienen esa palabra en el título. Con TDD, primero se ejecuta la prueba esperando que falle y luego se implementa la lógica hasta que pase.

¿Qué aserciones garantizan el comportamiento correcto?

  • Verificar que el payload no esté vacío.
  • Verificar que el tamaño sea dos cuando se busca "hola".
  • Mapear y ordenar IDs para comparar sin depender del orden de llegada.
# suponer que el response ya está parseado a json
expect(json).not_to be_empty
expect(json.size).to eq(2)

returned_ids = json.map { |p| p['id'] }.sort
expected_ids = [post1.id, post2.id].sort
expect(returned_ids).to eq(expected_ids)

Además, se confirma el flujo propio de TDD: primero la prueba falla porque aún se regresan los tres posts creados y no existe la lógica de filtrado; luego se implementa el comportamiento para que solo lleguen los dos relevantes.

¿Tienes una estrategia distinta para probar búsquedas por título? Cuéntala en los comentarios y enriquezcamos la práctica de pruebas entre todos.