Creación y Actualización de Posts con Pruebas TDD
Clase 13 de 33 • Curso de Creación de APIs con Ruby on Rails
Contenido del curso
- 3

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

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

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

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

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

Diagrama de Entidad Relación para Modelos de Aplicación
01:41 - 9

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

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

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

Implementación de Pruebas y Controladores en Rails
10:34 - 13

Creación y Actualización de Posts con Pruebas TDD
10:12 - 14

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

Serialización de Modelos en Rails con ActiveModelSerializer
06:03 - 16

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

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

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

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

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

Pruebas de Autenticación en API con Test Driven Development
12:17 - 22

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

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

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

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

Pruebas de API con Postman: Ejecución y Verificación de Respuestas
10:43 - 27

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

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

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

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

Envío de Correos en Rails con ActionMailer y Background Jobs
11:06 - 32
Autenticación y Autorización con JWT y Auth0 en Aplicaciones Web
03:48
¿Cómo implementar los métodos para crear y actualizar un post?
Para empezar a desarrollar métodos que nos permitan crear y actualizar posts, vamos a seguir la metodología de desarrollo impulsado por pruebas (TDD, por sus siglas en inglés). Esto implica que primero crearemos las pruebas necesarias para garantizar el correcto funcionamiento de nuestras funciones, antes de realizar la implementación final.
¿Cómo crear una prueba para el método POST?
El método POST será responsable de la creación de nuevos posts. La creación de una prueba para este método sigue estos pasos:
-
Preparación de datos: Necesitamos una serie de datos que serán enviados a la petición POST. Estos datos incluirán:
- Un título para el post.
- El contenido del post.
- Un campo para indicar si está publicado o no.
- Un
userID, que lo generaremos creando un usuario en nuestro sistema usandoFactoryBot.
-
Llamar al endpoint POST: Utilizaremos los datos generados para realizar la petición al endpoint POST. Es importante distinguir entre el método HTTP POST y el modelo de datos llamado "Post".
-
Verificaciones de la prueba:
- Asegurarnos de que el payload de la respuesta no esté vacío.
- Verificar que el payload contenga un
ID. - Confirmar que la respuesta HTTP tenga un código de estado
created(201), lo que significa que el recurso ha sido creado exitosamente.
¿Cómo probar el método PUT para actualizar un post?
Para el método PUT, que actualiza un post existente, los pasos son los siguientes:
-
Crear un Post existente: A diferencia del POST, aquí necesitamos un post ya creado para poder actualizarlo.
-
Preparar los parámetros de actualización: Al igual que con la creación, utilizaremos
FactoryBotjunto conFakerpara generar datos aleatorios y realizaremos modificaciones como cambiar el título o el contenido. -
Realizar la petición PUT: Pasaremos el
IDdel post que queremos actualizar, junto con los parámetros de actualización. -
Verificaciones de la prueba:
- Verificar que el payload retornado no esté vacío.
- Comprobar que el
IDdel payload corresponde con elIDdel post que se actualizó. - Confirmar que la respuesta HTTP sea
ok(200), indicando que la operación fue exitosa.
¿Cómo manejar errores en posts y actualizaciones inválidas?
Es crucial verificar cómo el sistema maneja datos incompletos o inválidos. Para esto, agregamos pruebas que comprueben cómo responde el sistema ante estas situaciones:
-
Errores al crear un post: Intentamos crear un post con un campo obligatorio vacío, como el título. La expectativa es recibir una respuesta
unprocessable entity(422), junto con un mensaje de error. -
Errores al actualizar un post: De manera similar, probamos actualizar un post definiendo campos importantes como el contenido o título a
nil. La prueba debe verificar que se retorne un estadounprocessable entityy un mensaje de error.
Para ejecutar estas pruebas, volvemos a la consola de comandos y verificamos que las pruebas respectivas fallen debido a la inexistencia de rutas. Así, hemos establecido un marco de pruebas que validará la correcta implementación de lógica para la creación y actualización de posts. Ahora, estamos listos para pasar a la implementación práctica que hará que estas pruebas sean exitosas en el futuro.