CursosEmpresasBlogLiveConfPrecios

Pruebas con componente padre

Clase 10 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

    15:32 min
  • 10
    Pruebas con componente padre

    Pruebas con componente padre

    Viendo ahora
  • 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
    • Armando Rivera

      Armando Rivera

      student•
      hace 4 años

      Comparto mi solución del reto

      it('should show a selected person', () => { // Arrange const personList = [ new Person('Peter', 'Parker', 24, 70, 1.7), new Person('Armando', 'Rivera', 24, 80, 1.8), new Person('Bruce', 'Wayne', 24, 80, 1.8), ]; component.personList = personList; // Act fixture.detectChanges(); const debugButtonList = fixture.debugElement.queryAll( By.css('app-person .btn-choose') ); debugButtonList[0].triggerEventHandler('click', null); fixture.detectChanges(); const debugPersonSelectedInfo = fixture.debugElement.queryAll( By.css('.selectedPerson ul li') ); // Assert expect(debugPersonSelectedInfo[0].nativeElement.textContent).toContain( personList[0].name ); expect(debugPersonSelectedInfo[1].nativeElement.textContent).toContain( personList[0].age ); });
      David Alexander Castiblanco Flórez

      David Alexander Castiblanco Flórez

      student•
      hace 2 años

      Si estás haciendo testing sobre una version de Angular >17, hay que adicionarle un override, para que la función de detección de cambios tome efecto:beforeEach(async () => {        await TestBed.configureTestingModule({            imports: [                PeopleComponent            ]        })        .overrideComponent(PeopleComponent, {            set: { changeDetection: ChangeDetectionStrategy.Default }        })        .compileComponents();    });

      beforeEach(async () => { await TestBed.configureTestingModule({ imports: [ PeopleComponent ] }) .overrideComponent(PeopleComponent, { set: { changeDetection: ChangeDetectionStrategy.Default } }) .compileComponents(); });
      Jorge Luis Silva Medina

      Jorge Luis Silva Medina

      student•
      hace 3 años

      Mejorandolo un poco para que sea el nombre dinámico

      it('sould render selected person after choose person', () => { // Arrange component.people = [ new Person('Jorge', 'Medina', 25, 67.2, 1.81), new Person('Glenda', 'López', 24, 62, 1.75), new Person('Mariana', 'López', 5, 30, 1.4), ]; const personName = component.people[0].name; const expectMsg = Name: ${personName}; // Act fixture.detectChanges(); const personDebug = fixture.debugElement.query(By.css('app-person')); const btnDebug = personDebug.query(By.css('.btn-choose')); btnDebug.triggerEventHandler('click', null); fixture.detectChanges(); const liNameEl: HTMLElement = fixture.debugElement.query( By.css('div ul li') ).nativeElement; // Assert expect(component.selectedPerson).toEqual(component.people[0]); expect(liNameEl?.textContent).toEqual(expectMsg); });

      Jessica Silvia Payano Castro

      Jessica Silvia Payano Castro

      student•
      hace 9 meses

      Este es mi desarrollo:

      it('should render the person with click and show selected person', ()=>{ // Arrange const buttonDebug = fixture.debugElement.queryAll(By.css('app-person .button-choose')); // Act buttonDebug.forEach((btn, index) => { btn.triggerEventHandler('click', null); fixture.detectChanges(); const selectedPerson = component.selectedPerson; const nameDebug = fixture.debugElement.query(By.css('.name')); const nameElement = nameDebug.nativeElement; const ageDebug = fixture.debugElement.query(By.css('.age')); const ageElement = ageDebug.nativeElement; // Assert expect(nameElement.textContent).toContain(selectedPerson?.name) expect(ageElement.textContent).toContain(selectedPerson?.age) expect(selectedPerson).toEqual(component.people[index]); }) })
      Ana Velez Ossa

      Ana Velez Ossa

      student•
      hace 2 años

      Este fue mi resultado:

      it('should render selected person after choosing person', () => { // Configuración del componente con una lista de personas component.people = [ new Person('Ana', 'Velez', 29, 58, 1.68), new Person('Marisol', 'Nieto', 29, 60, 1.72), new Person('Santiago', 'Ossa', 25, 90, 1.62), new Person('Eladio', 'Velez', 25, 90, 1.62) ]; // Texto esperado después de seleccionar una persona const expectedContent = 'Name: Ana'; // Detectar cambios en el componente fixture.detectChanges(); // Encontrar el botón de elección para la primera persona (Ana) const chooseButton = fixture.debugElement.query(By.css('app-person .btn-choose')); // Simular el evento de clic en el botón chooseButton.triggerEventHandler('click', null); // Detectar cambios en el componente después del clic fixture.detectChanges(); // Encontrar el elemento que muestra la persona seleccionada const selectedPersonElement: HTMLElement = fixture.debugElement.query(By.css('li')).nativeElement; // Verificar que la persona seleccionada es la primera persona (Ana) expect(component.selectedPerson).toEqual(component.people[0]); // Verificar que el contenido del elemento seleccionado contiene el nombre esperado expect(selectedPersonElement.textContent).toContain(expectedContent); });
      Carlos Alejandro Hernández Mejía

      Carlos Alejandro Hernández Mejía

      student•
      hace 3 años

      Mi solución usando faker.js para generar a las personas:

      it('should change the selected person when a person is selected', () => { // Arrange component.people = generateManyPeople(3); fixture.detectChanges(); const personDebugElements = fixture.debugElement.queryAll(By.directive(PersonComponent)); const firstPerson = personDebugElements[0]; const personComponent = firstPerson.componentInstance as PersonComponent; const firstButtonDebugElement = firstPerson.query(By.css('button[name="selectPerson"]')); // Act firstButtonDebugElement.triggerEventHandler('click', null); fixture.detectChanges(); // Assert expect(component.selectedPerson).toBe(personComponent.person); });
      Jorge Luis Silva Medina

      Jorge Luis Silva Medina

      student•
      hace 3 años

      Comparto mi monstrito

      it('sould render selected person after choose person', () => { // Arrange const expectMsg = 'Name: Jorge'; component.people = [ new Person('Jorge', 'Medina', 25, 67.2, 1.81), new Person('Glenda', 'López', 24, 62, 1.75), new Person('Mariana', 'López', 5, 30, 1.4), ]; // Act fixture.detectChanges(); const personDebug = fixture.debugElement.query(By.css('app-person')); const btnDebug = personDebug.query(By.css('.btn-choose')); btnDebug.triggerEventHandler('click', null); fixture.detectChanges(); const liNameEl: HTMLElement = fixture.debugElement.query( By.css('div ul li') ).nativeElement; // Assert expect(component.selectedPerson).toEqual(component.people[0]); expect(liNameEl?.textContent).toEqual(expectMsg); });
      Brayam Esteban Quiñones Sanchez

      Brayam Esteban Quiñones Sanchez

      student•
      hace 3 años

      Mi solucon usando un spy para verificar que se llem el metodo de asignacion de person

      it('should render a person selected from app-person', () => { //Arrange component.people = [ new Person('Esteban', 'Qs', 27, 89, 1.77), new Person('Valentin', 'Feregrino', 12, 2, 3), new Person('Antoio', 'Feregrino', 12, 2, 3), ]; const spy = spyOn(component, 'choose').and.callThrough(); //Act fixture.detectChanges(); const peopleDebug = fixture.debugElement.queryAll(By.css('app-person')); peopleDebug[1].query(By.css('button.btn-choose')).triggerEventHandler('click', null); fixture.detectChanges(); const renderPersonList = fixture.debugElement.queryAll(By.css('li')); //Assert expect(spy).toHaveBeenCalled(); expect(renderPersonList[0].nativeElement.textContent).toContain(component.people[1].name); expect(renderPersonList[1].nativeElement.textContent).toContain(component.people[1].age); });

    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