5 Hábitos para Tratar tu Código de Pruebas como Código de Producción

Rate this content
Bookmark

En esta charla, David hablará sobre 5 hábitos que puedes seguir para asegurar la misma calidad que tu código de producción y construir suites de pruebas que sean robustas, consistentes y te ayuden a depurar los problemas rápidamente.

- Viaje típico para equipos que adoptan la automatización de pruebas

- 5 hábitos a seguir al construir tu suite de pruebas

- Nuestros aprendizajes de una actividad reciente de refactorización

This talk has been presented at TestJS Summit 2022, check out the latest edition of this JavaScript Conference.

FAQ

Es crucial tratar el código de prueba con la misma seriedad que el código de producción para asegurar que las pruebas sean manejables, mantenibles y menos propensas a errores, lo que conduce a un software más confiable y de mayor calidad.

Las pruebas unitarias son fundamentales porque deben ser abundantes y ayudan a verificar la funcionalidad de los componentes individuales del código, reduciendo errores y mejorando la estabilidad del software.

Las pruebas de interfaz de usuario, al requerir más integración, tienden a ejecutarse más lentamente. Esto puede ralentizar el proceso de integración continua, que debería completarse idealmente en unos 10 minutos para un ciclo de retroalimentación rápido.

David Burns sugiere hacer pruebas más modulares, donde las pruebas unitarias, de integración y de interfaz de usuario se manejen por separado para aumentar la velocidad y reducir la inestabilidad de las pruebas complejas.

Mantener las dependencias de prueba actualizadas asegura que se aprovechen las nuevas características y mejoras en las herramientas de prueba, contribuyendo a la eficiencia y efectividad del proceso de prueba.

David Burns recomienda utilizar herramientas que mantengan a los desarrolladores y probadores en un 'flujo' consistente, como extensiones en VS Code, para ejecutar pruebas eficientemente sin distracciones y mantener alta la productividad.

David Burns
David Burns
22 min
03 Nov, 2022

Comments

Sign in or register to post your comment.

Video Summary and Transcription

La charla de hoy se centra en los cinco hábitos para tratar el código de pruebas como código de producción. Se enfatiza la importancia de las pruebas modulares y descomponer las pruebas de interfaz de usuario en componentes más pequeños. Tratar a los SDETs como ingenieros de software es crucial para la calidad del código y las pruebas. También se discuten los desafíos de las pruebas de instantáneas y los beneficios de las pruebas de componentes, incluida la mejora de la eficiencia y la solución de problemas de asincronía y promesas anidadas.

1. Introducción

Short description:

Hoy voy a hablar sobre los cinco hábitos para tratar tu código de prueba como lo harías con el código de producción. Mi nombre es David Burns, soy el responsable de la Oficina de Programas de Código Abierto en Browserstack y soy el presidente del grupo de trabajo de pruebas de navegadores y herramientas del W3C. Al final del día, podrás llevar algo contigo y ver cómo puedes reorganizar todo lo que haces en el trabajo para facilitar tu vida.

Hola a todos. Hoy voy a hablar sobre los cinco hábitos para tratar tu código de prueba como lo harías con el código de producción. Así que, en primer lugar, ¿quién soy yo? Mi nombre es David Burns o como la mayoría de la gente me conoce, tester automatizado. Soy el responsable de la Oficina de Programas de Código Abierto en Browserstack. Soy el presidente del grupo de trabajo de pruebas de navegadores y herramientas del W3C. Soy un colaborador de Selenium y Nightwatch JS. Llevo tiempo en esta industria. Y espero que al final del día, puedas llevar algo contigo y ver cómo puedes reorganizar todo lo que haces en el trabajo para facilitar tu vida.

2. Enfoque de las pruebas y la Pirámide de pruebas

Short description:

