logoImagina
iconCurso
Te recomendamos nuestro curso de Angular 18
Descubre el curso de Angular 18
Ir al curso

Cómo Usar Testing en Angular con Jasmine y Karma

iconImage
Escrito por Equipo de Imagina
Actualizado el 29-07-2024
Duración: 15 min

En el desarrollo moderno de aplicaciones web, asegurar la calidad del código es una prioridad. Uno de los enfoques más efectivos para lograr esto es a través del testing, y en el caso de Angular, Jasmine y Karma son herramientas fundamentales. A lo largo de este artículo, exploraremos en detalle qué es el testing en Angular, su importancia y cómo implementarlo utilizando estas herramientas.

Desarrolladora web haciendo testing en Angular

¿Qué es el Testing en Angular?

El testing en Angular es el proceso mediante el cual verificamos que las diferentes partes de nuestra aplicación funcionen correctamente. Esto incluye desde componentes individuales hasta el comportamiento de la aplicación en su conjunto. Angular proporciona un entorno robusto para realizar tanto pruebas unitarias como de integración, asegurando que cada pieza del código cumpla con su propósito sin introducir errores.

Las pruebas unitarias se enfocan en probar componentes individuales o unidades de código de manera aislada. Utilizando Jasmine como framework de pruebas, podemos definir y ejecutar estos tests. Jasmine es una herramienta poderosa y flexible que nos permite escribir pruebas claras y concisas para nuestro código Angular.

Por otro lado, Karma actúa como nuestro ejecutor de pruebas. Se encarga de lanzar los tests en diferentes navegadores y reportar los resultados de manera automática. Karma se configura para ejecutar las pruebas cada vez que hacemos un cambio en nuestro código, proporcionando un flujo de trabajo eficiente y continuo.

¿Por qué es Importante el Testing?

El testing no solo es una práctica recomendada, sino que es esencial para cualquier proyecto de desarrollo web. A continuación, destacamos algunas razones clave:

  1. Detección temprana de errores: Con el testing, podemos identificar errores en las etapas iniciales del desarrollo, lo que reduce el coste y el tiempo necesarios para corregirlos.
  2. Facilita el mantenimiento del código: Las pruebas ayudan a documentar el comportamiento esperado del código.
  3. Confianza en el código: Tener una suite completa de pruebas proporciona confianza al equipo de desarrollo para realizar cambios y mejoras en el código sin temor a romper funcionalidades existentes.
  4. Mejora la calidad del producto: Al asegurar que cada componente funciona correctamente y que el sistema en su conjunto cumple con los requisitos, mejoramos la calidad del producto final.

El testing en Angular utilizando Jasmine y Karma no solo es una práctica recomendada, sino que es una necesidad para cualquier equipo de desarrollo que busque entregar aplicaciones web robustas y de alta calidad.

Herramientas de Testing en Angular

Para llevar a cabo el testing en Angular de manera efectiva, es fundamental conocer y utilizar las herramientas adecuadas. En este contexto, Jasmine y Karma se destacan como las herramientas más populares y potentes para la realización de pruebas en aplicaciones Angular.

Jasmine

Jasmine es un framework de testing para JavaScript que permite escribir y ejecutar pruebas de manera sencilla y eficaz. Es muy utilizado en el entorno Angular debido a su simplicidad y capacidad para integrarse fácilmente con otras herramientas. Algunas de las carcterísticas son:

  • Sintaxis Descriptiva: Jasmine utiliza una sintaxis que es fácil de leer y entender, lo que facilita la escritura y revisión de pruebas. Los términos comunes incluyen describe, it, expect, y beforeEach.

  • Soporte para Mocks y Spies: Jasmine permite la creación de mocks y spies que simulan el comportamiento de objetos y funciones, lo que es crucial para pruebas unitarias.

  • Ejecución Independiente de Navegador: Las pruebas escritas en Jasmine pueden ejecutarse en cualquier entorno de JavaScript, ya sea en un navegador o en Node.js.

Karma

Karma es una herramienta de ejecución de pruebas que facilita la ejecución de pruebas de JavaScript en múltiples navegadores. Fue desarrollado específicamente para proyectos de Angular, pero puede usarse con cualquier proyecto de JavaScript. Algunas de las características son:

  • Ejecución en Tiempo Real: Karma ejecuta las pruebas en tiempo real cada vez que se guardan los cambios en el código, proporcionando retroalimentación inmediata.

  • Compatibilidad con Múltiples Navegadores: Permite ejecutar pruebas en diferentes navegadores simultáneamente, asegurando que el código funcione de manera consistente en todos los entornos.

  • Integración Continua: Se integra fácilmente con herramientas de integración continua (CI), lo que permite automatizar el proceso de pruebas y asegurar la calidad constante del código.

