CursosEmpresasBlogLiveConfPrecios

Pruebas para PUT y DELETE

Clase 19 de 25 • Curso de Angular: Unit Testing para Servicios

Clase anteriorSiguiente clase

Contenido del curso

Introducción

  • 1
    Unit testing para servicios en Angular

    Unit testing para servicios en Angular

    00:56 min
  • 2
    Jest vs. Jasmine: entornos de testing para Angular

    Jest vs. Jasmine: entornos de testing para Angular

    13:39 min

Fundamentos de unit testing en Angular

  • 3
    Tu primera prueba en Angular

    Tu primera prueba en Angular

    10:03 min
  • 4
    Explorando matchers

    Explorando matchers

    09:46 min
  • 5
    Reporte de coverage

    Reporte de coverage

    10:13 min
  • 6
    Mocha Report

    Mocha Report

    07:42 min

Testing en servicios

  • 7
    Pruebas unitarias para servicios

    Pruebas unitarias para servicios

    15:55 min
  • 8
    Servicios con dependencias

    Servicios con dependencias

    17:52 min
  • 9
    Spies

    Spies

    10:38 min
  • 10
    Angular TestBed

    Angular TestBed

    04:55 min
  • 11
    TestBed + Spies

    TestBed + Spies

    09:21 min

Proyecto

  • 12
    Setup y maquetación del proyecto

    Setup y maquetación del proyecto

    10:55 min
  • 13
    Product Service Http

    Product Service Http

    12:31 min

Testing en consultas HTTP

  • 14
    HttpClientTestingModule

    HttpClientTestingModule

    16:57 min
  • 15
    Generando Mocks

    Generando Mocks

    08:22 min
  • 16
    Pruebas para GET

    Pruebas para GET

    09:10 min
  • 17
    Pruebas maliciosas para GET

    Pruebas maliciosas para GET

    09:54 min
  • 18
    Pruebas para POST

    Pruebas para POST

    13:51 min
  • 19
    Pruebas para PUT y DELETE

    Pruebas para PUT y DELETE

    Viendo ahora

Bonus

  • 20
    Pruebas a errores

    Pruebas a errores

    12:38 min
  • 21
    Pruebas con interceptores

    Pruebas con interceptores

    12:43 min
  • 22
    Pruebas al login

    Pruebas al login

    12:01 min
  • 23
    Pruebas a la API del navegador

    Pruebas a la API del navegador

    14:01 min
  • 24
    GitHub Actions

    GitHub Actions

    21:24 min

