SlideShare a Scribd company logo
JavaScript Unit-Testing
Mihail Irintchev
SiteGround.com
How do you test your JS?
1. Write your JavaScript code
2. See if it works in your favourite browser
3. Change something + [F5]
4. If it doesn't work repeat #3 until you make it work
or you go crazy...
5. In case you made it work, discover few
days/weeks later that it doesn't work in another
browser
I think I'm going crazy...
So what's the first step to sanity?
WRITE TESTABLE CODE
What's wrong with this code?
js_sample_001.js
(inline functions and more inside, ajax
directly hooked to element, etc.)
Anonymous functions, within functions,
within functions...
I'll put functions in your functions...
All your DOM elements are belong to JS!
Server URL coupling
js_sample_001.js
(with highlighted hardcoded url)
Refactoring...
js_sample_002.js
Refactoring...
js_sample_002.js
Now that's better...
js_sample_003.js
(init func and hooked named functions to
page)
Now that's better...
Now that's better...
Now what about testing?
Popular JS Unit-testing frameworks:

QUnit

Jasmine

UnitJS

JsUnit (no longer actively maintained)

Some other – see:
http://en.wikipedia.org/wiki/List_of_unit_testing_frameworks#JavaScript
What's about QUnit?

Used by the jQuery project to test jQuery, jQuery
UI, jQuery Mobile

Can be used to test any generic JavaScript
code, including itself

Very easy to install – just include JS & CSS
file in your HTML
Minimal setup: The tests.htm file
The tests.js file
...remember this earlier?
… and the results:
More tests: quite a variety
… and the results:
Test modules
... and the results page:
Setup / TearDown methods:
What about asynch methods &
AJAX?
Use an AJAX mocking library, such as jquery-mockjax:
No bullshit
Let me show you...
Other mock JS frameworks:
-ajax
But what about test automation?
Why phing?
1. Because I like it and I am used to it, and...
2. PHING ALL THE THINGS!
But phing runs in the console...
JS needs browser to run in...
How do we run the browser?
Wouldn't it be slow?
Need speed? Ditch the browser!
But what about cross-browser
testing?
Credits
”Browser Eyeballing != JavaScript Testing”, Jordan Kasper
bit.ly/js-testing
”Unit Testing JavaScript With QUnit And Phing”, Robert Price
http://www.robertprice.co.uk/robblog/2012/12/unit-testing-javascript-with-qunit-and-phin
”Qunit Phing Task”, Martin Jonsson
http://github.com/martinj/phing-task-qunit
Questions?
@irintchev
m.irintchev@siteground.com

More Related Content

PDF
Developing large scale JavaScript applications
PDF
Backbone.js
PPTX
Backbone.js
PDF
High Performance JavaScript 2011
PDF
Test your Javascript! v1.1
PDF
One step in the future: CSS variables
PPTX
Xdebug, KCacheGrind and Webgrind with WampServer
PDF
Webpack Tutorial, Uppsala JS
Developing large scale JavaScript applications
Backbone.js
Backbone.js
High Performance JavaScript 2011
Test your Javascript! v1.1
One step in the future: CSS variables
Xdebug, KCacheGrind and Webgrind with WampServer
Webpack Tutorial, Uppsala JS

What's hot (20)

PPTX
Browser Automated Testing Frameworks - Nightwatch.js
PDF
webpack 101 slides
PPTX
An Intro into webpack
PPTX
UI Testing Automation - Alex Kalinovsky - CreamTec LLC
PPT
AngularJS for Legacy Apps
PDF
Webdriver.io
PDF
Module, AMD, RequireJS
PDF
Webpack DevTalk
PDF
Service Worker 201 (en)
PPTX
High Performance Snippets
PDF
Building a js widget
PDF
Night Watch with QA
PDF
JavaScript + Jenkins = Winning!
PPTX
Your Script Just Killed My Site
PPTX
Automation testing with Drupal 8
PDF
Service Worker 101 (en)
PDF
Webpack: from 0 to 2
PDF
PHP MVC Tutorial
PDF
20160905 - BrisJS - nightwatch testing
PDF
jQuery Proven Performance Tips & Tricks
Browser Automated Testing Frameworks - Nightwatch.js
webpack 101 slides
An Intro into webpack
UI Testing Automation - Alex Kalinovsky - CreamTec LLC
AngularJS for Legacy Apps
Webdriver.io
Module, AMD, RequireJS
Webpack DevTalk
Service Worker 201 (en)
High Performance Snippets
Building a js widget
Night Watch with QA
JavaScript + Jenkins = Winning!
Your Script Just Killed My Site
Automation testing with Drupal 8
Service Worker 101 (en)
Webpack: from 0 to 2
PHP MVC Tutorial
20160905 - BrisJS - nightwatch testing
jQuery Proven Performance Tips & Tricks
Ad

Similar to Js unit testing (20)

PDF
Qunit tutorial
PPTX
Java script unit testing
PDF
JAVASCRIPT TDD(Test driven Development) & Qunit Tutorial
PPT
JavaScript Unit Testing
PPT
JsUnit
PDF
Automated Web Testing using JavaScript
PDF
Javascript Unit Testing Tools
KEY
Enterprise Strength Mobile JavaScript
PPTX
3 Ways to test your ColdFusion API - 2017 Adobe CF Summit
PDF
Quick tour to front end unit testing using jasmine
PPTX
Unit Testing TypeScript
ODP
Dot Net Notts Js Unit Testing at Microlise
PPT
Jsunit
ODP
Js unit testingpresentation
PPTX
Automated Testing using JavaScript
PDF
Quick tour to front end unit testing using jasmine
PPTX
Testing Ext JS and Sencha Touch
PPTX
JavaScript Unit Testing
PDF
Front end unit testing using jasmine
KEY
JavaScript Testing VIA Selenium
Qunit tutorial
Java script unit testing
JAVASCRIPT TDD(Test driven Development) & Qunit Tutorial
JavaScript Unit Testing
JsUnit
Automated Web Testing using JavaScript
Javascript Unit Testing Tools
Enterprise Strength Mobile JavaScript
3 Ways to test your ColdFusion API - 2017 Adobe CF Summit
Quick tour to front end unit testing using jasmine
Unit Testing TypeScript
Dot Net Notts Js Unit Testing at Microlise
Jsunit
Js unit testingpresentation
Automated Testing using JavaScript
Quick tour to front end unit testing using jasmine
Testing Ext JS and Sencha Touch
JavaScript Unit Testing
Front end unit testing using jasmine
JavaScript Testing VIA Selenium
Ad

Recently uploaded (20)

PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Electronic commerce courselecture one. Pdf
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Machine learning based COVID-19 study performance prediction
PDF
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
PPTX
Cloud computing and distributed systems.
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
Spectroscopy.pptx food analysis technology
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PPTX
Machine Learning_overview_presentation.pptx
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
“AI and Expert System Decision Support & Business Intelligence Systems”
Encapsulation_ Review paper, used for researhc scholars
Advanced methodologies resolving dimensionality complications for autism neur...
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Electronic commerce courselecture one. Pdf
MYSQL Presentation for SQL database connectivity
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
Unlocking AI with Model Context Protocol (MCP)
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
Building Integrated photovoltaic BIPV_UPV.pdf
Network Security Unit 5.pdf for BCA BBA.
Machine learning based COVID-19 study performance prediction
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
Cloud computing and distributed systems.
Chapter 3 Spatial Domain Image Processing.pdf
Spectroscopy.pptx food analysis technology
Per capita expenditure prediction using model stacking based on satellite ima...
Machine Learning_overview_presentation.pptx

Js unit testing