CursosEmpresasBlogLiveConfPrecios

Pruebas aisladas al componente

Clase 9 de 23 • Curso de Angular: Unit Testing para Componentes

Clase anteriorSiguiente clase

Contenido del curso

Introducción

  • 1
    Unit Testing en Angular para Componentes

    Unit Testing en Angular para Componentes

    01:24 min
  • 2
    Creando el proyecto

    Creando el proyecto

    04:29 min
  • 3
    Primera prueba

    Primera prueba

    17:28 min

Componentes

  • 4
    Creando un componente & nativeElement

    Creando un componente & nativeElement

    15:45 min
  • 5
    DebugElement & ByCss

    DebugElement & ByCss

    09:58 min
  • 6
    Componentes con Inputs

    Componentes con Inputs

    14:06 min
  • 7
    Simulando el clic

    Simulando el clic

    15:08 min
  • 8
    Componentes con Outputs

    Componentes con Outputs

    08:01 min
  • 9
    Pruebas aisladas al componente

    Pruebas aisladas al componente

    Viendo ahora
  • 10
    Pruebas con componente padre

    Pruebas con componente padre

    15:43 min
  • 11
    Resolviendo el reto

    Resolviendo el reto

    10:32 min

Componentes con dependencias

  • 12
    Proyecto: creando product component

    Proyecto: creando product component

    05:22 min
  • 13
    Componentes con dependencias

    Componentes con dependencias

    13:36 min
  • 14
    Pruebas a getAllProducts

    Pruebas a getAllProducts

    15:09 min
  • 15
    FakeAsync and tick

    FakeAsync and tick

    17:16 min
  • 16
    Pruebas a promesas

    Pruebas a promesas

    09:32 min
  • 17
    Promesas simulando click

    Promesas simulando click

    08:23 min

Directivas

  • 18
    Creando la Directiva

    Creando la Directiva

    10:11 min
  • 19
    Pruebas a Directiva

    Pruebas a Directiva

    14:25 min
  • 20
    Directiva con ngModel

    Directiva con ngModel

    09:22 min

Pipes

  • 21
    Creando pipe

    Creando pipe

    07:37 min
  • 22
    Testing pipes

    Testing pipes

    14:51 min