Próximos pasos

  • 25
    Toma el Curso de Angular: Unit Testing para Componentes

    Toma el Curso de Angular: Unit Testing para Componentes

    01:04 min
  • Tomar el examen del curso
    • Andrés Quintero Arias

      Andrés Quintero Arias

      student•
      hace 4 años

      Para vs-code cree un snippet sencillo para crear las pruebas:

      • Pulsar Ctrl+Shift+P, y escribir "Configure User Snippets"

      • Seleccionar "New Global Snippets file"

      • escribir "spec.ts"

      • En el nuevo archivo que se abre, pegar lo siguiente:

      "it method":{ "scope": "typescript", "prefix": "test-it", "body": [ "it('${1:description-test}', () => {", "// Arrange", "$2", "// Act", "// Assert", "});" ], "description": "it method" }
      • Guardar y salir. Ahora en los archivos spec.ts al escribir "test-it" seguido de la tecla Tab, aparecerá la porción de códgo
        Adrian Silva

        Adrian Silva

        student•
        hace 2 años

        Excelente, muchas gracias, aprendí a hacer snippets👍

      Armando Rivera

      Armando Rivera

      student•
      hace 4 años

      En el código veo esto

      this.http.delete<boolean>

      Creo que lo correcto sería

      this.http.delete<{ rta: boolean }>

      Ya que así es como responde el DELETE de la API https://api.escuelajs.co/docs/#/products/ProductsController_delete

        Tanelo Mondaca Silva

        Tanelo Mondaca Silva

        student•
        hace 3 años

        No es necesario, ya que el tipado <boolean> indica que la respuesta va a ser un booleano Con eso solo estás colocando código demás

        Armando Rivera

        Armando Rivera

        student•
        hace 3 años

        @taknello <boolean> indica que la respuesta va a ser un booleano, pero la respuesta no es un booleano, es un objeto

        { "rta": true }
      Cesar Elías Armendariz Ruano

      Cesar Elías Armendariz Ruano

      student•
      hace 4 años
      describe('test for update', () => {       it('should return an updated product', (doneFn) => {         // Arrange         const mockData = generateOneProduct();         const id = '1';         const dto: UpdateProductDTO = {           title: 'update Product'         };         // Act         productsService.update(id, {...dto}).subscribe((data) => {           // Assert           expect(data).toEqual(mockData);           doneFn();         });         //http config         const url = `${environment.API_URL}/api/v1/products/${id}`;         const req = httpController.expectOne(url);         req.flush(mockData);         expect(req.request.body).toEqual(dto);         expect(req.request.method).toEqual('PUT');       });   });     describe('test for delete', () => {       it('should delete a product', (doneFn) => {         // Arrange         const id = '1';         // Act         productsService.delete(id).subscribe((data) => {           // Assert           expect(data).toBe(true);           doneFn();         });         //http config         const url = `${environment.API_URL}/api/v1/products/${id}`;         const req = httpController.expectOne(url);         req.flush(true);         expect(req.request.method).toEqual('DELETE');       });   });
      Julian Alejandro

      Julian Alejandro

      student•
      hace 3 años

      ¿Cómo sería una prueba para el siguiente método?

      fetchReadAndUpdate(id: string, dto: UpdateProductDTO) { return zip( this.getOne(id), this.update(id, dto) ); }
        Tanelo Mondaca Silva

        Tanelo Mondaca Silva

        student•
        hace 3 años

        Tienes que hacer mocks de los metodos que estás llamando para que respondan lo que idealmente los métodos reales responderían

      Juan Luna

      Juan Luna

      student•
      hace 3 años

      ¿No se debería crear un producto y luego actualizarlo?

      no se algo como esto:

      fdescribe('test for update', ()=>{ it('should return a product updated, dto should be mutable and http.method is "PUT"', (doneFn)=>{ // ARRANGE const mockData = generateOneProduct(); const cdto: CreateProductDTO = { title: 'New Product', price: 100, images: ['image0', 'image1'], description: 'bal bla bla, bal bla, bla', categoryId: 12 }; const udto: UpdateProductDTO = { title: 'product Updated', price: 200 }; // ACT productsService.create({...cdto}).subscribe(data =>{ // ARRANGE const updated: Product = { id: data.id, title: 'product Updated', price: 200, images: ['image0', 'image1'], description: 'bal bla bla, bal bla, bla', category: { id: 12, name: data.category.name } }; // ASSERT expect(data).toEqual(mockData); productsService.update(data.id, {...udto}).subscribe(dataUpdated => { // ASSERT console.log(dataUpdated); expect(dataUpdated).toEqual(updated); doneFn(); }); // CONFIG const url = `${environment.API_URL}/api/v1/products/${data.id}`; const req = httpController.expectOne(url); req.flush(updated); expect(req.request.body).toEqual(udto); expect(req.request.method).toEqual('PUT'); httpController.verify(); }); // CONFIG const url = `${environment.API_URL}/api/v1/products`; // console.log(url); const req = httpController.expectOne(url); req.flush(mockData); expect(req.request.body).toEqual(cdto); expect(req.request.method).toEqual('POST'); // httpController.verify(); }); });

      yo lo he probado y funciona, mi pregunta es ¿Es necesario hacerlo así o basta como lo hizo el profe Nicolás?

      Jorge Luis Silva Medina

      Jorge Luis Silva Medina

      student•
      hace 3 años

      Exacto la misma estructura pero maneje diferente el método de comparación toBeTrue. Excelente consejo para el spred operator. Ya quiero ver el curso de testing para NestJS

    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