Configuración Inicial

Para comenzar con el testing en Angular utilizando Jasmine y Karma, es esencial configurar correctamente el entorno de desarrollo. A continuación, detallamos los pasos necesarios para la configuración de Jasmine y Karma en Angular.

Instalar Angular CLI

La Angular CLI (Command Line Interface) es una herramienta fundamental para crear y administrar proyectos Angular. Facilita la configuración y las tareas comunes, incluyendo la configuración inicial del testing.

Para instalar Angular CLI, sigue estos pasos:

  1. Instala Node.js: Angular CLI requiere Node.js. Puedes descargar e instalar la última versión de Node.js desde su web oficial.

  2. Instala Angular CLI: Una vez que tengas Node.js instalado, abre una terminal y ejecuta el siguiente comando:

1 npm install -g @angular/cli

Este comando instala Angular CLI globalmente en tu sistema.

  1. Crea un Nuevo Proyecto Angular: Con Angular CLI instalado, puedes crear un nuevo proyecto Angular ejecutando:
1ng new nombre-del-proyecto

¿Cómo Configurar Jasmine y Karma?

Una vez que tu proyecto Angular está creado, es hora de configurar Jasmine y Karma. Por defecto, Angular CLI incluye configuraciones básicas para estas herramientas, pero es útil entender cómo funcionan y cómo se pueden personalizar.

  1. Verifica la Configuración Inicial: Angular CLI genera archivos de configuración para Jasmine y Karma. Verifica que estos archivos (karma.conf.js y test.ts) estén presentes en tu proyecto.

  2. Archivo karma.conf.js: Este archivo contiene la configuración de Karma. Un ejemplo básico de configuración es:

