CursosEmpresasBlogLiveConfPrecios

Promesas

Clase 16 de 25 • Curso de JavaScript Testing con Jest 2019

Clase anteriorSiguiente clase

Contenido del curso

Introducción al curso

  • 1

    ¿Dónde aprender testing con JavaScript?

    00:15 min
  • 2
    Qué son pruebas Unitarias

    Qué son pruebas Unitarias

    05:12 min
  • 3
    Herramientas para pruebas en Javascript

    Herramientas para pruebas en Javascript

    01:09 min

Configuración

  • 4
    ¿Qué es Jest?

    ¿Qué es Jest?

    02:55 min
  • 5
    Instalación y configuración

    Instalación y configuración

    08:02 min
  • 6
    Creando nuestra primera prueba unitaria

    Creando nuestra primera prueba unitaria

    14:04 min

Matchers

  • 7
    Common Matchers / Comparadores Comunes

    Common Matchers / Comparadores Comunes

    07:01 min
  • 8
    Numbers

    Numbers

    13:11 min
  • 9
    Truthness / Verdadero

    Truthness / Verdadero

    15:05 min
  • 10
    Arrays

    Arrays

    11:53 min
  • 11
    Coverage

    Coverage

    07:28 min
  • 12
    Strings

    Strings

    07:26 min
  • 13
    Monitoreo

    Monitoreo

    05:10 min
  • 14
    Setup de pruebas

    Setup de pruebas

    06:30 min

Testing Asynchronous Code

  • 15
    Callbacks

    Callbacks

    07:42 min
  • 16
    Promesas

    Promesas

    Viendo ahora
  • 17
    Reject y resolve

    Reject y resolve

    03:55 min
  • 18
    Async/Await

    Async/Await

    09:35 min
  • 19
    Aplicaciones de testing para Async/Await

    Aplicaciones de testing para Async/Await

    09:06 min

Snapshot Testing

  • 20
    Snapshot Testing

    Snapshot Testing

    12:48 min
  • 21
    Excepciones Snapshot

    Excepciones Snapshot

    08:33 min

Implementando Jest en diferentes Frameworks

  • 22
    Preparar proyecto para trabajar con React JS

    Preparar proyecto para trabajar con React JS

    16:36 min
  • 23
    Preparar proyecto para trabajar con Vue JS

    Preparar proyecto para trabajar con Vue JS

    11:03 min
  • 24
    Preparar proyecto para trabajar con Express JS

    Preparar proyecto para trabajar con Express JS

    11:53 min
  • 25
    Beneficios de las Pruebas Unitarias

    Beneficios de las Pruebas Unitarias

    01:07 min
Tomar examen
Resumen

En esta clase, Vamos a probar las promesas.