En esta parte, discutiremos cómo las personas tienden a abordar las pruebas en los proyectos y cómo descomponer las pruebas para que sean manejables, mantenibles y menos propensas a errores. También exploraremos la importancia de tratar el código de prueba como código de producción y mejorar las herramientas. Además, examinaremos la pirámide de pruebas, que incluye pruebas unitarias, pruebas de servicio y pruebas de interfaz de usuario, y el equilibrio entre el aislamiento y la integración. Por último, abordaremos el problema de sobrecargar las pruebas unitarias y los desafíos resultantes para mantenerlas.

Aquí está nuestra agenda. Voy a analizar cómo las personas tienden a ver sus pruebas en los proyectos, cómo podemos descomponer las pruebas para que sean manejables, mantenibles y menos propensas a errores. Esa es la parte más importante. Cómo tratar tu código de prueba como código de producción. Entonces, qué hacemos con la última parte y cómo mejorar tus herramientas y en realidad por qué esto es importante. Te sorprenderás. Así que empecemos y veamos a dónde llegamos.

Ahora, he estado trabajando en pruebas durante muchos, muchos años y tiendo a ver cómo las personas ven las pruebas desde diferentes perspectivas. Y si lo vemos de la manera teórica, así es como deberían hacerlo las personas. En la parte inferior, tenemos aquí la pirámide de pruebas. En la parte inferior, tenemos las pruebas unitarias. La razón por la que eso es importante es porque la razón por la que es más amplia es que siempre debería haber muchas más de ellas que cualquier otro tipo de pruebas en nuestro código de prueba. Luego tenemos las pruebas de servicio. Estas son nuestras pruebas de integración. Estas son todas como si las pruebas unitarias fueran pequeñas, las pruebas de servicio tienden a ser medianas y comienzan a cerrar las brechas entre todos nuestros pequeños componentes de código o áreas atómicas de código. Y nos acerca a la siguiente parte, que son nuestras pruebas de interfaz de usuario. Ahora, una de las cosas que no incluí aquí es la prueba manual. Por lo general, tiendo a hablar sobre las pruebas automatizadas, pero esto no significa que menosprecie las pruebas manuales. Y si observas las flechas en el lateral, verás que en el lado izquierdo, a medida que miro la pantalla, hay más aislamiento y más integración. A medida que subes, necesitarás más integración y menos aislamiento. Sin embargo, el inconveniente de agregar más integración es que las cosas se volverán más lentas. Esto es simplemente ciencia de la computación, ¿verdad? Cuanto más código tenga que procesarse, más lento será, ¿verdad? Si haces un bucle dentro de otro bucle, sabes que será más lento que un solo bucle tratando de encontrar algo. Idealmente, debemos intentar hacer pruebas súper rápidas y muchas menos pruebas lentas. Desafortunadamente, especialmente por lo que veo, y aprecio que pueda haber mucho sesgo, después de haber trabajado en Selenium y NightwatchJS durante muchos, muchos años, es que las personas hacen pruebas unitarias. Estas generalmente son realizadas por tus desarrolladores, y se hacen con jest, Karma o cosas así, y las personas ponen mucho esfuerzo en ellas. Luego comenzarás a tener algunas pruebas de servicio o estas pruebas de integración, y así tomé mi imagen aquí del trabajo de Martin Fowler, y la he reorganizado un poco. Luego, especialmente ahora que veo esto en BrowserStack y hablo con los clientes, y cuando estaba en Mozilla, hablando con usuarios de Selenium, las personas tienden a arrojar todo, y quiero decir todo, a sus pruebas unitarias. Las llenarían, pondrían toneladas de pruebas, y luego, poco a poco, las pruebas se volverían inmantenibles.

