CursosEmpresasBlogLiveConfPrecios

Trend Metric

Clase 15 de 27 • Curso de Performance Testing en Node.js con K6

Clase anteriorSiguiente clase

Contenido del curso

Introducción al performance testing

  • 1
    ¿Por qué hacemos testing?

    ¿Por qué hacemos testing?

    05:14 min
  • 2
    ¿Cuándo necesitamos performance testing?

    ¿Cuándo necesitamos performance testing?

    03:18 min
  • 3
    Performance testing en front-end: Lighthouse y WebPageTest

    Performance testing en front-end: Lighthouse y WebPageTest

    08:59 min
  • 4
    Performance testing en back-end: K6

    Performance testing en back-end: K6

    02:59 min

Creando nuestra suite de tests

  • 5

    Instalación de K6 en Linux, MacOS, Windows y Docker

    00:58 min
  • 6
    Crea tu primer test en K6 e interpreta los resultados

    Crea tu primer test en K6 e interpreta los resultados

    06:27 min
  • 7
    Opciones, stages y virtual users

    Opciones, stages y virtual users

    08:31 min
  • 8
    Smoke testing, stress testing y spike testing

    Smoke testing, stress testing y spike testing

    09:47 min
  • 9
    Load testing y soak testing

    Load testing y soak testing

    06:02 min
  • 10

    Ejecución de Tests Masivos en Local con K6

    01:26 min
  • 11
    Exportando los resultados

    Exportando los resultados

    05:50 min

Custom Metrics

  • 12
    Counter Metric

    Counter Metric

    08:52 min
  • 13
    Gauge Metric

    Gauge Metric

    09:24 min
  • 14
    Rate Metric

    Rate Metric

    05:26 min
  • 15
    Trend Metric

    Trend Metric

    Viendo ahora

Criterios de aceptación

  • 16
    Checks Y Thresholds

    Checks Y Thresholds

    07:35 min
  • 17
    Opciones de los Thresholds

    Opciones de los Thresholds

    07:04 min

Visualizando resultados

  • 18
    Dashboard de resultados

    Dashboard de resultados

    04:10 min
  • 19
    Creando nuestro dashboard local

    Creando nuestro dashboard local

    05:25 min

Ejecución remota y resultados en la nube

  • 20
    Testing en la nube

    Testing en la nube

    04:40 min
  • 21
    Enviando resultados a K6 Cloud

    Enviando resultados a K6 Cloud

    06:54 min
  • 22
    Ejecutando tests en K6 Cloud

    Ejecutando tests en K6 Cloud

    07:45 min

Bonus: Integraciones de K6

  • 23
    Conoce todas las integraciones de K6

    Conoce todas las integraciones de K6

    03:05 min
  • 24
    Creando un dashboard en New Relic

    Creando un dashboard en New Relic

    11:58 min
  • 25
    Integrando tus test a un flujo de trabajo profesional

    Integrando tus test a un flujo de trabajo profesional

    10:55 min
  • 26
    Performance test en CI/CD

    Performance test en CI/CD

    12:18 min

Despedida

  • 27
    ¿Con qué puedes continuar tu aprendizaje?

    ¿Con qué puedes continuar tu aprendizaje?

    01:28 min
