CursosEmpresasBlogLiveConfPrecios

Contenido del curso

Para quién es este curso?

  • 1
    ¿Para quién es este curso?

    ¿Para quién es este curso?

    04:07 min

Conceptos Avanzados

  • 2
    Emulación de dispositivos

    Emulación de dispositivos

    14:26 min
  • 3
    Modo incógnito del navegador

    Modo incógnito del navegador

    03:35 min
  • 4
    Creando helpers de utilidad

    Creando helpers de utilidad

    18:49 min
  • 5
    Capturas de pantalla

    Capturas de pantalla

    11:31 min
  • 6
    Visual Testing

    Visual Testing

    20:46 min
  • 7
    Generando PDFs

    Generando PDFs

    12:12 min
  • 8
    Geolocalización

    Geolocalización

    07:09 min
  • 9
    Probando accesibilidad

    Probando accesibilidad

    11:42 min
  • 10
    Puppeteer con Firefox

    Puppeteer con Firefox

    09:10 min
  • 11
    Medir performance: page load

    Medir performance: page load

    18:36 min
  • 12
    Medir performance: first contentful paint

    Medir performance: first contentful paint

    Viendo ahora

Creando nuestro propio framework

  • 13
    Inicializando nuestro framework

    Inicializando nuestro framework

    14:19 min
  • 14
    Creando la Base Page

    Creando la Base Page

    09:44 min
  • 15
    Page Object Model

    Page Object Model

    23:05 min
  • 16
    Hacer un E2E

    Hacer un E2E

    37:52 min
  • 17
    Agregar reporte

    Agregar reporte

    05:14 min

BDD

  • 18
    BDD y Gherkin

    BDD y Gherkin

    09:39 min
  • 19
    Configurando codeceptjs con Gherkin y BDD

    Configurando codeceptjs con Gherkin y BDD

    08:01 min
  • 20
    Creando una Prueba con Gherkin

    Creando una Prueba con Gherkin

    17:21 min
  • 21
    Creando un Scenario Outline

    Creando un Scenario Outline

    14:13 min
  • 22
    Generando reporte y agregando imágenes al reporte

    Generando reporte y agregando imágenes al reporte

    15:32 min

CI/CD

  • 23
    Configurando Jenkins con nuestras pruebas y creando reportes

    Configurando Jenkins con nuestras pruebas y creando reportes

    16:33 min

Conclusion del curso

  • 24
    Sigue aprendiendo

    Sigue aprendiendo

    02:07 min
Tomar examen

