Validaciones y Pruebas TDD en Rails: Modelos USR y Post
Clase 10 de 33 • Curso de Creación de APIs con Ruby on Rails
Contenido del curso
Proyecto
- 3

Creación de APIs con Rails: Proyecto Blog API paso a paso
04:37 min - 4

Configuración de Gemas para Pruebas en Proyectos Rails
06:26 min - 5

Configuración de Gemas en Proyectos Rails: Arspec, Factory Bot y Database Cleaner
07:25 min - 6

Implementación de un Health Check Endpoint en API con RSpec
12:28 min - 7

Diseño de Casos de Uso y Diagramas de Entidad para Aplicaciones
03:16 min - 8

Diagrama entidad relación: usuario y post
01:41 min - 9

Modelado de Aplicaciones con TDD en Rails
05:59 min - 10

Validaciones y Pruebas TDD en Rails: Modelos USR y Post
Viendo ahora - 11

Implementación de Endpoints para Listar y Mostrar Posts con TDD
15:12 min - 12

Implementar controlador Posts con TDD
10:34 min - 13

Pruebas TDD para crear y actualizar posts
10:12 min - 14

Implementación de Métodos y Manejo de Excepciones en Rails API
10:23 min - 15

Active Model serializers: control total de JSON en Rails
06:03 min - 16

Búsqueda y Filtrado de Posts por Título con TDD
05:57 min - 17

Implementación de Búsqueda de Posts con Servicios en Rails
06:06 min - 18

Problema N+1 en Rails: Detección y Solución Eficaz
04:40 min - 19

Identificación y solución del problema N+1 en Rails
06:20 min - 20

Flujo de Autenticación en APIs con Tokens y Proveedores
05:29 min - 21

Tests con RSpec para autenticación de tokens
12:17 min - 22

Autenticación con Tokens: Implementación en Rails API
05:53 min - 23

Autenticación de Usuarios en Controladores Rails
09:19 min - 24

Autenticación y Seguridad en CRUD de Posts en Rails
09:17 min - 25

Pruebas de Creación y Actualización con Autenticación en Rails
14:21 min - 26

Probando API Ruby on Rails con Postman
10:43 min - 27

Caching en Aplicaciones Web: Funciones y Niveles
07:15 min - 28

Aceleración de Búsquedas en Rails con Caching
08:23 min - 29

Background Jobs en Rails: Conceptos y Funcionalidades
05:45 min - 30

Procesamiento en Background y Envío de Correos con Rails
09:45 min - 31

Envío de Correos en Rails con ActionMailer y Background Jobs
11:06 min - 32
Autenticación y Autorización con JWT y Auth0 en Aplicaciones Web
03:48 min
Cierre
Aplicar TDD en Rails con RSpec fortalece la calidad del código desde el inicio. Aquí se escribe primero la prueba, se observa cómo falla y luego se implementa lo mínimo para ponerla en verde. En este caso, se validan campos clave en los modelos Post y User, y se comprueban relaciones usando association matchers.
¿Qué objetivo tiene TDD en Rails con RSpec?
El propósito es asegurar que el comportamiento cumpla los requerimientos desde el diseño. Primero se crean pruebas en post_spec.rb, luego se ejecutan, fallan y se implementan las validaciones necesarias en los modelos.
- Escribir pruebas con contexto usando describe e it para mensajes claros al fallar.
- Usar matchers como “should validate presence of …”.
- Agrupar verificaciones: “validate presence of required fields”.
- Ejecutar en terminal y corregir hasta ver todo en verde.
¿Qué pruebas fallan primero y por qué?
- Falla la validación de
titleen Post al no existir la lógica de validación. - Luego fallan
content,publishedyuser_idal no estar validados. - En User fallan
email,name,auth_tokeny la relación con Post.
¿Por qué es útil eliminar el pending autogenerado?
- Evita falsos positivos en archivos de prueba.
- Indica que ya se están implementando pruebas reales.
¿Cómo se escriben pruebas de validaciones y relaciones?
Se crean pruebas declarativas y legibles. Se aprovechan matchers de validación y de asociación.
¿Cómo validar presencia con RSpec?
- Usar el patrón “validate presence of …” para campos obligatorios.
- Mantener nombres claros como “validate presence of required fields”.
Ejemplo de pruebas para Post:
# spec/models/post_spec.rb
RSpec.describe Post, type: :model do
describe 'validations' do
it 'validate presence of required fields' do
should validate_presence_of(:title)
should validate_presence_of(:content)
should validate_presence_of(:published)
should validate_presence_of(:user_id)
end
end
end
¿Cómo probar relaciones con association matchers?
- Verificar que User tenga muchos posts con “should have many posts”.
Ejemplo de pruebas para User:
# spec/models/user_spec.rb
RSpec.describe User, type: :model do
describe 'validations' do
it 'validate presence of required fields' do
should validate_presence_of(:email)
should validate_presence_of(:name)
should validate_presence_of(:auth_token)
end
end
describe 'relations' do
it 'validate relationships' do
should have_many(:posts)
end
end
end
¿Cómo se implementan las validaciones en los modelos?
Tras ver fallar las pruebas, se agregan las validaciones mínimas en los modelos para que pasen. Esto cumple el ciclo de escribir, fallar, implementar, pasar.
¿Qué validaciones requiere Post?
title,content,publishedyuser_idcon presencia obligatoria.
# app/models/post.rb
class Post < ApplicationRecord
validates :title, presence: true
validates :content, presence: true
validates :published, presence: true
validates :user_id, presence: true
end
¿Qué validaciones y relaciones requiere User?
email,name,auth_tokencon presencia obligatoria.- Relación con muchos posts.
# app/models/user.rb
class User < ApplicationRecord
has_many :posts
validates :email, presence: true
validates :name, presence: true
validates :auth_token, presence: true
end
¿Te gustaría comentar cómo nombras tus pruebas o qué matchers usas para mantenerlas legibles y efectivas?