Tomar examen
    Gerardo Alberto Soto Alvarez del Castillo

    Gerardo Alberto Soto Alvarez del Castillo

    student•
    hace 3 años

    Esta fue mi solución:

    import http from "k6/http"; import { Counter, Trend } from "k6/metrics"; export const options = { vus: 10, duration: '20s' } const categoriesCounter = new Counter("_categories_counter"); const categoriesTrend = new Trend("_categories_trend") const productsCounter = new Counter("_products_counter"); const productsTrend = new Trend("_products_Trend"); const usersCounter = new Counter("_users_counter"); const usersTrend = new Trend("_users_trend"); export default function(){ let randomRequest = parseInt(Math.random()*3); if (randomRequest === 0){ let requestCategories = http.get('https://api.escuelajs.co/api/v1/categories'); categoriesCounter.add(1); categoriesTrend.add(requestCategories.timings.duration); } else if (randomRequest === 1) { let requestProducts = http.get('https://api.escuelajs.co/api/v1/products'); productsCounter.add(1); productsTrend.add(requestProducts.timings.duration); } else { let requestUsers = http.get('https://api.escuelajs.co/api/v1/users'); usersCounter.add(1); usersTrend.add(requestUsers.timings.duration); }; };

    Salida:

    salida_trend_counter_K6.png

    Facundo Carroz

    Facundo Carroz

    student•
    hace 3 años

    Hola 🖐. Les dejo mi solución al reto.

    import http from 'k6/http'; import { Trend } from 'k6/metrics'; export const options = { vus: 10, duration: '20s' } const productsCalled = new Trend("products_called"); const categoriesCalled = new Trend("categories_called"); const usersCalled = new Trend("users_called"); export default function(){ const randomEndpoint = random(0, 2);// Return random value between 0 and 2 let selectedEndpoint; switch(randomEndpoint){ case 0: selectedEndpoint = "products"; productsCalled.add(1); categoriesCalled.add(0); usersCalled.add(0); break; case 1: selectedEndpoint = "categories"; productsCalled.add(0); categoriesCalled.add(1); usersCalled.add(0); break; case 2: selectedEndpoint = "users"; productsCalled.add(0); categoriesCalled.add(0); usersCalled.add(1); break; } const response = http.get("https://api.escuelajs.co/api/v1/" + selectedEndpoint); } function random(min, max) { return Math.floor((Math.random() * (max - min + 1)) + min); }
    manuel pineda

    manuel pineda

    student•
    hace 3 años

    Hola, adjunto mi solucion:

    import { Counter, Trend } from 'k6/metrics'; import http from 'k6/http'; import { randomIntBetween } from 'https://jslib.k6.io/k6-utils/1.4.0/index.js'; export const options = { stages: [{ duration: '10s', target: 10 }] }; const endpoints = [ { url: 'https://api.escuelajs.co/api/v1/products', counter: new Counter('product calls'), trend: new Trend('http_req_products') }, { url: 'https://api.escuelajs.co/api/v1/categories', counter: new Counter('categories calls'), trend: new Trend('http_req_categories') }, { url: 'https://api.escuelajs.co/api/v1/users', counter: new Counter('users calls'), trend: new Trend('http_req_users') }, ] export default function () { const number = randomIntBetween(0, 2); const { url, counter, trend } = endpoints[number]; const res = http.get(url); counter.add(1); trend.add(res.timings.duration); }```
    CRISTIAN DAVID ARENAS GOMEZ

    CRISTIAN DAVID ARENAS GOMEZ

    student•
    hace 3 años

    Aqui les comparto la solucion al reto.

    import http from 'k6/http'; // Importa el módulo http de K6 para hacer peticiones HTTP import { Trend } from 'k6/metrics'; // Importa el módulo Trend de K6 para registrar métricas export const options = { // Configura las opciones de la prueba vus: 10, // Especifica el número de usuarios virtuales concurrentes que realizarán la prueba duration: '20s' // Especifica la duración de la prueba } const products = new Trend('products'); // Crea un objeto de tipo Trend para registrar la cantidad de solicitudes realizadas para productos const category = new Trend('categories'); // Crea un objeto de tipo Trend para registrar la cantidad de solicitudes realizadas para categorías const users = new Trend('users'); // Crea un objeto de tipo Trend para registrar la cantidad de solicitudes realizadas para usuarios export default function testEcommerceAPI() { // Define la función principal que realizará la prueba const randomEndpoint = random(0, 2); // Genera un número aleatorio entre 0 y 2 para elegir un endpoint aleatorio let endpoint; // Declara una variable para almacenar el endpoint elegido switch (randomEndpoint) { // Usa una estructura switch para asignar el endpoint elegido y registrar la solicitud correspondiente en las métricas case 0: // Si se elige el endpoint 0 endpoint = 'products'; // Asigna el valor 'products' a la variable endpoint products.add(1); // Registra una solicitud para productos en las métricas category.add(0); // Registra una solicitud para categorías en las métricas users.add(0); // Registra una solicitud para usuarios en las métricas break; case 1: // Si se elige el endpoint 1 endpoint = 'categories'; // Asigna el valor 'categories' a la variable endpoint products.add(0); // Registra una solicitud para productos en las métricas category.add(1); // Registra una solicitud para categorías en las métricas users.add(0); // Registra una solicitud para usuarios en las métricas break; case 2: // Si se elige el endpoint 2 endpoint = 'users'; // Asigna el valor 'users' a la variable endpoint products.add(0); // Registra una solicitud para productos en las métricas category.add(0); // Registra una solicitud para categorías en las métricas users.add(1); // Registra una solicitud para usuarios en las métricas break; default: // Si no se elige ningún endpoint break; } console.log(`Endpoint: ${endpoint}`); // Imprime el endpoint elegido en la consola function random(min, max) { // Define una función que genera un número aleatorio entre un rango dado return Math.floor((Math.random() * (max - min + 1)) + min); } }
    William Schnaider Torres Bermon

    William Schnaider Torres Bermon

    student•
    hace 3 años

    K6 documentation

    Mateo Andrés Piana

    Mateo Andrés Piana

    student•
    hace un año

    Mi solución:

    import http from "k6/http"; import { Counter, Trend } from 'k6/metrics' export const options = { vus: 10, duration: "20s" } const productsCounter = new Counter("called_products") const categoriesCounter = new Counter("called_categories") const usersCounter = new Counter("called_users") const productsTrend = new Trend("called_products") const categoriesTrend = new Trend("called_categories") const usersTrend = new Trend("called_users") export default function () { const randomNumber = Math.floor(Math.random() * 3) const urls = [ "https://api.escuelajs.co/api/v1/products", "https://api.escuelajs.co/api/v1/categories", "https://api.escuelajs.co/api/v1/users" ] const counters = [ productsCounter, categoriesCounter, usersCounter ] const trends = [ productsTrend, categoriesTrend, usersTrend ] let _ = http.get(urls[randomNumber]) counters[randomNumber].add(1) trends[randomNumber].add(1) }
      Mateo Andrés Piana

      Mateo Andrés Piana

      student•
      hace un año

      Se asigna el nombre "_" a la variable para hacer referencia a que no se va a utilizar.

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