Usaremos Axios para hacer una peticion http. La cual nos devuelve una promesa.
npm install --save axios

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
        Carlos Andrés Charris S

        Carlos Andrés Charris S

        student•
        hace 7 años

        Usando async y await

        promise.js

        import axios from 'axios'; export const getDataFromApi = url => axios( url );

        promise.test.js

        import { getDataFromApi } from '../promise'; describe( 'Probando promesas', () => { const url = 'https://rickandmortyapi.com/api/character'; test( 'Realizando una peticion a un API', async ( done ) => { const respuesta = await getDataFromApi( url ); const arreglo = respuesta.data.results; // expect( arreglo ).toHaveLength( 20 ); expect( arreglo.length ).toBeGreaterThan( 21 ); done() } ); } );
        Fredy Bustos

        Fredy Bustos

        student•
        hace 7 años

        ¿Y si lo que quiero es testear es la respuesta, es decir que las keys tengan el valor que espero?

          Jorge Méndez Ortega

          Jorge Méndez Ortega

          student•
          hace 7 años

          para ese caso podrias utilizar

          //expect(JSON a validar).toHaveProperty("nombre del campo"); expect(data).toHaveProperty("results");
        Oney Ortiz Roman

        Oney Ortiz Roman

        student•
        hace 7 años

        Seria correcto hacer lo siguiente

        expect(data).not.toBe(null)

        o hay posibilidad de un falso positivo?

          Oscar Barajas Tavares

          Oscar Barajas Tavares

          Team Platzi•
          hace 7 años

          Puede ser utilizado, pero podria tener ese falso positivo si data fuera null, Hay forma de validar con “toBeNull”

        Ruben Eduardo Acosta Vela

        Ruben Eduardo Acosta Vela

        student•
        hace 7 años

        Si uso fetch para realizar la petición me sale este error:

        Captura de pantalla de 2018-11-17 23-30-56.png

        Mi pregunta es, ¿Cómo corrijo este error, si fetch es una función implícita de js? , no la puedo definir o importar para usarla.

          Omar Gutiérrez Condori

          Omar Gutiérrez Condori

          student•
          hace 7 años

          quizás llamarla con:

          window.fetch

          También si tu navegador es algo antiguo no tenga soporte de ella.

          Ruben Eduardo Acosta Vela

          Ruben Eduardo Acosta Vela

          student•
          hace 7 años

          El error sale en la termina, al ejecutar npm run test, no en el navegador.

        Jesús David Bossa

        Jesús David Bossa

        student•
        hace 7 años

        Y si tenemos funciones que hagan request tipo post, put y delete, y no queremos que se modifiquen datos en la DB?

          Carlos Sampol

          Carlos Sampol

          Team Platzi•
          hace 7 años

          Puedes crear un mock api y no hay necesidad de cambiar datos de la DB

        Luis Felipe Carrasco Galindo

        Luis Felipe Carrasco Galindo

        student•
        hace 7 años

        esto sirve como base para API testing??

          Diego Forero

          Diego Forero

          Team Platzi•
          hace 7 años

          Si, el principio es el mismo.

        Markoz Peña Mendez

        Markoz Peña Mendez

        student•
        hace 6 años

        Esta es mi clase favorita hasta ahora. Esto muy poderoso porque es el inicio de hacer pruebas a API <3

        Michael Merchan

        Michael Merchan

        student•
        hace 5 años

        Usando aync await. en mi caso me toco modificar el archivo .babelrc

        { "presets": [ [ "@babel/preset-env", { "targets": { "node": "current" } } ] ] }

        promise.js

        import axios from 'axios' export const getDataFromApi = async (url)=>{ return await axios.get(url) }

        promise.test.js

        import {getDataFromApi} from './promise' describe('Probando promesas', () => { it('Realizando una peticion a una api', async () => { const api = 'https://rickandmortyapi.com/api/character/' const {data} = await getDataFromApi(api) expect(data.results.length).toBeGreaterThan(0) }) })
        German Gerardo Guerci

        German Gerardo Guerci

        student•
        hace 5 años

        https://jestjs.io/docs/asynchronous

        If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail.

        import { getDataFromApi } from "../promise"; describe('Probando promesas', () => { test('Realizando una petición a una api', () => { const api = 'https://rickandmortyapi.com/api/character/' return getDataFromApi(api).then(data => { expect(data.results.length).toBeGreaterThan(0); }) }) })```
          Edgar Ubaldo

          Edgar Ubaldo

          student•
          hace 5 años

          Yeah, It's a good improvement

        Miguel Angel Reyes Moreno

        Miguel Angel Reyes Moreno

        student•
        hace 5 años

        Axios nos permite hacer peticiones HTTP y nos regresa una promesa. Además tenemos la garantía de que va a funcionar según sea el navegador.

        npm i --save axios No la guardaremos como depedencia de desarrollo porque es algo que sí necesita el proyecto para funcionar correctamente.

        Obtendremos los datos de La API de Rick y Morty

        Ojo: los console.log son solamente para pruebas, no debemos dejar ninguno en nuestros proyectos.

        async hace que una función automáticamente retorne una promesa.

        import axios from 'axios'; export const getDataFromApi = url => axios (url)
        import {getDataFromApi} from './../promise'; describe('Probando promesas', () => { const api = 'https://rickandmortyapi.com/api/character'; test('Realizando petición a una API', () => { async done => { const respuesta = await getDataFromApi(api); const array = respuesta.data.results; expect(array.length).toBeGreaterThan(0); done(); } }); });
          Edgar Ubaldo

          Edgar Ubaldo

          student•
          hace 5 años

          done ( ) is not neccesary call it because using async/await you are returning a promise and is the same thing that you pass ''done" as parameter of test callback and call it

        Usuario anónimo

        Usuario anónimo

        user•
        hace 5 años
        /** promise.js */ import axios from 'axios' export const DataFromApi = (url) => { return axios.get(url) .then(({ data }) => { return data; }); } /** promise.test.js */ import { DataFromApi } from '../js/promise' describe("Probando promesas", () => { test("Realizando una petición a una api", done => { const api = "https://rickandmortyapi.com/api/character"; DataFromApi(api).then(data => { expect(data.results.length).toBeGreaterThan(0); done(); }); }); });
        Santiago Lopera Naranjo

        Santiago Lopera Naranjo

        student•
        hace 5 años

        También podemos probar usando la información que da la respuesta:

        describe('Probando promesas', () => { test('probando api', (done) => { const api = 'https://rickandmortyapi.com/api/character'; getDataFromApi(api).then(data => { console.log(data.info.count) expect(data.info.count).toBeGreaterThan(0) done() }) }) })

        ☝ Esto dado el caso siempre fueramos a usar la misma API

        Sebastian Diaz

        Sebastian Diaz

        student•
        hace 6 años

        Esto seria mas un prueba de integración ?

        Carlos Delgado

        Carlos Delgado

        student•
        hace 6 años

        alguién sabe como podría probar el status code http de la respuesta ?? quiero verificar que la llamada a la API me devuelva un status 200 o si falla entonces un código diferente

          Juan Castro

          Juan Castro

          teacher•
          hace 6 años

          Lo estudiamos en esta clase: https://platzi.com/clases/1357-js-jest/13835-preparar-proyecto-para-trabajar-con-express-js/. :wink:

        JUAN FELIPE CONTRERAS DELGADO

        JUAN FELIPE CONTRERAS DELGADO

        student•
        hace 7 años

        :)

        David Zabaleta Franco

        David Zabaleta Franco

        student•
        hace 6 años

        👍

        Samuel Miranda Martínez

        Samuel Miranda Martínez

        student•
        hace 5 años

        Por cosas de la vida me toco volver a lanzar el comando

        npm init

        Porque estafa fallando la instalación de axios.

        Platzi Team

        Platzi Team

        student•
        hace 5 años

        A Practicar 🔥

        Edgar Lopez Arroyo

        Edgar Lopez Arroyo

        student•
        hace 5 años
        import axios from 'axios'; export function getData(url) { return axios.get(url) .then(({data}) => { return data; }); }
        import { getData } from '../promises'; describe("Probando promesas", ()=>{ test("Haciendo una peticion a una API", done => { const url = 'https://rickandmortyapi.com/api/character/'; getData(url).then(data => { console.log(data.results) expect(data.results.length).toBeGreaterThan(0); done(); }); }); });```