Bienvenida e Introducción

1

¿Qué son las pruebas unitarias?

2

¿Por qué hacer pruebas unitarias?

Creando un framework de pruebas básico

3

Mi primera prueba unitaria en JavaScript

4

Las funciones expect() y it()

5

Organizando el código para correr en la web

6

Organizando el código para correr utilizando nodejs

Análisis estático de código

7

Herramientas de análisis estático de código

8

ESLint: Agregando alertas a nuestro código con ECMA Script

9

Herramientas de corrección de estilo

10

Herramientas de tipado

Trabajando con Jasmine en el frontend

11

Profundización en SpyOn: Comandos más utilizados y cómo ponerlos a prueba

12

Configurar un ambiente de trabajo para trabajar con el framework jasmine

13

Configurar Jasmine utilizando Node.js

14

Primer set de pruebas con Jasmine

15

Diccionario Jasmine

Probando Nodejs apps con Jasmine

16

Introducción al módulo de testing del lado del servidor

17

Configurando el proyecto Jasmine utilizando npm

18

Agregando Plugins a Jasmine

19

Configurando nuestro reporter

20

Pruebas en el servidor: Verificando un status 200 en GET

21

Pruebas en el servidor: Probando el método GET y Reto con FindByID

22

Pruebas en el servidor: Probando el método POST (request to server)

23

Pruebas en el servidor: Probando el método POST (request to PDF)

Probando Angular apps con Jasmine

24

Tipos de pruebas

25

Pruebas en el frontend: Probando el componente principal (App)

26

Configurando los ciclos de vida

27

Creando las pruebas del formulario: Configuración

28

Creando las pruebas necesarias para un formulario. (Primeras pruebas)

29

Probando el caso de exito al guardar un elemento en el servidor.

30

Trabajando con event emitters

31

Testeando ngZone y navegación.

32

Configurando el TestBed de el componente PINs

33

Creando un espia sobre el objecto window

Pruebas de integración de Angular apps con Jasmine

34

Ejecutando funciones a través de eventos en el template

35

Probando la navegación

36

Probando servicios con HTTP

37

Completando las pruebas del servicio HTTP

38

Cierre del curso

Aún no tienes acceso a esta clase

Crea una cuenta y continúa viendo este curso

Curso de Unit Testing para MEAN con Jasmine

Curso de Unit Testing para MEAN con Jasmine

Cristian Daniel Marquez Barrios

Cristian Daniel Marquez Barrios

Introducción al módulo de testing del lado del servidor

16/38
Recursos

Vamos a crear las pruebas unitarias de una aplicación construida con el Stack MEAN: Node.js y Express.js en el backend, MongoDB como base de datos y Angular (con TypeScript) en el frontend.

Vamos a probar la interacción del frontend (Angular) con el servidor o con los clientes y cómo interactúa el servidor con el framework que hace las consultas a la base de datos y con el cliente que hace las peticiones. NO vamos a probar la base de datos directamente.

Aportes 3

Preguntas 1

Ordenar por:

¿Quieres ver más aportes, preguntas y respuestas de la comunidad? Crea una cuenta o inicia sesión.

Profe tengo una duda, asi de sencillo, Jasmin ó Jest ó Cypress la verdad no se cual aprender, yo diría Chocolate, Gomitas, Galletas difícil de decidir.

oK… Queda claro el alcance que vamos a tener con jasmine!!

Cuando creamos una aplicación como esta que nos presenta el profe MEAN al principio del curso. Cuanto tiempo debo agregar al desarrollo para agrear pruebas unitarias al proyecto, por un decir tengo destinadas 80 horas del proyecto. Debo agregar un 20 o 30% más de tiempo?

Me quedé sorprendido de la claridad semántica de las asersiones con expect(), me pregunto si sería posible utilizar este tipo de funciones para programar el código de la app misma? por ejemplo utilizar cosas como expect(variable).not().tobeNaN(), comprendo que para algunos casos esto implicaría escribir más código y es algo que fácilmente podría ser abusado para utilizar estas asersiones en lugar de expresiones más simples, (x != NaN), no obstante se ve fácilmente su utilidad al permitir la escritura de un código más claro; de otra manera porqué tomarse la molestia de crearlas y no dejar el testing framework con el uso de if’s o expresiones ternarias? Por otro lado yo nunca he visto en ningún lenguaje el uso de construcciones tan específicas (y tal número de las mismas) para hacer todo tipo de asersiones. Existe la forma de usar esto en javascript para la escritura del código de aplicación como parte del mismo? y si es así que tan práctico resultaría?