1module.exports = function(config) { 2 config.set({ 3 frameworks: ['jasmine', '@angular-devkit/build-angular'], 4 plugins: [ 5 require('karma-jasmine'), 6 require('karma-chrome-launcher'), 7 require('karma-jasmine-html-reporter'), 8 require('@angular-devkit/build-angular/plugins/karma') 9 ], 10 client: { 11 clearContext: false // leave Jasmine Spec Runner output visible in browser 12 }, 13 jasmineHtmlReporter: { 14 suppressAll: true // removes the duplicated traces 15 }, 16 reporters: ['progress', 'kjhtml'], 17 port: 9876, 18 colors: true, 19 logLevel: config.LOG_INFO, 20 autoWatch: true, 21 browsers: ['Chrome'], 22 singleRun: false, 23 restartOnFileChange: true 24 }); 25};
  1. Archivo test.ts: Este archivo configura el entorno de pruebas de Jasmine:
1import 'zone.js/testing'; 2import { getTestBed } from '@angular/core/testing'; 3import { 4 BrowserDynamicTestingModule, 5 platformBrowserDynamicTesting 6} from '@angular/platform-browser-dynamic/testing'; 7 8declare const require: { 9 context(path: string, deep?: boolean, filter?: RegExp): { 10 keys(): string[]; 11 <T>(id: string): T; 12 }; 13}; 14 15// First, initialize the Angular testing environment. 16getTestBed().initTestEnvironment( 17 BrowserDynamicTestingModule, 18 platformBrowserDynamicTesting() 19); 20// Then we find all the tests. 21const context = require.context('./', true, /\.spec\.ts$/); 22// And load the modules. 23context.keys().map(context);

Estructura de un Proyecto Angular con Testing

La estructura de un proyecto Angular bien organizado incluye carpetas y archivos específicos para pruebas. A continuación se describe una estructura típica:

  1. src/app: Contiene los componentes, servicios y módulos de la aplicación.
  2. src/app//.spec.ts: Archivos de prueba para cada componente, servicio o módulo. Estos archivos contienen las pruebas unitarias escritas con Jasmine.
  3. src/assets: Archivos estáticos utilizados por la aplicación.
  4. src/environments: Configuraciones específicas del entorno (desarrollo, producción).
  5. e2e: Contiene las pruebas end-to-end (E2E) para la aplicación, utilizando herramientas como Protractor.

Cada componente en Angular debería tener su propio archivo de prueba .spec.ts. Por ejemplo, si tienes un componente app.component.ts, debería haber un archivo app.component.spec.ts en la misma carpeta, que contenga las pruebas unitarias para ese componente.

Descubre la formación a tu medida
Rellena el formulario para obtener más información sobre los cursos.
Tamaño de la empresa *
Términos y condiciones *

Tipos de Pruebas en Angular

En Angular, existen varios tipos de pruebas que podemos realizar para asegurarnos de que nuestra aplicación funcione correctamente en todos los aspectos. Los tres tipos principales de pruebas son:

Pruebas Unitarias

Las pruebas unitarias se centran en probar componentes individuales o unidades de código en aislamiento. Su objetivo es verificar que cada unidad de código funcione según lo esperado de manera independiente. En Angular, utilizamos Jasmine para escribir estas pruebas y Karma para ejecutarlas.

A continuación, se muestra un ejemplo de cómo escribir una prueba unitaria para un componente Angular:

1import { ComponentFixture, TestBed } from '@angular/core/testing'; 2import { AppComponent } from './app.component'; 3 4describe('AppComponent', () => { 5 let component: AppComponent; 6 let fixture: ComponentFixture<AppComponent>; 7 8 beforeEach(async () => { 9 await TestBed.configureTestingModule({ 10 declarations: [ AppComponent ] 11 }).compileComponents(); 12 }); 13 14 beforeEach(() => { 15 fixture = TestBed.createComponent(AppComponent); 16 component = fixture.componentInstance; 17 fixture.detectChanges(); 18 }); 19 20 it('debería crear el componente', () => { 21 expect(component).toBeTruthy(); 22 }); 23 24 it('debería tener como título "app"', () => { 25 expect(component.title).toEqual('app'); 26 }); 27});

En este ejemplo, se configuran y ejecutan pruebas unitarias para verificar que el componente AppComponent se crea correctamente y que su título es el esperado.

Pruebas de Integración

Las pruebas de integración se utilizan para probar cómo interactúan múltiples unidades de código entre sí. A diferencia de las pruebas unitarias, que se enfocan en componentes aislados, las pruebas de integración aseguran que diferentes partes del sistema funcionen en conjunto. A continuación, se presenta un ejemplo de cómo escribir una prueba de integración en Angular:

1import { TestBed } from '@angular/core/testing'; 2import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing'; 3import { DataService } from './data.service'; 4 5describe('DataService', () => { 6 let service: DataService; 7 let httpMock: HttpTestingController; 8 9 beforeEach(() => { 10 TestBed.configureTestingModule({ 11 imports: [ HttpClientTestingModule ], 12 providers: [ DataService ] 13 }); 14 15 service = TestBed.inject(DataService); 16 httpMock = TestBed.inject(HttpTestingController); 17 }); 18 19 it('debería recuperar datos del API', () => { 20 const dummyData = [{ id: 1, name: 'John' }, { id: 2, name: 'Doe' }]; 21 22 service.getData().subscribe(data => { 23 expect(data.length).toBe(2); 24 expect(data).toEqual(dummyData); 25 }); 26 27 const req = httpMock.expectOne(`${service.API_URL}/data`); 28 expect(req.request.method).toBe('GET'); 29 req.flush(dummyData); 30 }); 31 32 afterEach(() => { 33 httpMock.verify(); 34 }); 35});

En este ejemplo, se prueba la integración de DataService con el cliente HTTP para asegurarse de que puede recuperar datos del API correctamente.

Pruebas End-to-End (E2E)

Las pruebas end-to-end (E2E) verifican el funcionamiento de la aplicación completa desde el punto de vista del usuario. Estas pruebas simulan interacciones del usuario con la aplicación para asegurarse de que todos los componentes funcionen correctamente en conjunto. En Angular, se suelen utilizar herramientas como Protractor para realizar pruebas E2E.

A continuación, se muestra un ejemplo básico de una prueba E2E utilizando Protractor:

1import { browser, by, element } from 'protractor'; 2 3describe('Pruebas E2E para la aplicación', () => { 4 it('debería mostrar el título correcto en la página de inicio', () => { 5 browser.get('/'); 6 const title = element(by.css('app-root h1')).getText(); 7 expect(title).toEqual('Bienvenidos a la aplicación Angular!'); 8 }); 9});

En este ejemplo, la prueba E2E abre la aplicación en el navegador, busca el título en la página de inicio y verifica que el texto sea el esperado.

Buenas Prácticas en Testing

Implementar buenas prácticas en testing es esencial para asegurar que nuestras pruebas sean eficaces, mantenibles y ofrezcan un valor real al proceso de desarrollo. En esta sección, exploraremos algunas estrategias de testing y consejos para el mantenimiento y actualización de pruebas en proyectos Angular.

Estrategias de Testing

Para maximizar la efectividad de nuestras pruebas, es crucial seguir una serie de estrategias bien definidas. Aquí presentamos algunas de las más importantes:

  1. Escribir Pruebas Simples y Aisladas: Las pruebas unitarias deben ser simples y enfocadas en una sola unidad de código. Evita dependencias innecesarias que puedan complicar la prueba y dificulte la identificación de errores.

  2. Uso de Mocks y Spies: Utilizar mocks y spies es esencial para simular el comportamiento de dependencias externas y aislar la unidad de código que estás probando. Jasmine proporciona excelentes herramientas para este propósito.

  3. Cobertura de Código: Asegúrate de que tus pruebas cubran la mayor parte del código posible. Las herramientas de cobertura de código pueden ayudarte a identificar partes del código que no están siendo probadas.

  4. Pruebas Automatizadas en Integración Continua (CI): Integra tus pruebas en un pipeline de CI para que se ejecuten automáticamente cada vez que se realiza un cambio en el código. Esto asegura que cualquier error introducido se detecte de inmediato.

  5. Pruebas de Regresión: Cada vez que se introduce una nueva funcionalidad o se corrige un error, es importante realizar pruebas de regresión para asegurarse de que los cambios no hayan afectado negativamente otras partes del sistema.

Mantenimiento y Actualización de Pruebas

El mantenimiento y la actualización de pruebas son aspectos críticos para asegurar que nuestro conjunto de pruebas siga siendo relevante y efectivo a lo largo del tiempo. Aquí hay algunos consejos clave:

  • Revisar y Actualizar Regularmente: A medida que el código evoluciona, las pruebas también deben actualizarse para reflejar estos cambios.

  • Refactorización de Pruebas: Eliminar duplicaciones y mejorar la organización de las pruebas contribuye a un conjunto de pruebas más limpio y manejable.

  • Eliminar Pruebas Obsoletas: Mantener pruebas obsoletas puede llevar a confusiones y a la ejecución de tests innecesarios que consumen tiempo y recursos.

  • Documentación de Pruebas: Documenta el propósito de cada prueba y cualquier configuración especial necesaria para su ejecución.

  • Feedback Continuo: Utiliza el feedback continuo de las herramientas de CI para identificar y corregir fallos rápidamente.

¿Cómo Aprender Angular como un Experto?

Hemos explorado a fondo cómo utilizar testing en Angular con Jasmine y Karma, desde la configuración inicial hasta la implementación de pruebas unitarias, de integración y end-to-end (E2E). Hemos aprendido la importancia del testing en el desarrollo web y cómo estas herramientas pueden ayudarnos a asegurar la calidad y fiabilidad de nuestras aplicaciones.

Para profundizar aún más en tus habilidades de desarrollo y testing en Angular, te recomendamos nuestro Curso de Angular 18. Este curso ofrece una cobertura completa de Angular, incluyendo módulos avanzados de testing, para que puedas convertirte en un experto en el desarrollo de aplicaciones robustas y de alta calidad.

¡No pierdas la oportunidad de mejorar tus proyectos de desarrollo web!

Descubre la formación a tu medida
Rellena el formulario para obtener más información sobre los cursos.
Tamaño de la empresa *
Términos y condiciones *
Tutoriales relacionados
Angular 8 ya está aquí y estas son sus Novedades
Descubre las últimas innovaciones en Angular 8 y potencia tus desarrollos web. Domina las nuevas funcionalidades con nuestro tutorial experto.
Cómo usar el Hook useContext de React
Explorando useContext en React: cómo este poderoso Hook puede transformar la gestión del estado en tus aplicaciones.
Conoce las Novedades de Angular 15
Descubre las sorprendentes innovaciones de Angular 15: potencia, rendimiento y nuevas funcionalidades que te dejarán sin aliento. ¡Visítanos ahora!
Angular 11: Ya tenemos nueva versión
Descubre las sorprendentes mejoras de Angular 11 y desata todo tu potencial en el desarrollo web. ¡Entra ahora y sé parte de la revolución!
Tabla de contenido
¿Qué es el Testing en Angular?
¿Por qué es Importante el Testing?
Herramientas de Testing en Angular
Jasmine
Karma
Configuración Inicial
Instalar Angular CLI
¿Cómo Configurar Jasmine y Karma?
Estructura de un Proyecto Angular con Testing
Tipos de Pruebas en Angular
Pruebas Unitarias
Pruebas de Integración
Pruebas End-to-End (E2E)
Buenas Prácticas en Testing
Estrategias de Testing
Mantenimiento y Actualización de Pruebas
¿Cómo Aprender Angular como un Experto?
Descubre la formación a tu medida
Rellena el formulario para obtener más información sobre los cursos.
Tamaño de la empresa *
Términos y condiciones *