QnA

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Despliegue Atómico para Hipsters de JavaScript
DevOps.js Conf 2024DevOps.js Conf 2024
25 min
Despliegue Atómico para Hipsters de JavaScript
This Talk discusses atomic deployment for JavaScript and TypeScript, focusing on automated deployment processes, Git hooks, and using hard links to copy changes. The speaker demonstrates setting up a bare repository, configuring deployment variables, and using the post-receive hook to push changes to production. They also cover environment setup, branch configuration, and the build process. The Talk concludes with tips on real use cases, webhooks, and wrapping the deployment process.
Pruebas de rendimiento efectivas para su servidor con Autocannon
TestJS Summit 2021TestJS Summit 2021
36 min
Pruebas de rendimiento efectivas para su servidor con Autocannon
Top Content
Tamar is an experienced code writer and architect with expertise in Node.js. Performance testing can be confusing, but understanding terms like throughput and the 99th percentile is crucial. The 99th percentile is important for making commitments and ensuring customer satisfaction. AutoCanon is a powerful tool for simulating requests and analyzing server performance. It can be installed globally or used as a library in Node.js. Autocannon is preferred over Gatling for performance testing and can be integrated with end-to-end tests in Cypress.
Pruebas de integración encantadoras con Testcontainers
TestJS Summit 2022TestJS Summit 2022
21 min
Pruebas de integración encantadoras con Testcontainers
Top Content
Testing is crucial for development and production, with integration tests becoming more popular. Test containers is a library that integrates with Docker to create reliable test environments. It is flexible and can be used with various frameworks and test libraries. The IDE setup involves configuring the container and connecting it to the application. Test containers can be used for complex operations and allows running tests with real dependencies.
Regresión Visual con Puppeteer, Playwright y Cypress
TestJS Summit 2021TestJS Summit 2021
9 min
Regresión Visual con Puppeteer, Playwright y Cypress
Top Content
Hello, I'm Rainer Haneckamp, a trainer and consultant at Angular Architects. In this talk, we'll explore visual regression testing using tools like Puppeteer, Playwright, and Cypress. We'll learn how to use Storybook and Puppeteer with Jest for visual regression testing. We'll also see how Jest and Playwright can be used together for visual regression testing. Finally, we'll discover how to use Cypress for visual regression testing. Thank you for watching!
¿Playwright puede hacer esto?
TestJS Summit 2022TestJS Summit 2022
23 min
¿Playwright puede hacer esto?
Playwright is a powerful tool for end-to-end testing, offering support for all major browsers and platforms. It provides features like parallelization, built-in waiting, and assertions. Playwright allows for running tests on multiple browsers with a single command and has functionality for generating tests and performing visual regression testing. It also enables the manipulation of the network layer and loading internals of web pages. Best practices include using short and idempotent scripts, splitting user account flows into separate tests, and cleaning up after each test case.
La Guía del Desarrollador Perezoso: ¿Cómo Automatizar las Actualizaciones de Código?
DevOps.js Conf 2022DevOps.js Conf 2022
22 min
La Guía del Desarrollador Perezoso: ¿Cómo Automatizar las Actualizaciones de Código?
Code automations can save time and effort in development tasks. There are tools and examples available for automating tasks like updating dependencies and code formatting. Automation allows teams to focus on valuable work and improves overall performance. Deciding when to automate depends on the impact and type of code. The last automated task discussed was applying translation updates to multiple projects.

Workshops on related topic

Pruebas automatizadas de accesibilidad con jest-axe y Lighthouse CI
TestJS Summit 2021TestJS Summit 2021
85 min
Pruebas automatizadas de accesibilidad con jest-axe y Lighthouse CI
Workshop
Bonnie Schulkin
Bonnie Schulkin
¿Incluyen tus pruebas automatizadas verificaciones de accesibilidad? Este masterclass cubrirá cómo comenzar con jest-axe para detectar violaciones de accesibilidad basadas en código, y Lighthouse CI para validar la accesibilidad de las páginas completamente renderizadas. Ninguna cantidad de pruebas automatizadas puede reemplazar las pruebas manuales de accesibilidad, pero estas verificaciones se asegurarán de que tus probadores manuales no estén haciendo más trabajo del necesario.
Automatización de pruebas utilizando WebdriverIO
TestJS Summit 2022TestJS Summit 2022
163 min
Automatización de pruebas utilizando WebdriverIO
Workshop
Kevin Lamping
Kevin Lamping
En este masterclass, cubro no solo lo que WebdriverIO puede hacer, sino también cómo lo utilizarás día a día. He construido los ejercicios en torno a escenarios del mundo real que demuestran cómo realmente configurar las cosas. No es solo "qué hacer", sino específicamente "cómo llegar allí". Cubriremos los fundamentos de las pruebas automatizadas de UI para que puedas escribir pruebas mantenibles y útiles para tu sitio web y/o aplicación web.
JS Automatización de Pruebas de Seguridad para Desarrolladores en Cada Compilación
TestJS Summit 2021TestJS Summit 2021
111 min
JS Automatización de Pruebas de Seguridad para Desarrolladores en Cada Compilación
WorkshopFree
Oliver Moradov
Bar Hofesh
2 authors
Como desarrollador, necesitas entregar rápido y simplemente no tienes tiempo para pensar constantemente en seguridad. Aún así, si algo sale mal, es tu trabajo arreglarlo, pero las pruebas de seguridad bloquean tu automatización, crean cuellos de botella y solo retrasan las versiones... pero no tiene por qué ser así...

