Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
I like my tests, like I like my friends, flake-...
Search
Amir Rustamzadeh
August 22, 2018
Programming
210
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
I like my tests, like I like my friends, flake-free and reliable
Cypress end-to-end testing talk given at JS Conf US in Carlsbad, CA.
Amir Rustamzadeh
August 22, 2018
More Decks by Amir Rustamzadeh
See All by Amir Rustamzadeh
Scalable Testing Practices for Modern Apps
amir
1
430
End-to-End Testing Vue Apps with Cypress
amir
2
410
REFACTR.Tech Cypress Workshop Intro
amir
1
210
Next-Generation Web Application End-to-End Testing with Cypress
amir
0
420
Other Decks in Programming
See All in Programming
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
180
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
750
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
560
Mujeres en SEO Summit 2026 - Greatest Disaster Hits en Web Performance
guaca
0
200
OSもどきOS
arkw
0
590
「AIで開発し、AIを届ける」をEvalでつなぐ 〜AIネイティブに始めるプロダクト開発の実践〜 / Connecting "Develop with AI, deliver AI" with Eval
rkaga
4
5.4k
鹿野さんに聞く!『TypeScriptコードレシピ集』で磨く実践力
tonkotsuboy_com
4
840
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
400
トークンをケチるな、設計しろ:GitHub Copilotを賢く使うコンテキスト戦略
ochtum
0
190
1B+ /day規模のログを管理する技術
broadleaf
0
110
任せる範囲はこう広がった / How the Scope of AI Delegation Has Expanded
nrslib
0
130
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
280
Featured
See All Featured
Become a Pro
speakerdeck
PRO
31
6k
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
A Soul's Torment
seathinner
6
3k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
350
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
65
56k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.9k
Done Done
chrislema
186
16k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
123
22k
How Software Deployment tools have changed in the past 20 years
geshan
0
34k
Transcript
I like my tests, like I like my friends, flake-free
and reliable Amir Rustamzadeh @amirrustam JS Conf ! 2018
Sr. Software Engineer @amirrustam Amir Rustamzadeh
[email protected]
E2E Integration Unit Visit The Testing Pyramid @amirrustam
E2E Integration Unit Visit The Testing Pyramid Easy, developers really
like to write these. @amirrustam
E2E Integration Unit Visit The Testing Pyramid Easy, developers really
like to write these. More Difficult, costly, slower… Often completely ignored @amirrustam
E2E Integration Unit Visit The Testing Pyramid Best for users
& business @amirrustam
Renaissance of the Web 2005 2006 2014 2013 @amirrustam
Renaissance of the Web 2005 2006 2014 2013 More complexity
moved from backend to frontend. @amirrustam
2005 2006 2014 2013 Renaissance of the Web + Testing
Automation 2004 @amirrustam
Selenium Architecture Selenium Server Drivers Tests Python Javascript Java @amirrustam
Selenium Architecture Selenium Server Drivers Tests Python Javascript Java ⚠
Classical Syncing Dilemma @amirrustam
Selenium Architecture Flakiness Non-deterministic @amirrustam
✋ JSDOM or DOM Emulation JSDOM is not a real
browser. Your users don’t run your app with JSDOM. One of the primary reasons for E2E is to simulate real user actions. @amirrustam
Don’t let your users be your first E2E test. @amirrustam
Stateless Stateful @amirrustam
Fast, easy and reliable testing for anything that runs in
a browser. Free. Open Source. MIT License @amirrustam
$ npm install -D cypress ☝ All-in-one tool You get
everything you need ❤ Familiar tools underneath Mocha, Chia, Sinon @amirrustam
Lets see it in action…. @amirrustam https://github.com/cypress-io/cypress-example-todomvc
Cypress Architecture Browser Cypress Test Runner Your App @amirrustam
⚡ Native-access to the DOM and your app.
- Fast Test Runs @amirrustam
⏳ Automatic Waiting @amirrustam
Debuggability @amirrustam
Realtime Reloading @amirrustam
Flake-free, consistent, and reliable. @amirrustam
How are commands executed? 1 2 3 @amirrustam
⚙ Component Testing cypress-react-unit-testing vue angular angularjs hyper-app svelte cycle
@amirrustam https:!//github.com/bahmutov/cypress-vue-unit-test#test-adapters-for-other-frameworks
3 cypress open Great for everyday development workflow Cypress +
Editor Side-by-Side TDD Nirvana cypress run Testing in CI/CD Pipeline Headless More efficient for running all your tests @amirrustam
3 cypress open Great for everyday development workflow Cypress +
Editor Side-by-Side TDD Nirvana cypress run --record Video Recordings of Tests @amirrustam
Cypress Dashboard - Great for CI @amirrustam
cypress run --record --parallel Introducing Parallelization Now available in Cypress
3.1 @amirrustam
cypress run --parallel cypress run --parallel cypress run --parallel Your
CI Machines 3x parallelism Ready for work signup.spec.js login.spec.js widget.spec.js @amirrustam
Previous Spec Test Runs Spec Test Duration History Test Duration
(seconds) The Future Automatic Load Balancing of Test Specs Duration Forecast @amirrustam
Automatic Load Balancing of Test Specs login.spec.js signup.spec.js widget.spec.js @amirrustam
Cypress Parallelization Easily optimize your CI usage You save a
lot of ⏳ time and money @amirrustam
cypress run --group frontend Introducing Test Run Grouping Now available
in Cypress 3.1
Documentation docs.cypress.io
Best Practices docs.cypress.io @amirrustam
https:!//youtu.be/5XQOK0v_YRE Cypress Best Practices Brian Mann, Creator of Cypress
End to End testing with Cypress By Andrew Van Slaars
egghead.io/courses/end-to-end-testing-with-cypress
docs.cypress.io/examples/examples/tutorials.html Tutorial Videos
Testing Workshop docs.cypress.io/examples/examples/workshop.html
Podcasts docs.cypress.io/examples/media/podcasts-media.html
We are trying to drastically improve the status quo of
testing on the web. @amirrustam
Thank You npm install -D cypress Free. Open Source. MIT
License Follow @amirrustam for link to slides.