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
JavaScriptTesting
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Luca Grulla
April 23, 2012
1.2k
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
JavaScriptTesting
Delivered at XP2010
Luca Grulla
April 23, 2012
More Decks by Luca Grulla
See All by Luca Grulla
Il grande bluff delle stime
lucagrulla
0
360
Building a Firehose with NodeJS
lucagrulla
1
140
Featured
See All Featured
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
270
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
1
250
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
420
Embracing the Ebb and Flow
colly
88
5.1k
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
410
30 Presentation Tips
portentint
PRO
1
320
How to train your dragon (web standard)
notwaldorf
97
6.7k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.7k
How to Build an AI Search Optimization Roadmap - Criteria and Steps to Take #SEOIRL
aleyda
1
2.1k
GitHub's CSS Performance
jonrohan
1033
470k
Paper Plane (Part 1)
katiecoart
PRO
0
8.8k
Transcript
The secret art of Agile Javascrip3ng Brian Blignaut Luca Grulla Trondheim, 4/6/10 ‐ XP2010
Our background Large public facing websites Significant javascript codebase with complex DOM interacKon Heavy use of Ajax Large amount of business logic Long life expectancy
Disclaimer This presentaKon is technology agnosKc Each tool used is replaceable It is not about how to use jQuery
Technology Stack • JQuery • JSTestDriver • Ewloe • JavascriptLint
It used to be so simple…
Rich clients
We want unit tests
Scenario Login form Need to validate user credenKals Need to execute a server call via ajax POST Based on the result we need to show a welcome or an error message
None
None
None
None
So what is wrong with this code ?
None
We want to test it!
Domain abstrac3on
Abstrac3on around integra3on points
HTTP DOM PresentaKon Logic Business Logic
None
None
None
None
None
None
None
None
Live Demo ‐ Shopping Cart
Our approach Javascript is a first class language create abstracKons: business logic presentaKon logic integraKons …but not limited to a specific paVern !! Keep your presentaKon logic class as skinny as possible in order to express intents Favour interacKon tests over integraKon tests
Tools Considera3ons ….whatever you like but has to be pluggable in your ConKnuous IntegraKon !!
Ques3ons ?
Thank You ! Brian Blignaut
[email protected]
Luca Grulla
[email protected]
hVp://www.lucagrulla.it
References Live demo starKng point code hVp://github.com/gurrie/norway Live demo refactored code hVp://github.com/gurrie/norway/tree/completedSoluKon Ewloe hVp://github.com/gurrie/ewloe