El escáner de seguridad de NeuraLegion, enfocado en los desarrolladores, Dynamic Application Security Testing (DAST), permite a los desarrolladores detectar, priorizar y remediar problemas de seguridad de manera TEMPRANA, en cada confirmación, sin falsos positivos/alertas, sin ralentizarte.

¡Únete a esta masterclass para aprender diferentes formas en que los desarrolladores pueden acceder a Nexploit y comenzar a escanear sin salir de la terminal!

Recorreremos la configuración de principio a fin, mientras configuramos un pipeline, ejecutamos pruebas de seguridad y analizamos los resultados.

Tabla de contenidos:
- Qué es realmente DAST (Dynamic Application Security Testing) enfocado en los desarrolladores y cómo funciona
- Ver dónde y cómo encaja un DAST moderno y preciso en el CI/CD
- Integrar el escáner Nexploit de NeuraLegion con GitHub Actions
- Comprender cómo se pueden probar las aplicaciones modernas, las API y los mecanismos de autenticación
- Hacer un fork de un repositorio, configurar un pipeline, ejecutar pruebas de seguridad y analizar los resultados
Automatización de pruebas de seguridad para desarrolladores en cada compilación
GraphQL Galaxy 2021GraphQL Galaxy 2021
82 min
Automatización de pruebas de seguridad para desarrolladores en cada compilación
WorkshopFree
Oliver Moradov
Bar Hofesh
2 authors
Como desarrollador, necesitas entregar rápido y simplemente no tienes tiempo para pensar constantemente en seguridad. Aún así, si algo sale mal, es tu trabajo arreglarlo, pero las pruebas de seguridad bloquean tu automatización, crean cuellos de botella y solo retrasan las versiones, especialmente con graphQL... pero no tiene por qué ser así...

El escáner de seguridad de NeuraLegion, enfocado en los desarrolladores, permite detectar, priorizar y remediar problemas de seguridad de manera temprana, en cada confirmación, sin falsos positivos o alertas, sin ralentizarte.

Únete a esta masterclass para aprender diferentes formas en las que los desarrolladores pueden acceder al escáner de seguridad de NeuraLegion y comenzar a escanear sin salir de la terminal!

Recorreremos la configuración de principio a fin, mientras configuramos un pipeline para un objetivo GraphQL vulnerable, ejecutamos pruebas de seguridad y analizamos los resultados.

Tabla de contenidos:
- Qué es realmente el escáner de seguridad de NeuraLegion enfocado en los desarrolladores (Dynamic Application Security Testing) y cómo funciona
- Ver dónde y cómo encaja un escáner moderno y preciso enfocado en los desarrolladores en el CI/CD
- Integrar el escáner de NeuraLegion con GitHub Actions
- Comprender cómo se pueden probar las aplicaciones modernas, GraphQL y otras API y mecanismos de autenticación
- Hacer un fork de un repositorio, configurar un pipeline, ejecutar pruebas de seguridad y analizar los resultados