Medir performance: first contentful paint

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

      Comentarios

      Angel Hernandez

      Angel Hernandez

      student
      hace 3 años
      Mario Alexander Vargas Celis

      Mario Alexander Vargas Celis

      student
      hace 2 años
      Jesus Cuadro

      Jesus Cuadro

      student
      hace 3 años

      Increible me gusto mucho ver como se podia hacer el test de los frames por segundo! No sabia que se podian testear ese tipo de cosas.

      const puppeteer = require("puppeteer"); const {AxePuppeteer} = require("@axe-core/puppeteer") describe("first paint y first contentful paint",()=>{ let browser let page beforeAll(async()=>{ browser = await puppeteer.launch({ headless:true, defaultViewport: null, //slowMo: 500 }); page = await browser.newPage(); //await page.goto("https://platzi.com", {waitUntil: "networkidle2"}); },10000); afterAll(async ()=>{ await browser.close(); }); test("Medir el performance del first paint y first contentful paint", async()=>{ const navigationPromise = page.waitForNavigation(); await page.goto("https://platzi.com"); await navigationPromise const firstPaint = JSON.parse( await page.evaluate(()=>JSON.stringify(performance.getEntriesByName("first-paint"))) ); const firstContentfulPaint=JSON.parse( await page.evaluate(()=>JSON.stringify(performance.getEntriesByName("first-contentful-paint"))) ); console.log('firstPaint ', firstPaint[0].startTime) console.log('firstContentfulPaint ', firstContentfulPaint[0].startTime) }, 15000); test("Medir el performance frames por segundos", async()=>{ const devtoolsProtocolClient = await page.target().createCDPSession(); await devtoolsProtocolClient.send("Overlay.setShowFPSCounter",{show:true}); await page.goto("https://platzi.com"); await page.screenshot({path:"framesPorSegundo.jpg", type:"jpeg"}) }, 15000); }) ```const puppeteer = require("puppeteer");const {AxePuppeteer} = require("@axe-core/puppeteer") describe("first paint y first contentful paint",()=>{         let browser        let page            beforeAll(async()=>{            browser = await puppeteer.launch({                headless:true,                defaultViewport: null,                 //slowMo: 500            });             page = await browser.newPage();            //await page.goto("https://platzi.com", {waitUntil: "networkidle2"});         },10000);            afterAll(async ()=>{             await browser.close();         });     test("Medir el performance del first paint y first contentful paint", async()=>{         const navigationPromise = page.waitForNavigation();        await page.goto("https://platzi.com");        await navigationPromise         const firstPaint = JSON.parse(            await page.evaluate(()=>JSON.stringify(performance.getEntriesByName("first-paint")))        );         const firstContentfulPaint=JSON.parse(            await page.evaluate(()=>JSON.stringify(performance.getEntriesByName("first-contentful-paint")))        );        console.log('firstPaint ', firstPaint\[0].startTime)        console.log('firstContentfulPaint ', firstContentfulPaint\[0].startTime)             }, 15000);     test("Medir el performance frames por segundos", async()=>{         const devtoolsProtocolClient = await page.target().createCDPSession();        await devtoolsProtocolClient.send("Overlay.setShowFPSCounter",{show:true});        await page.goto("https://platzi.com");         await page.screenshot({path:"framesPorSegundo.jpg", type:"jpeg"})                }, 15000); })

      Medir el performance con Page Load

      // Importante importar FS para sacar screenshots y extraerlos const fs = require('fs') it('Medir el performance de la automatizacion', async () => { await page.waitForSelector('img') const metrics = await page.metrics() console.log(metrics) }, 350000) it('Medir el performance de la pagina', async () => { await page.waitForSelector('img') const metrics2 = await page.evaluate(() => JSON.stringify(window.performance) ) console.log(metrics2) }, 350000) it('Medir el performance del page load', async () => { await page.tracing.start({ path: 'profile.json' }) await page.goto('https://google.com/') await page.tracing.stop() }, 350000) it('Medir el performance del page load con screenshots', async () => { await page.tracing.start({ path: 'profile.json', screenshots: true }) await page.goto('https://google.com/') await page.tracing.stop() }, 350000) it('Medir el performance del page load con screenshots y extrayendolos', async () => { await page.tracing.start({ path: 'profile.json', screenshots: true }) await page.goto('https://google.com/') await page.tracing.stop() const tracing = JSON.parse(fs.readFileSync('./profile.json', 'utf8')) //Filtrar en JSON const traceScreenShots = tracing.traceEvents.filter( (x)=> x.cat === 'disabled-by-default-devtools.screenshot' && x.name === 'Screenshot' && typeof x.args !== 'undefined' && typeof x.args.snapshot !== 'undefined' ) // Iteramos sobre este arreglo para obtener las imagenes traceScreenShots.forEach(function (snap, index) { fs.writeFile(`trace-screenshot-${index}.png`, snap.args.snapshot, 'base64', function(error){ if (error) { console.error('No pude crear el achivo', error); } }) }); }, 350000)

      Medir el performance con First Contentful Paint

      it('Medir el performance del first paint y first contentful paint', async () => { const navigationPromise = page.waitForNavigation() await page.goto('https://google.com/') await navigationPromise const firstPaint = JSON.parse( await page.evaluate(() => JSON.stringify(performance.getEntriesByName('first-paint')) ) ) const firstContentfulPaint = JSON.parse( await page.evaluate(() => JSON.stringify( performance.getEntriesByName('first-contentful-paint') ) ) ) console.log('firstPaint ', firstPaint[0].startTime) console.log('firstContentfulPaint ', firstContentfulPaint[0].startTime) }, 350000) it('Medir el performance de los frames por segundo', async () => { const devtoolsProtocolClient = await page.target().createCDPSession() await devtoolsProtocolClient.send('Overlay.setShowFPSCounter', { show: true }) await page.goto('https://google.com/') await page.screenshot({ path: 'framesPorSegundo.jpg', type: 'jpeg' }) }, 350000)