Próximos pasos

  • 23
    Continúa con el Curso de Testing en Formularios y Routing

    Continúa con el Curso de Testing en Formularios y Routing

    00:56 min
  • Tomar el examen del curso
    • Jean Pool Zambrano Hernandez

      Jean Pool Zambrano Hernandez

      student•
      hace 2 años

      Si están usando Angular 17, deben crear el componente Host de la siguiente manera: @Component({  standalone: true,  imports: [PersonComponent],  template: `<app-person [person]="person" (onSelected)="onSelected($event)"></app-person>`})export class HostComponent {  person = new Person('Santiago', 'Molina', 13, 40, 1.5);  selectedPerson: Person | undefined;   onSelected(person: Person) {    this.selectedPerson = person;  }}

      Cesar Elías Armendariz Ruano

      Cesar Elías Armendariz Ruano

      student•
      hace 4 años

      Esto es muy util cuando el componente tiene varios inputs y outputs por lo que estos componentes tienen ese comportamiento necesitan un padre para comprobar que este componente cumple con su función

      person.component.spec.ts

      fdescribe('PersonComponent from HostComponent', () => {   let component: HostComponent;   let fixture: ComponentFixture<HostComponent>;   beforeEach(async () => {     await TestBed.configureTestingModule({       declarations: [ HostComponent, PersonComponent ]     })     .compileComponents();   });   beforeEach(() => {     fixture = TestBed.createComponent(HostComponent);     component = fixture.componentInstance;     fixture.detectChanges();   });   it('should create', () => {     expect(component).toBeTruthy();   });   it('should display person name', () => {     // Arrange     const expectName = component.person.name;     const h3De = fixture.debugElement.query(By.css('app-person h3'));     const h3El = h3De.nativeElement;     // Act     fixture.detectChanges();     // Assert     expect(h3El.textContent).toContain(expectName);   });   it('should raise selected event when do click', () => {     // Arrange     const btnDe = fixture.debugElement.query(By.css('app-person .btn-choose'));     // Act     btnDe.triggerEventHandler('click', null);     fixture.detectChanges();     // Assert     expect(component.selectedPerson).toEqual(component.person);   }) })
      Carlos Alejandro Hernández Mejía

      Carlos Alejandro Hernández Mejía

      student•
      hace 3 años

      Pruebas aisladas al componente


      💡 Las pruebas aisladas entre componentes son pruebas que se realizan sobre un componente sin tener en cuenta sus dependencias o componentes hijos.
      Normalmente, los componentes que poseen varios @Inputs (u @Outputs) se usan cómo hijos de otros componentes más grandes. En estos casos, es necesario ejecutar pruebas aisladas para verificar el comportamiento y la lógica del componente en sí, sin tener en cuenta cómo interactúa con otros componentes o servicios.
      Para hacer pruebas aisladas, puedes seguir los siguientes pasos:

      1. Definir un HostComponent que instancie a tu componente hijo:

        @Component({ template: ` <app-child [input]="value" (onEvent)="onEventHandler($event)"> </app-child> `, }) export class HostComponent { value = 'myValue'; onEventHandler(value: string): void { // do something with the value } }
      2. Defina un conjunto de pruebas aisladas para HostComponent y configure el entorno de pruebas para el mismo.

        describe('ChildComponent from HostComponent', () => { let hostComponent: HostComponent; let fixture: ComponentFixture<HostComponent>; beforeEach(async () => { await TestBed.configureTestingModule({ declarations: [HostComponent, ChildComponent], }).compileComponents(); fixture = TestBed.createComponent(HostComponent); hostComponent = fixture.componentInstance; fixture.detectChanges(); }); it('should create a HostComponent', () => { expect(hostComponent).toBeTruthy(); }); // Test for the next step });
      3. Escriba su conjunto de pruebas para el componente hijo. Por ejemplo

        describe('Tests for the Child Component', () => { let childDebugElement : DebugElement; beforeEach(() => { childDebugElement = fixture.debugElement.query(By.directive(ChildComponent)); }); it('should have a ChildComponent', () => { expect(childDebugElement.componentInstance).toBeTruthy(); }); it('should have a ChildComponent with the value as HostComponent', () => { expect(childDebugElement.componentInstance.input).toEqual(hostComponent.value); }); it('should emit an event when do click', () => { // Arrange const button: DebugElement = childDebugElement.query(By.css('button[name="buttonName"]')); const onChildEventSpy= spyOn(childDebugElement.componentInstance, 'onEvent').and.callThrough(); const onEventHandlerSpy= spyOn(hostComponent, 'onEventHandler').and.callThrough(); // Act button.triggerEventHandler('click', null); // Assert expect(onChildEventSpy).toHaveBeenCalled(); expect(onEventHandlerSpy).toHaveBeenCalled(); }); // Another test cases });
      Franklin Gil

      Franklin Gil

      student•
      hace 3 años

      El objetivo de un HostComponente es probar los input y outputs de un componente chiquito. Aislarlo de la logica general del componente padre.

    Escuelas

    • Desarrollo Web
      • Fundamentos del Desarrollo Web Profesional
      • Diseño y Desarrollo Frontend
      • Desarrollo Frontend con JavaScript
      • Desarrollo Frontend con Vue.js
      • Desarrollo Frontend con Angular
      • Desarrollo Frontend con React.js
      • Desarrollo Backend con Node.js
      • Desarrollo Backend con Python
      • Desarrollo Backend con Java
      • Desarrollo Backend con PHP
      • Desarrollo Backend con Ruby
      • Bases de Datos para Web
      • Seguridad Web & API
      • Testing Automatizado y QA para Web
      • Arquitecturas Web Modernas y Escalabilidad
      • DevOps y Cloud para Desarrolladores Web
    • English Academy
      • Inglés Básico A1
      • Inglés Básico A2
      • Inglés Intermedio B1
      • Inglés Intermedio Alto B2
      • Inglés Avanzado C1
      • Inglés para Propósitos Específicos
      • Inglés de Negocios
    • Marketing Digital
      • Fundamentos de Marketing Digital
      • Marketing de Contenidos y Redacción Persuasiva
      • SEO y Posicionamiento Web
      • Social Media Marketing y Community Management
      • Publicidad Digital y Paid Media
      • Analítica Digital y Optimización (CRO)
      • Estrategia de Marketing y Growth
      • Marketing de Marca y Comunicación Estratégica
      • Marketing para E-commerce
      • Marketing B2B
      • Inteligencia Artificial Aplicada al Marketing
      • Automatización del Marketing
      • Marca Personal y Marketing Freelance
      • Ventas y Experiencia del Cliente
      • Creación de Contenido para Redes Sociales
    • Inteligencia Artificial y Data Science
      • Fundamentos de Data Science y AI
      • Análisis y Visualización de Datos
      • Machine Learning y Deep Learning
      • Data Engineer
      • Inteligencia Artificial para la Productividad
      • Desarrollo de Aplicaciones con IA
      • AI Software Engineer
    • Ciberseguridad
      • Fundamentos de Ciberseguridad
      • Hacking Ético y Pentesting (Red Team)
      • Análisis de Malware e Ingeniería Forense
      • Seguridad Defensiva y Cumplimiento (Blue Team)
      • Ciberseguridad Estratégica
    • Liderazgo y Habilidades Blandas
      • Fundamentos de Habilidades Profesionales
      • Liderazgo y Gestión de Equipos
      • Comunicación Avanzada y Oratoria
      • Negociación y Resolución de Conflictos
      • Inteligencia Emocional y Autogestión
      • Productividad y Herramientas Digitales
      • Gestión de Proyectos y Metodologías Ágiles
      • Desarrollo de Carrera y Marca Personal
      • Diversidad, Inclusión y Entorno Laboral Saludable
      • Filosofía y Estrategia para Líderes
    • Diseño de Producto y UX
      • Fundamentos de Diseño UX/UI
      • Investigación de Usuarios (UX Research)
      • Arquitectura de Información y Usabilidad
      • Diseño de Interfaces y Prototipado (UI Design)
      • Sistemas de Diseño y DesignOps
      • Redacción UX (UX Writing)
      • Creatividad e Innovación en Diseño
      • Diseño Accesible e Inclusivo
      • Diseño Asistido por Inteligencia Artificial
      • Gestión de Producto y Liderazgo en Diseño
      • Diseño de Interacciones Emergentes (VUI/VR)
      • Desarrollo Web para Diseñadores
      • Diseño y Prototipado No-Code
    • Contenido Audiovisual
      • Fundamentos de Producción Audiovisual
      • Producción de Video para Plataformas Digitales
      • Producción de Audio y Podcast
      • Fotografía y Diseño Gráfico para Contenido Digital
      • Motion Graphics y Animación
      • Contenido Interactivo y Realidad Aumentada
      • Estrategia, Marketing y Monetización de Contenidos
    • Desarrollo Móvil
      • Fundamentos de Desarrollo Móvil
      • Desarrollo Nativo Android con Kotlin
      • Desarrollo Nativo iOS con Swift
      • Desarrollo Multiplataforma con React Native
      • Desarrollo Multiplataforma con Flutter
      • Arquitectura y Patrones de Diseño Móvil
      • Integración de APIs y Persistencia Móvil
      • Testing y Despliegue en Móvil
      • Diseño UX/UI para Móviles
    • Diseño Gráfico y Arte Digital
      • Fundamentos del Diseño Gráfico y Digital
      • Diseño de Identidad Visual y Branding
      • Ilustración Digital y Arte Conceptual
      • Diseño Editorial y de Empaques
      • Motion Graphics y Animación 3D
      • Diseño Gráfico Asistido por Inteligencia Artificial
      • Creatividad e Innovación en Diseño
    • Programación
      • Fundamentos de Programación e Ingeniería de Software
      • Herramientas de IA para el trabajo
      • Matemáticas para Programación
      • Programación con Python
      • Programación con JavaScript
      • Programación con TypeScript
      • Programación Orientada a Objetos con Java
      • Desarrollo con C# y .NET
      • Programación con PHP
      • Programación con Go y Rust
      • Programación Móvil con Swift y Kotlin
      • Programación con C y C++
      • Administración Básica de Servidores Linux
    • Negocios
      • Fundamentos de Negocios y Emprendimiento
      • Estrategia y Crecimiento Empresarial
      • Finanzas Personales y Corporativas
      • Inversión en Mercados Financieros
      • Ventas, CRM y Experiencia del Cliente
      • Operaciones, Logística y E-commerce
      • Gestión de Proyectos y Metodologías Ágiles
      • Aspectos Legales y Cumplimiento
      • Habilidades Directivas y Crecimiento Profesional
      • Diversidad e Inclusión en el Entorno Laboral
      • Herramientas Digitales y Automatización para Negocios
    • Blockchain y Web3
      • Fundamentos de Blockchain y Web3
      • Desarrollo de Smart Contracts y dApps
      • Finanzas Descentralizadas (DeFi)
      • NFTs y Economía de Creadores
      • Seguridad Blockchain
      • Ecosistemas Blockchain Alternativos (No-EVM)
      • Producto, Marketing y Legal en Web3
    • Recursos Humanos
      • Fundamentos y Cultura Organizacional en RRHH
      • Atracción y Selección de Talento
      • Cultura y Employee Experience
      • Gestión y Desarrollo de Talento
      • Desarrollo y Evaluación de Liderazgo
      • Diversidad, Equidad e Inclusión
      • AI y Automatización en Recursos Humanos
      • Tecnología y Automatización en RRHH
    • Finanzas e Inversiones
      • Fundamentos de Finanzas Personales y Corporativas
      • Análisis y Valoración Financiera
      • Inversión y Mercados de Capitales
      • Finanzas Descentralizadas (DeFi) y Criptoactivos
      • Finanzas y Estrategia para Startups
      • Inteligencia Artificial Aplicada a Finanzas
      • Domina Excel
      • Financial Analyst
      • Conseguir trabajo en Finanzas e Inversiones
    • Startups
      • Fundamentos y Validación de Ideas
      • Estrategia de Negocio y Product-Market Fit
      • Desarrollo de Producto y Operaciones Lean
      • Finanzas, Legal y Fundraising
      • Marketing, Ventas y Growth para Startups
      • Cultura, Talento y Liderazgo
      • Finanzas y Operaciones en Ecommerce
      • Startups Web3 y Blockchain
      • Startups con Impacto Social
      • Expansión y Ecosistema Startup
    • Cloud Computing y DevOps
      • Fundamentos de Cloud y DevOps
      • Administración de Servidores Linux
      • Contenerización y Orquestación
      • Infraestructura como Código (IaC) y CI/CD
      • Amazon Web Services
      • Microsoft Azure
      • Serverless y Observabilidad
      • Certificaciones Cloud (Preparación)
      • Plataforma Cloud GCP

    Platzi y comunidad

    • Platzi Business
    • Live Classes
    • Lanzamientos
    • Executive Program
    • Trabaja con nosotros
    • Podcast

    Recursos

    • Manual de Marca

    Soporte

    • Preguntas Frecuentes
    • Contáctanos

    Legal

    • Términos y Condiciones
    • Privacidad
    • Tyc promociones
    Reconocimientos
    Reconocimientos
    Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
    Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
    Logo reconocimientoPrimera Startup EdTech · 2018
    Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
    Logo reconocimientoCEO Mejor Emprendedor del año · 2024
    De LATAM conpara el mundo
    YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads