SlideShare une entreprise Scribd logo
1  sur  47
Télécharger pour lire hors ligne
Javascript Unit
                     Testing
                       Introduction to QUnit & JsTestDriver




Wednesday 4 May 2011
Tom Van Herreweghe

                       PHP developer

                       ZCE 5.0 & 5.3

                       I like Javascript

                       http://blog.theanalogguy.be

                       @miljar




Wednesday 4 May 2011
Overview


                       Introduction to QUnit

                       Introduction to JsTestDriver




Wednesday 4 May 2011
QUnit



Wednesday 4 May 2011
QUnit

                       JS Unit Testing library

                         JsUnit, DOH, YUI Test, ...

                       JQuery

                       http://docs.jquery.com/Qunit




Wednesday 4 May 2011
QUnit setup


                         Demo




Wednesday 4 May 2011
QUnit structure


              module(‘name’[, {lifecycle}])




Wednesday 4 May 2011
QUnit structure


     test(‘name’[, expected], test-code)




Wednesday 4 May 2011
QUnit structure


                           Demo




Wednesday 4 May 2011
QUnit assertions


                       ok(state[, ‘message’])




Wednesday 4 May 2011
QUnit assertions


        equal(actual, expected[, ‘message’])




                          corresponds with: ==
Wednesday 4 May 2011
QUnit assertions

               notEqual(actual, expected[,
                      ‘message’])



                          corresponds with: !=
Wednesday 4 May 2011
QUnit assertions


                            Demo




Wednesday 4 May 2011
QUnit assertions

             deepEqual(actual, expected[,
                    ‘message’])



                       corresponds with: === (recursive)
Wednesday 4 May 2011
QUnit assertions

       notDeepEqual(actual, expected[,
                ‘message’])



                       corresponds with: !== (recursive)
Wednesday 4 May 2011
QUnit assertions


                            Demo




Wednesday 4 May 2011
QUnit assertions

               raises(function[, expected][,
                        ‘message’])




Wednesday 4 May 2011
QUnit assertions


                            Demo




Wednesday 4 May 2011
Async testing

                       the good: callbacks

                       the bad: timers

                       the ugly: currently not in QUnitAdapter for
                       JsTestDriver




Wednesday 4 May 2011
Async testing

                 Timers: hard to predict
               running time + slows down




Wednesday 4 May 2011
Async testing


                   Callbacks: run assertions




Wednesday 4 May 2011
Async testing

                       Currently not supported
                          in QUnitAdapter




Wednesday 4 May 2011
Async testing

                       stop()

                       start()

                       expect()

                       asyncTest()




Wednesday 4 May 2011
Async testing


                          Demo




Wednesday 4 May 2011
JsTestDriver



Wednesday 4 May 2011
JsTestDriver

                       Testrunner for your Unit Tests

                       Written in Java

                       Client / Server architecture

                       http://code.google.com/p/js-test-driver




Wednesday 4 May 2011
JsTestDriver




Wednesday 4 May 2011
JsTestDriver


                       Custom syntax

                       Need mapping from QUnit to JsTestDriver

                       Some QUnit functionalities not (yet) available




Wednesday 4 May 2011
JsTestDriver

                       module()

                       test()

                       ok()

                       equals()

                       same() (old name for deepEqual())



Wednesday 4 May 2011
JsTestDriver


                           Fetch JAR from
               http://code.google.com/p/js-test-driver/downloads/list




Wednesday 4 May 2011
JsTestDriver


                         Run server
        java -jar /path/to/JsTestDriver-1.3.2.jar --port 4224




Wednesday 4 May 2011
JsTestDriver


                       Point browser(s) to
                         http://localhost:4224




Wednesday 4 May 2011
JsTestDriver


                          Demo




Wednesday 4 May 2011
JsTestDriver

                  Download QUnit adapter
           http://code.google.com/p/js-test-driver/wiki/
                          QUnitAdapter




Wednesday 4 May 2011
JsTestDriver


                        Create config




Wednesday 4 May 2011
JsTestDriver

                           Run tests
           java -jar /path/to/JsTestDriver-1.3.2.jar --config
                 /path/to/jsTestDriver.conf --tests all




Wednesday 4 May 2011
JsTestDriver


                          Demo




Wednesday 4 May 2011
Questions?

                       Read more?

                       Slideshare

                       Joind.in

                       Github
                       https://github.com/Miljar/
                       PHPBenelux-BE-may




Wednesday 4 May 2011
Code Coverage



Wednesday 4 May 2011
Code Coverage


                       Download plugin from
            http://code.google.com/p/js-test-driver/downloads/list




Wednesday 4 May 2011
Code Coverage


                       Include plugin in config




Wednesday 4 May 2011
Code Coverage


         Add flags when executing tests
                       --testOutput /path/to/outputfolder




Wednesday 4 May 2011
Code Coverage


                        Install LCOV




Wednesday 4 May 2011
Code Coverage


                           Generate HTML
                   genhtml /path/to/jsTestDriver.conf-coverage.dat




Wednesday 4 May 2011
Code Coverage


                           Demo




Wednesday 4 May 2011
Some links

                       QUnit
                       http://docs.jquery.com/Qunit

                       JsTestDriver
                       http://code.google.com/p/js-test-driver/

                       CI with JsTestDriver
                       http://j.mp/acO6QI




Wednesday 4 May 2011
Copyrights


                       Ben Scholzen (http://www.flickr.com/photos/dasprid/5142854471/in/
                       set-72157625158543743)

                       JsTestDriver schema (http://code.google.com/p/js-test-driver/)

                       Christian Johansen (http://cjohansen.no/)




Wednesday 4 May 2011

Contenu connexe

Similaire à Javascript Unit Testting (PHPBenelux 2011-05-04)

Open Source Test Workshop for QA Testers, Developers, IT Managers
Open Source Test Workshop for QA Testers, Developers, IT ManagersOpen Source Test Workshop for QA Testers, Developers, IT Managers
Open Source Test Workshop for QA Testers, Developers, IT ManagersClever Moe
 
Using+javascript+to+build+native+i os+applications
Using+javascript+to+build+native+i os+applicationsUsing+javascript+to+build+native+i os+applications
Using+javascript+to+build+native+i os+applicationsMuhammad Ikram Ul Haq
 
Koss, How to make desktop caliber browser apps
Koss, How to make desktop caliber browser appsKoss, How to make desktop caliber browser apps
Koss, How to make desktop caliber browser appsEvil Martians
 
SeaJS - 跨环境模块化开发实践
SeaJS - 跨环境模块化开发实践SeaJS - 跨环境模块化开发实践
SeaJS - 跨环境模块化开发实践lifesinger
 
Writing jQuery that doesn't suck - London jQuery
Writing jQuery that doesn't suck - London jQueryWriting jQuery that doesn't suck - London jQuery
Writing jQuery that doesn't suck - London jQueryRoss Bruniges
 
Efficient Dependency Detection for Safe Java Test Acceleration
Efficient Dependency Detection for Safe Java Test AccelerationEfficient Dependency Detection for Safe Java Test Acceleration
Efficient Dependency Detection for Safe Java Test Accelerationjon_bell
 
让开发也懂前端
让开发也懂前端让开发也懂前端
让开发也懂前端lifesinger
 
You're doing it wrong
You're doing it wrongYou're doing it wrong
You're doing it wrongAdam Goucher
 
The Fast, The Slow and the Lazy
The Fast, The Slow and the LazyThe Fast, The Slow and the Lazy
The Fast, The Slow and the LazyMaurício Linhares
 
Node js techtalksto
Node js techtalkstoNode js techtalksto
Node js techtalkstoJason Diller
 
Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011
Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011
Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011Finalist - open IT oplossingen
 
2010.10.30 steven sustaining tdd agile tour shenzhen
2010.10.30 steven sustaining tdd   agile tour shenzhen2010.10.30 steven sustaining tdd   agile tour shenzhen
2010.10.30 steven sustaining tdd agile tour shenzhenOdd-e
 
Programação GUI com jRuby
Programação GUI com jRubyProgramação GUI com jRuby
Programação GUI com jRubyFrevo on Rails
 

Similaire à Javascript Unit Testting (PHPBenelux 2011-05-04) (20)

Open Source Test Workshop for QA Testers, Developers, IT Managers
Open Source Test Workshop for QA Testers, Developers, IT ManagersOpen Source Test Workshop for QA Testers, Developers, IT Managers
Open Source Test Workshop for QA Testers, Developers, IT Managers
 
Beyond Page Objects
Beyond Page ObjectsBeyond Page Objects
Beyond Page Objects
 
Using+javascript+to+build+native+i os+applications
Using+javascript+to+build+native+i os+applicationsUsing+javascript+to+build+native+i os+applications
Using+javascript+to+build+native+i os+applications
 
Koss, How to make desktop caliber browser apps
Koss, How to make desktop caliber browser appsKoss, How to make desktop caliber browser apps
Koss, How to make desktop caliber browser apps
 
What's Cooking in Xtext 2.0
What's Cooking in Xtext 2.0What's Cooking in Xtext 2.0
What's Cooking in Xtext 2.0
 
SeaJS - 跨环境模块化开发实践
SeaJS - 跨环境模块化开发实践SeaJS - 跨环境模块化开发实践
SeaJS - 跨环境模块化开发实践
 
Namesmatter
NamesmatterNamesmatter
Namesmatter
 
Writing jQuery that doesn't suck - London jQuery
Writing jQuery that doesn't suck - London jQueryWriting jQuery that doesn't suck - London jQuery
Writing jQuery that doesn't suck - London jQuery
 
Efficient Dependency Detection for Safe Java Test Acceleration
Efficient Dependency Detection for Safe Java Test AccelerationEfficient Dependency Detection for Safe Java Test Acceleration
Efficient Dependency Detection for Safe Java Test Acceleration
 
让开发也懂前端
让开发也懂前端让开发也懂前端
让开发也懂前端
 
You're doing it wrong
You're doing it wrongYou're doing it wrong
You're doing it wrong
 
Groke
GrokeGroke
Groke
 
The Fast, The Slow and the Lazy
The Fast, The Slow and the LazyThe Fast, The Slow and the Lazy
The Fast, The Slow and the Lazy
 
Node js techtalksto
Node js techtalkstoNode js techtalksto
Node js techtalksto
 
New selenium rc
New selenium rcNew selenium rc
New selenium rc
 
CommonJS Frameworks
CommonJS FrameworksCommonJS Frameworks
CommonJS Frameworks
 
Einstein finalist.nl
Einstein finalist.nlEinstein finalist.nl
Einstein finalist.nl
 
Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011
Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011
Inspiratiemiddag_Vincent_Everts_Finalist generatie_einstein_komt_eraan_07042011
 
2010.10.30 steven sustaining tdd agile tour shenzhen
2010.10.30 steven sustaining tdd   agile tour shenzhen2010.10.30 steven sustaining tdd   agile tour shenzhen
2010.10.30 steven sustaining tdd agile tour shenzhen
 
Programação GUI com jRuby
Programação GUI com jRubyProgramação GUI com jRuby
Programação GUI com jRuby
 

Dernier

call Now 9811711561 Cash Payment乂 Call Girls in Dwarka Mor
call Now 9811711561 Cash Payment乂 Call Girls in Dwarka Morcall Now 9811711561 Cash Payment乂 Call Girls in Dwarka Mor
call Now 9811711561 Cash Payment乂 Call Girls in Dwarka Morvikas rana
 
CALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual serviceanilsa9823
 
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,dollysharma2066
 
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual serviceanilsa9823
 
2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)Delhi Call girls
 
CALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual serviceanilsa9823
 
Pokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy TheoryPokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy Theorydrae5
 
Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666nishakur201
 
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual serviceanilsa9823
 
$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...
$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...
$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...PsychicRuben LoveSpells
 
Top Rated Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated  Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...Top Rated  Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...Call Girls in Nagpur High Profile
 
call girls in candolim beach 9870370636] NORTH GOA ..
call girls in candolim beach 9870370636] NORTH GOA ..call girls in candolim beach 9870370636] NORTH GOA ..
call girls in candolim beach 9870370636] NORTH GOA ..nishakur201
 
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female serviceanilsa9823
 
Lilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptxLilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptxABMWeaklings
 
2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)Delhi Call girls
 
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girlsPooja Nehwal
 
Introducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdfIntroducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdfnoumannajam04
 
The Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by MindbrushThe Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by MindbrushShivain97
 

Dernier (20)

call Now 9811711561 Cash Payment乂 Call Girls in Dwarka Mor
call Now 9811711561 Cash Payment乂 Call Girls in Dwarka Morcall Now 9811711561 Cash Payment乂 Call Girls in Dwarka Mor
call Now 9811711561 Cash Payment乂 Call Girls in Dwarka Mor
 
CALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Jankipuram Lucknow best sexual service
 
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
8377087607 Full Enjoy @24/7-CLEAN-Call Girls In Chhatarpur,
 
(Anamika) VIP Call Girls Navi Mumbai Call Now 8250077686 Navi Mumbai Escorts ...
(Anamika) VIP Call Girls Navi Mumbai Call Now 8250077686 Navi Mumbai Escorts ...(Anamika) VIP Call Girls Navi Mumbai Call Now 8250077686 Navi Mumbai Escorts ...
(Anamika) VIP Call Girls Navi Mumbai Call Now 8250077686 Navi Mumbai Escorts ...
 
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Aliganj Lucknow best sexual service
 
2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Palam (Delhi)
 
CALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Mahanagar Lucknow best sexual service
 
Pokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy TheoryPokemon Go... Unraveling the Conspiracy Theory
Pokemon Go... Unraveling the Conspiracy Theory
 
Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666Call Girls Anjuna beach Mariott Resort ₰8588052666
Call Girls Anjuna beach Mariott Resort ₰8588052666
 
(Aarini) Russian Call Girls Surat Call Now 8250077686 Surat Escorts 24x7
(Aarini) Russian Call Girls Surat Call Now 8250077686 Surat Escorts 24x7(Aarini) Russian Call Girls Surat Call Now 8250077686 Surat Escorts 24x7
(Aarini) Russian Call Girls Surat Call Now 8250077686 Surat Escorts 24x7
 
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual serviceCALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
CALL ON ➥8923113531 🔝Call Girls Rajajipuram Lucknow best sexual service
 
$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...
$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...
$ Love Spells^ 💎 (310) 882-6330 in West Virginia, WV | Psychic Reading Best B...
 
Top Rated Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated  Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...Top Rated  Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated Pune Call Girls Tingre Nagar ⟟ 6297143586 ⟟ Call Me For Genuine Se...
 
call girls in candolim beach 9870370636] NORTH GOA ..
call girls in candolim beach 9870370636] NORTH GOA ..call girls in candolim beach 9870370636] NORTH GOA ..
call girls in candolim beach 9870370636] NORTH GOA ..
 
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Adil Nagar Lucknow best Female service
 
Lilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptxLilac Illustrated Social Psychology Presentation.pptx
Lilac Illustrated Social Psychology Presentation.pptx
 
2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)
2k Shots ≽ 9205541914 ≼ Call Girls In Mukherjee Nagar (Delhi)
 
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
9892124323, Call Girls in mumbai, Vashi Call Girls , Kurla Call girls
 
Introducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdfIntroducing to billionaire brain wave.pdf
Introducing to billionaire brain wave.pdf
 
The Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by MindbrushThe Selfspace Journal Preview by Mindbrush
The Selfspace Journal Preview by Mindbrush
 

Javascript Unit Testting (PHPBenelux 2011-05-04)

  • 1. Javascript Unit Testing Introduction to QUnit & JsTestDriver Wednesday 4 May 2011
  • 2. Tom Van Herreweghe PHP developer ZCE 5.0 & 5.3 I like Javascript http://blog.theanalogguy.be @miljar Wednesday 4 May 2011
  • 3. Overview Introduction to QUnit Introduction to JsTestDriver Wednesday 4 May 2011
  • 5. QUnit JS Unit Testing library JsUnit, DOH, YUI Test, ... JQuery http://docs.jquery.com/Qunit Wednesday 4 May 2011
  • 6. QUnit setup Demo Wednesday 4 May 2011
  • 7. QUnit structure module(‘name’[, {lifecycle}]) Wednesday 4 May 2011
  • 8. QUnit structure test(‘name’[, expected], test-code) Wednesday 4 May 2011
  • 9. QUnit structure Demo Wednesday 4 May 2011
  • 10. QUnit assertions ok(state[, ‘message’]) Wednesday 4 May 2011
  • 11. QUnit assertions equal(actual, expected[, ‘message’]) corresponds with: == Wednesday 4 May 2011
  • 12. QUnit assertions notEqual(actual, expected[, ‘message’]) corresponds with: != Wednesday 4 May 2011
  • 13. QUnit assertions Demo Wednesday 4 May 2011
  • 14. QUnit assertions deepEqual(actual, expected[, ‘message’]) corresponds with: === (recursive) Wednesday 4 May 2011
  • 15. QUnit assertions notDeepEqual(actual, expected[, ‘message’]) corresponds with: !== (recursive) Wednesday 4 May 2011
  • 16. QUnit assertions Demo Wednesday 4 May 2011
  • 17. QUnit assertions raises(function[, expected][, ‘message’]) Wednesday 4 May 2011
  • 18. QUnit assertions Demo Wednesday 4 May 2011
  • 19. Async testing the good: callbacks the bad: timers the ugly: currently not in QUnitAdapter for JsTestDriver Wednesday 4 May 2011
  • 20. Async testing Timers: hard to predict running time + slows down Wednesday 4 May 2011
  • 21. Async testing Callbacks: run assertions Wednesday 4 May 2011
  • 22. Async testing Currently not supported in QUnitAdapter Wednesday 4 May 2011
  • 23. Async testing stop() start() expect() asyncTest() Wednesday 4 May 2011
  • 24. Async testing Demo Wednesday 4 May 2011
  • 26. JsTestDriver Testrunner for your Unit Tests Written in Java Client / Server architecture http://code.google.com/p/js-test-driver Wednesday 4 May 2011
  • 28. JsTestDriver Custom syntax Need mapping from QUnit to JsTestDriver Some QUnit functionalities not (yet) available Wednesday 4 May 2011
  • 29. JsTestDriver module() test() ok() equals() same() (old name for deepEqual()) Wednesday 4 May 2011
  • 30. JsTestDriver Fetch JAR from http://code.google.com/p/js-test-driver/downloads/list Wednesday 4 May 2011
  • 31. JsTestDriver Run server java -jar /path/to/JsTestDriver-1.3.2.jar --port 4224 Wednesday 4 May 2011
  • 32. JsTestDriver Point browser(s) to http://localhost:4224 Wednesday 4 May 2011
  • 33. JsTestDriver Demo Wednesday 4 May 2011
  • 34. JsTestDriver Download QUnit adapter http://code.google.com/p/js-test-driver/wiki/ QUnitAdapter Wednesday 4 May 2011
  • 35. JsTestDriver Create config Wednesday 4 May 2011
  • 36. JsTestDriver Run tests java -jar /path/to/JsTestDriver-1.3.2.jar --config /path/to/jsTestDriver.conf --tests all Wednesday 4 May 2011
  • 37. JsTestDriver Demo Wednesday 4 May 2011
  • 38. Questions? Read more? Slideshare Joind.in Github https://github.com/Miljar/ PHPBenelux-BE-may Wednesday 4 May 2011
  • 40. Code Coverage Download plugin from http://code.google.com/p/js-test-driver/downloads/list Wednesday 4 May 2011
  • 41. Code Coverage Include plugin in config Wednesday 4 May 2011
  • 42. Code Coverage Add flags when executing tests --testOutput /path/to/outputfolder Wednesday 4 May 2011
  • 43. Code Coverage Install LCOV Wednesday 4 May 2011
  • 44. Code Coverage Generate HTML genhtml /path/to/jsTestDriver.conf-coverage.dat Wednesday 4 May 2011
  • 45. Code Coverage Demo Wednesday 4 May 2011
  • 46. Some links QUnit http://docs.jquery.com/Qunit JsTestDriver http://code.google.com/p/js-test-driver/ CI with JsTestDriver http://j.mp/acO6QI Wednesday 4 May 2011
  • 47. Copyrights Ben Scholzen (http://www.flickr.com/photos/dasprid/5142854471/in/ set-72157625158543743) JsTestDriver schema (http://code.google.com/p/js-test-driver/) Christian Johansen (http://cjohansen.no/) Wednesday 4 May 2011