Pruebas de Creación y Actualización con Autenticación en Rails
Clase 25 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 pruebas unitarias para autenticación y actualización de datos?
En el desarrollo de aplicaciones, asegurar que los procesos de autenticación y manipulación de datos funcionan correctamente es esencial. A través de pruebas unitarias, podemos garantizar que los métodos de crear y actualizar se ejecuten con la seguridad y restricciones previstas. Este artículo examinará cómo implementar estas pruebas, paso a paso, usando un enfoque en el contexto de Rails.
¿Qué pruebas unitarias son necesarias?
Antes de implementar las pruebas, es crucial listar las diferentes situaciones a verificar:
-
Creación de un post:
- Se puede crear con autenticación.
- No se puede crear sin autenticación (esperar un error 401).
-
Actualización de un post:
- Se puede actualizar un post propio con autenticación.
- No se puede actualizar un post de otro usuario (se espera un error 401).
- No se puede actualizar sin autenticación (se espera también un error 401).
¿Cómo crear las pruebas para la creación de un post?
Utilizando la autenticación adecuada, primero configuramos nuestros parámetros y encabezados para asegurarnos que las pruebas pasan los requisitos necesarios.
create_params = {
title: 'title',
content: 'some content',
published: true
}
# Request con autenticación
response = post '/posts', params: create_params, headers: auth_headers
expect(response.status).to eq(201)
# Request sin autenticación
response = post '/posts', params: create_params
expect(response.status).to eq(401)
En el bloque de código anterior, definimos una estructura básica para crear un post, verificando si las respuestas contienen el estado esperado.
¿Qué debemos considerar al actualizar un post?
Cuando probamos actualizaciones, nos interesa tanto la propiedad del usuario sobre el post como la respuesta del sistema cuando se cambia uno que no le pertenece.
# Actualización de un post propio
update_params = { title: 'new title' }
response = put "/posts/#{user_post.id}", params: update_params, headers: auth_headers
expect(response.status).to eq(200)
# Intentar actualizar un post de otro usuario
response = put "/posts/#{other_user_post.id}", params: update_params, headers: auth_headers
expect(response.status).to eq(404)
Implementamos un test similar al anterior, pero para verificar que los posts solo puedan ser actualizados por su propietario. Cuando intentamos modificar el post de otro usuario, el sistema deberá devolver un error.
¿Cómo gestionar errores en las pruebas?
Es común que las pruebas arrojen errores inesperados como un "500 Internal Server Error" debido a excepciones mal manejadas en nuestro código. En tales casos, podemos ajustar el controlador de excepciones para manejar errores más específicos.
rescue_from ActiveRecord::RecordNotFound, with: :record_not_found
def record_not_found
render json: { error: 'Not Found' }, status: :not_found
end
Al manejar correctamente estas excepciones, garantizamos que el test muestre un "404 Not Found" en lugar de un error de servidor genérico.
¿Es posible mejorar y reutilizar el código de autenticación?
Al manejar el método de autenticación, es una buena práctica refactorizar su ubicación para que sea reutilizable en otros controles:
module Secured
def authenticate_user
# lógica de autenticación
end
end
# Incluyendo en otros controladores
class PostsController < ApplicationController
include Secured
before_action :authenticate_user
end
Este enfoque ayuda a mantener el código limpio y disminuye la redundancia.
¿Por qué limpiar y revisar las pruebas futuras?
Una vez implementadas las pruebas para creación y actualización, es importante eliminar pruebas antiguas que ya no sean necesarias o que se hayan reemplazado por las nuevas, asegurando así un código más eficiente y menos propenso a errores.