SlideShare uma empresa Scribd logo
https://walmyrfilho.com
Criando testes
automatizados
rápidos e robustos
com Cypress
MTC dendicasa 2021
Sobre mim
Meu nome é Walmyr Filho, sou um engenheiro
de software especializado em automação de
testes e integração contínua, embaixador do
Cypress.io, autor do blog TAT e do canal TAT,
instrutor de cursos de automação de testes
web no Udemy, mentor e um cara apaixonado
por skateboarding, comida vegana, música,
tatuagens e minha família.
O problema dos testes lentos
Testes instáveis (flaky)
Boas práticas p/ testes rápidos e confiáveis
Mão-na-massa
Perguntas e respostas
Surpresa!
Agenda
Pontos de discussão
Testes leeentos
E os problemas que eles trazem junto consigo
ATRASAM O TIME
Gosto de um pipeline de
integração contínua de não mais
que 10 minutos. Mais que isso e
problemas começam a voltar
quando são mais caros de
corrigir.
ATRASAM ENTREGAS OU
COMPROMETEM A QUALIDADE
É arriscado entregar um software
sem a garantia de que todos os
testes de regressão estão
passando. Mas e quando são
muito lentos uai?
SÃO "LARGADOS DE ΜÃO"
É isso mesmo, testes que
atrasam o time não são uma
alternativa para times em busca
de agilidade.
Testes instáveis
(os famosos flakey tests)
EXECUÇÃO 1
Ô trem bão!
Passou!
EXECUÇÃO2
E nenhum código mudou desde a
última execução.
Falhou ) :
EXECUÇÃO4
Uai, aquela falha devia ser alguma
instabilidade no ambiente.
Passou!
EXECUÇÃO 5
Vixe, esse trem é flaky!
Falhou :(
EXECUÇÃO3
E nenhum código mudou desde a
última execução de novo.
Passou!
Faça autenticação de forma programática
Boas práticas
Testes devem ser independentes uns dos outros
Crie mecanismos para o controle do estado da app
Selecione elementos com atributos data-*
Não tente armazenar comandos do Cypress em variáveis
Testes não devem ser muito pequenos nem muito grandes
Não teste aplicações que você não controla
Não use os hooks after e afterEach
Não use cy.wait(Number)
Inicialize o servidor antes de iniciar os testes
Boas práticas - continuação
Configure uma URL base (baseUrl)
Já que sobrou espaçao, fica o convite para conhecerem a playlist
Explorando a Cypress RWA no canal Talking About Testing no YouTube.
https://bit.ly/3iOeykQ
Testes independentes
Além disso, testes independentes facilitam na
paralelizacão de sua execução.
Testes automatizados devem ser capazes de
serem executados de forma isolada, sem a
necesidade de que outro teste tenha executado
para criar algum estado na aplicação em teste.
A falha em um teste não deve impactar no
resultados de outros testes.
Dica: utilize o hook beforeEach quando
precisar executar passos repetidos para todos
os testes de um determinado describe ou
context.
Autenticação
programática
Ao adiconar mecanismos para realizar login de
forma programática, os testes ficam mais rápidos
e independentes.
Realizar login via interface gráfica de usuário
como pré-condição de todos testes é custoso (em
termos de tempo de execução), além de tornar os
testes dependentes, o que por si só já é uma má
prática.
Um botão de login desabilitado por uma erro de
HMTL, por exemplo, não deveria quebrar toda
uma suíte de testes.
Mecanismos
para criação de estado
Alguns exemplos desses mecanismos são:
chamadas de API para criação de recursos;
comunicação com o banco de dados via tasks; ou
a execução de scripts à nível de sistema
operacional.
Ao criar tais mecanismos, garantimos testes
completamente desacoplados uns dos outros,
não precisamos de abstrações que adicionam
complexidade aos testes, tais como Page
Objects, por exemplo, e garantimos testes
rápidos e direto-ao-ponto.
Atributos data-*
Adicionando atributos aos elementos do
frontend, tais como: data-test, data-testid, ou
data-cy, adicionamos o que chamo de
"testabilidade" na aplicação, visto que tais
atributos são especificamente criados para fins
de testes, diminuindo a chance de mudanças no
frontend quebraem os testes.
Não faça isso:
var el = cy.get('seletor')
cy.get('@myBtn).click()
Lembre-se. Cypress não é Selenium!
O Cypress possui uma arquitura própria, onde
apesar de em muitos casos permitir a escrita de
código que parece síncrono, mesmo que seja
assíncrono (visto que coloca cada comando em
uma fila para posterior execução), não é possível
fazer algo como:
const myBtn = cy.contains('button', 'My button')
myBtn.click()
Porém, você pode fazer:
cy.contains('button', 'My button').as('myBtn)
Não teste aplicações
externas
Para garantir que tais serviços estão de acordo
com sua aplicação, você pode ter uma suite de
smoke-test, por exemplo, ou testes de contrato.
Depender do login do Google via GUI para seus
testes, ou de alguma API de terceiros pode tornar
seus testes instáveis, visto que mudanças nestes
serviços (os quais você não controla) irão quebrar
seus testes, mesmo que esteja tudo certo do "do
seu lado".
Testes muito pequenos
ou muito grandes
Porém, cuidado com testes muuuito grandes.
Quem sabe estes estão testando muitas coisas
não relacionadas e poderiam ser quebrados em
testes menores.
Testes end-to-end não são testes de unidade.
Devido ao seu custo de execução, vale a pena
adicionar mais de uma verificação por teste, para
otimizar seu tempo.
Não use os hooks
after e afterEach
Como boa prática, faça qualquer limpeza antes
da execução dos testes, usando o hook
beforeEach, por exemplo.
Caso algo dê errado durante a execução dos
testes, tais hooks correm o risco de não serem
executados, deixando "lixo" na aplicação.
Não use cy.wait(5000)
cy.wait('@myReq')
O Cypress já possui esperas automáticas com
diferentes timeout defaults para esperar por
elementos estarem visíveis, por animações
acabarem, por requisições serem enviadas e
respondidas e por páginas serem carregadas.
O que você pode fazer, para tornar seus testes
ainda mais robustos, é aguardor por elementos
estarem visíveis:
Ex.: cy.get('[data-cy="avatar"]').should('be.visible')
Ou então, você pode esperar por uma deteminada
requisição a qual você deu um alias.
Ex2.: cy.intercept(...).as('myReq')
...
start-server-and-test
Utilize mecanismos, tais como o uso da biblioteca
star-server-and-test, para inicializar o servidor da
aplicação antes da execução dos testes,
garantindo que a mesma será executada com o
código correto e que os testes serão executados
somente quando a aplicação estiver respondendo.
Além disso, tal abordagem ajudará na execução
dos testes em um servidor de integração contínua.
Defina a baseUrl
Além disso, tal URL pode ser sobrescrita por meio
de um arquivo cypress.env.json, variáveis de
ambiente (CYPRESS_ ou cypress_), linha de
comando, plugins, etc, possibilitando a execução
dos mesmos testes contra diferentes ambientes.
Ao definir a baseUrl no arquivo de configuração
(cypress.json), seus testes podem visitar as
páginas via URLs relativas.
Seguindo essas boas práticas, você
terá testes rápidos e robustos, nos
quais seu time confia e ajuda a
manter e evoluir.
"Mão-na-massa"
Cypress RWA
MTC dendicasa 2021
Alguma pergunta?
Ficarei feliz em responder!
Clonar o projeto
https://github.com/cypress-
io/cypress-realworld-app, acessá-
lo e rodar yarn install
Abrir o runner e filtrar pelo teste
transaction-view.spec.ts
Executar a suite e tirar uma
screenshot dos testes passando
E postar a screenshot no LinkedIn
com o texto "Eu vi a talk de
Cypress do Walmyr no
#MTCDendiCasa2021" (marcando
MTC, o Cypress.io e eu)
Tenho 10 cupons grátis pro meu curso
de Cypress intermediário, para os
primeiros que realizarem os seguintes
passos:
1.
2.
3.
4.
Desafio/Surpresa!
https://docs.cypress.io/guides/
references/best-practices
https://github.com/cypress-
io/cypress-realworld-app
Referências
https://walmyrfilho.com
Muito obrigado!
MTC dendicasa 2021

Mais conteúdo relacionado

PPTX
Testes E2E em Cypress com JS
Nàtali Cabral
 
PDF
Testes automatizados com Cypress
COTIC-PROEG (UFPA)
 
PDF
Cypress vs Selenium WebDriver: Better, Or Just Different? -- by Gil Tayar
Applitools
 
PDF
API Testing following the Test Pyramid
Elias Nogueira
 
PDF
[MTC 2021] Criando testes automatizados rápidos e robustos com cypress - Walm...
minastestingconference
 
PDF
Test Automation
rockoder
 
PPTX
Cypress Automation
Susantha Pathirana
 
PDF
Cypress - Best Practices
Brian Mann
 
Testes E2E em Cypress com JS
Nàtali Cabral
 
Testes automatizados com Cypress
COTIC-PROEG (UFPA)
 
Cypress vs Selenium WebDriver: Better, Or Just Different? -- by Gil Tayar
Applitools
 
API Testing following the Test Pyramid
Elias Nogueira
 
[MTC 2021] Criando testes automatizados rápidos e robustos com cypress - Walm...
minastestingconference
 
Test Automation
rockoder
 
Cypress Automation
Susantha Pathirana
 
Cypress - Best Practices
Brian Mann
 

Mais procurados (20)

PPTX
Solucionando a Teoria do Caos com Cypress.io
Patrick Monteiro
 
PDF
Cypress testing
Vladyslav Romanchenko
 
PDF
e2e testing with cypress
Tomasz Bak
 
PDF
Automated testing with Cypress
Yong Shean Chong
 
PPTX
Cypress Testing.pptx
JasmeenShrestha
 
PPTX
End to end test automation with cypress
Kushan Shalindra Amarasiri - Technical QE Specialist
 
PPTX
QA Best Practices in Agile World_new
Praveen Dosapati (CSM)
 
PPTX
Agile Testing and Test Automation
Naveen Kumar Singh
 
PDF
Test Automation
nikos batsios
 
PPTX
Api testing
Keshav Kashyap
 
PPTX
Introduction to Integration Testing With Cypress
Erez Cohen
 
KEY
Arquitetura de Automação de Teste
Elias Nogueira
 
PPTX
How to Get Started with Cypress
Applitools
 
PDF
An Introduction To Automated API Testing
Sauce Labs
 
PPT
Automation testing
Biswajit Pratihari
 
PDF
Papel do QA na Transformação Ágil
Elias Nogueira
 
PPTX
Automation Testing
Sun Technlogies
 
PDF
DevCamp - O papel de um testador em uma equipe ágil
Elias Nogueira
 
PDF
4 Major Advantages of API Testing
QASource
 
Solucionando a Teoria do Caos com Cypress.io
Patrick Monteiro
 
Cypress testing
Vladyslav Romanchenko
 
e2e testing with cypress
Tomasz Bak
 
Automated testing with Cypress
Yong Shean Chong
 
Cypress Testing.pptx
JasmeenShrestha
 
End to end test automation with cypress
Kushan Shalindra Amarasiri - Technical QE Specialist
 
QA Best Practices in Agile World_new
Praveen Dosapati (CSM)
 
Agile Testing and Test Automation
Naveen Kumar Singh
 
Test Automation
nikos batsios
 
Api testing
Keshav Kashyap
 
Introduction to Integration Testing With Cypress
Erez Cohen
 
Arquitetura de Automação de Teste
Elias Nogueira
 
How to Get Started with Cypress
Applitools
 
An Introduction To Automated API Testing
Sauce Labs
 
Automation testing
Biswajit Pratihari
 
Papel do QA na Transformação Ágil
Elias Nogueira
 
Automation Testing
Sun Technlogies
 
DevCamp - O papel de um testador em uma equipe ágil
Elias Nogueira
 
4 Major Advantages of API Testing
QASource
 
Anúncio

Semelhante a Como criar testes rápidos e robustos com Cypress (20)

PDF
Teste de Performance - 3º Encontro da ALATS
Fabrício Campos
 
PPT
Curso Básico de Selenium
Autotic
 
PPTX
1 2 3 - Testando - Automatizando os testes de software
Heider Lopes
 
PPTX
Introdução a tdd
Fabrício Vargas Matos
 
PPT
Automação de Testes: Ferramentas e Aplicação com Integração Contínua
Gabriela Patuci
 
PDF
cypress.pdf
Rafael Martins
 
PDF
Ibm app scan
Reinaldo Junior
 
PPTX
Testando sua aplicação asp.net mvc de forma automatizada de ponta a ponta
tdc-globalcode
 
PDF
ibm_appscan
Reinaldo Junior
 
PPTX
Testes Unitários
Joberto Diniz
 
PDF
Caipira agil automacao front end selenium
Qualister
 
PPTX
Paletra sobre TDD, ocorrida no #DevDojo
flavio1110
 
PPTX
Introdução a testes automatizados
Thiago Ghisi
 
PDF
ld0mg1hrlhzbyvgfiyyq-signature-d9919623d100cd87ad7553e4c50163aa9329a439464540...
Antonio Lobato
 
PPTX
Integração contínua - Prática de desenvolvimento
Mario Mendonça
 
PPTX
Integração Contínua
Jackson Veroneze
 
PDF
Tipos de automação de teste
Marcos Pessoa
 
PDF
Paralelize seus testes web e mobile para ter feedbacks mais rápidos
Elias Nogueira
 
PDF
GOTEST-Aula5-Automacao-Parte2.pdf
RodolphoCesar2
 
PPTX
Automação de Teste para REST, Web e Mobile
Elias Nogueira
 
Teste de Performance - 3º Encontro da ALATS
Fabrício Campos
 
Curso Básico de Selenium
Autotic
 
1 2 3 - Testando - Automatizando os testes de software
Heider Lopes
 
Introdução a tdd
Fabrício Vargas Matos
 
Automação de Testes: Ferramentas e Aplicação com Integração Contínua
Gabriela Patuci
 
cypress.pdf
Rafael Martins
 
Ibm app scan
Reinaldo Junior
 
Testando sua aplicação asp.net mvc de forma automatizada de ponta a ponta
tdc-globalcode
 
ibm_appscan
Reinaldo Junior
 
Testes Unitários
Joberto Diniz
 
Caipira agil automacao front end selenium
Qualister
 
Paletra sobre TDD, ocorrida no #DevDojo
flavio1110
 
Introdução a testes automatizados
Thiago Ghisi
 
ld0mg1hrlhzbyvgfiyyq-signature-d9919623d100cd87ad7553e4c50163aa9329a439464540...
Antonio Lobato
 
Integração contínua - Prática de desenvolvimento
Mario Mendonça
 
Integração Contínua
Jackson Veroneze
 
Tipos de automação de teste
Marcos Pessoa
 
Paralelize seus testes web e mobile para ter feedbacks mais rápidos
Elias Nogueira
 
GOTEST-Aula5-Automacao-Parte2.pdf
RodolphoCesar2
 
Automação de Teste para REST, Web e Mobile
Elias Nogueira
 
Anúncio

Mais de Walmyr Lima e Silva Filho (18)

PDF
Testando na Gringa - Se preparando para uma entrevista técnica para uma vaga ...
Walmyr Lima e Silva Filho
 
PDF
Writing cypress tests without cucumber
Walmyr Lima e Silva Filho
 
PDF
Component testing with cypress
Walmyr Lima e Silva Filho
 
PDF
Esquenta QAX
Walmyr Lima e Silva Filho
 
PDF
Agile Testing - A quality culture in the company's core business
Walmyr Lima e Silva Filho
 
PDF
How to kill software quality in five steps
Walmyr Lima e Silva Filho
 
PDF
Lessons learned as a software engineer working at appear.in
Walmyr Lima e Silva Filho
 
PDF
Oslo QA Meetup
Walmyr Lima e Silva Filho
 
PDF
Estratégias para o uso de integração e entrega contínua com gocd
Walmyr Lima e Silva Filho
 
PDF
Agile testing coach Agile Lean Ireland 2017
Walmyr Lima e Silva Filho
 
PDF
Protractor tests no processo de integração contínua
Walmyr Lima e Silva Filho
 
PDF
Workshop - E2e tests with protractor
Walmyr Lima e Silva Filho
 
PDF
TDC 2016 Trilha Testes - Floripa
Walmyr Lima e Silva Filho
 
PDF
Protractor style guide - Agile Testers Conference 2016
Walmyr Lima e Silva Filho
 
PDF
Primeiros passos com protractor - GUTS-SC
Walmyr Lima e Silva Filho
 
PDF
Protractor + visual review 2
Walmyr Lima e Silva Filho
 
PDF
Agile testing coach - Agile Trends Floripa
Walmyr Lima e Silva Filho
 
PDF
Palestra agile testing coaching
Walmyr Lima e Silva Filho
 
Testando na Gringa - Se preparando para uma entrevista técnica para uma vaga ...
Walmyr Lima e Silva Filho
 
Writing cypress tests without cucumber
Walmyr Lima e Silva Filho
 
Component testing with cypress
Walmyr Lima e Silva Filho
 
Agile Testing - A quality culture in the company's core business
Walmyr Lima e Silva Filho
 
How to kill software quality in five steps
Walmyr Lima e Silva Filho
 
Lessons learned as a software engineer working at appear.in
Walmyr Lima e Silva Filho
 
Estratégias para o uso de integração e entrega contínua com gocd
Walmyr Lima e Silva Filho
 
Agile testing coach Agile Lean Ireland 2017
Walmyr Lima e Silva Filho
 
Protractor tests no processo de integração contínua
Walmyr Lima e Silva Filho
 
Workshop - E2e tests with protractor
Walmyr Lima e Silva Filho
 
TDC 2016 Trilha Testes - Floripa
Walmyr Lima e Silva Filho
 
Protractor style guide - Agile Testers Conference 2016
Walmyr Lima e Silva Filho
 
Primeiros passos com protractor - GUTS-SC
Walmyr Lima e Silva Filho
 
Protractor + visual review 2
Walmyr Lima e Silva Filho
 
Agile testing coach - Agile Trends Floripa
Walmyr Lima e Silva Filho
 
Palestra agile testing coaching
Walmyr Lima e Silva Filho
 

Como criar testes rápidos e robustos com Cypress

  • 2. Sobre mim Meu nome é Walmyr Filho, sou um engenheiro de software especializado em automação de testes e integração contínua, embaixador do Cypress.io, autor do blog TAT e do canal TAT, instrutor de cursos de automação de testes web no Udemy, mentor e um cara apaixonado por skateboarding, comida vegana, música, tatuagens e minha família.
  • 3. O problema dos testes lentos Testes instáveis (flaky) Boas práticas p/ testes rápidos e confiáveis Mão-na-massa Perguntas e respostas Surpresa! Agenda Pontos de discussão
  • 4. Testes leeentos E os problemas que eles trazem junto consigo ATRASAM O TIME Gosto de um pipeline de integração contínua de não mais que 10 minutos. Mais que isso e problemas começam a voltar quando são mais caros de corrigir. ATRASAM ENTREGAS OU COMPROMETEM A QUALIDADE É arriscado entregar um software sem a garantia de que todos os testes de regressão estão passando. Mas e quando são muito lentos uai? SÃO "LARGADOS DE ΜÃO" É isso mesmo, testes que atrasam o time não são uma alternativa para times em busca de agilidade.
  • 5. Testes instáveis (os famosos flakey tests) EXECUÇÃO 1 Ô trem bão! Passou! EXECUÇÃO2 E nenhum código mudou desde a última execução. Falhou ) : EXECUÇÃO4 Uai, aquela falha devia ser alguma instabilidade no ambiente. Passou! EXECUÇÃO 5 Vixe, esse trem é flaky! Falhou :( EXECUÇÃO3 E nenhum código mudou desde a última execução de novo. Passou!
  • 6. Faça autenticação de forma programática Boas práticas Testes devem ser independentes uns dos outros Crie mecanismos para o controle do estado da app Selecione elementos com atributos data-* Não tente armazenar comandos do Cypress em variáveis Testes não devem ser muito pequenos nem muito grandes Não teste aplicações que você não controla Não use os hooks after e afterEach Não use cy.wait(Number) Inicialize o servidor antes de iniciar os testes
  • 7. Boas práticas - continuação Configure uma URL base (baseUrl) Já que sobrou espaçao, fica o convite para conhecerem a playlist Explorando a Cypress RWA no canal Talking About Testing no YouTube. https://bit.ly/3iOeykQ
  • 8. Testes independentes Além disso, testes independentes facilitam na paralelizacão de sua execução. Testes automatizados devem ser capazes de serem executados de forma isolada, sem a necesidade de que outro teste tenha executado para criar algum estado na aplicação em teste. A falha em um teste não deve impactar no resultados de outros testes. Dica: utilize o hook beforeEach quando precisar executar passos repetidos para todos os testes de um determinado describe ou context.
  • 9. Autenticação programática Ao adiconar mecanismos para realizar login de forma programática, os testes ficam mais rápidos e independentes. Realizar login via interface gráfica de usuário como pré-condição de todos testes é custoso (em termos de tempo de execução), além de tornar os testes dependentes, o que por si só já é uma má prática. Um botão de login desabilitado por uma erro de HMTL, por exemplo, não deveria quebrar toda uma suíte de testes.
  • 10. Mecanismos para criação de estado Alguns exemplos desses mecanismos são: chamadas de API para criação de recursos; comunicação com o banco de dados via tasks; ou a execução de scripts à nível de sistema operacional. Ao criar tais mecanismos, garantimos testes completamente desacoplados uns dos outros, não precisamos de abstrações que adicionam complexidade aos testes, tais como Page Objects, por exemplo, e garantimos testes rápidos e direto-ao-ponto.
  • 11. Atributos data-* Adicionando atributos aos elementos do frontend, tais como: data-test, data-testid, ou data-cy, adicionamos o que chamo de "testabilidade" na aplicação, visto que tais atributos são especificamente criados para fins de testes, diminuindo a chance de mudanças no frontend quebraem os testes.
  • 12. Não faça isso: var el = cy.get('seletor') cy.get('@myBtn).click() Lembre-se. Cypress não é Selenium! O Cypress possui uma arquitura própria, onde apesar de em muitos casos permitir a escrita de código que parece síncrono, mesmo que seja assíncrono (visto que coloca cada comando em uma fila para posterior execução), não é possível fazer algo como: const myBtn = cy.contains('button', 'My button') myBtn.click() Porém, você pode fazer: cy.contains('button', 'My button').as('myBtn)
  • 13. Não teste aplicações externas Para garantir que tais serviços estão de acordo com sua aplicação, você pode ter uma suite de smoke-test, por exemplo, ou testes de contrato. Depender do login do Google via GUI para seus testes, ou de alguma API de terceiros pode tornar seus testes instáveis, visto que mudanças nestes serviços (os quais você não controla) irão quebrar seus testes, mesmo que esteja tudo certo do "do seu lado".
  • 14. Testes muito pequenos ou muito grandes Porém, cuidado com testes muuuito grandes. Quem sabe estes estão testando muitas coisas não relacionadas e poderiam ser quebrados em testes menores. Testes end-to-end não são testes de unidade. Devido ao seu custo de execução, vale a pena adicionar mais de uma verificação por teste, para otimizar seu tempo.
  • 15. Não use os hooks after e afterEach Como boa prática, faça qualquer limpeza antes da execução dos testes, usando o hook beforeEach, por exemplo. Caso algo dê errado durante a execução dos testes, tais hooks correm o risco de não serem executados, deixando "lixo" na aplicação.
  • 16. Não use cy.wait(5000) cy.wait('@myReq') O Cypress já possui esperas automáticas com diferentes timeout defaults para esperar por elementos estarem visíveis, por animações acabarem, por requisições serem enviadas e respondidas e por páginas serem carregadas. O que você pode fazer, para tornar seus testes ainda mais robustos, é aguardor por elementos estarem visíveis: Ex.: cy.get('[data-cy="avatar"]').should('be.visible') Ou então, você pode esperar por uma deteminada requisição a qual você deu um alias. Ex2.: cy.intercept(...).as('myReq') ...
  • 17. start-server-and-test Utilize mecanismos, tais como o uso da biblioteca star-server-and-test, para inicializar o servidor da aplicação antes da execução dos testes, garantindo que a mesma será executada com o código correto e que os testes serão executados somente quando a aplicação estiver respondendo. Além disso, tal abordagem ajudará na execução dos testes em um servidor de integração contínua.
  • 18. Defina a baseUrl Além disso, tal URL pode ser sobrescrita por meio de um arquivo cypress.env.json, variáveis de ambiente (CYPRESS_ ou cypress_), linha de comando, plugins, etc, possibilitando a execução dos mesmos testes contra diferentes ambientes. Ao definir a baseUrl no arquivo de configuração (cypress.json), seus testes podem visitar as páginas via URLs relativas.
  • 19. Seguindo essas boas práticas, você terá testes rápidos e robustos, nos quais seu time confia e ajuda a manter e evoluir.
  • 22. Clonar o projeto https://github.com/cypress- io/cypress-realworld-app, acessá- lo e rodar yarn install Abrir o runner e filtrar pelo teste transaction-view.spec.ts Executar a suite e tirar uma screenshot dos testes passando E postar a screenshot no LinkedIn com o texto "Eu vi a talk de Cypress do Walmyr no #MTCDendiCasa2021" (marcando MTC, o Cypress.io e eu) Tenho 10 cupons grátis pro meu curso de Cypress intermediário, para os primeiros que realizarem os seguintes passos: 1. 2. 3. 4. Desafio/Surpresa!