PHPUnit - Unit testing

  • 2,217 views
Uploaded on

PHPUnit - Unit testing

PHPUnit - Unit testing

More in: Technology
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
  • very good slides
    Are you sure you want to
    Your message goes here
No Downloads

Views

Total Views
2,217
On Slideshare
0
From Embeds
0
Number of Embeds
0

Actions

Shares
Downloads
41
Comments
1
Likes
2

Embeds 0

No embeds

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
    No notes for slide
  • - Kiểm thử phần mềm là quá trình thực thi một hệ thống phần mềm để xác định xem phần mềm đó có đúng với đặc tả không và thực hiện trong môi trường như mong đợi hay không. - Mục đích của kiểm thử phần mềm:Tìmralỗichưađượcpháthiệnmộtcáchsớmnhất, hiệuquảnhấtĐảmbảolỗiđãđượcsửa- Kiểmthửphầnmềmkhôngkiểmtra code, khôngkiểmtra database, model, không debug, không fix bug
  • Unit testing : làkiểu test kiểmtra code xemliệuchứcnăngnóđangthựchiệncóđúngcách hay khôngtheonhưyêucầu.Integration testing : làkiểu test kiểmtraliệutấtcảcác module làđượckếthợphoặcchưakếthợplạicùngvớinhauthựchiệncôngviệccóđạtđượckếtquảnhưtàiliệuyêucầuđãđượcxácđịnh (do mỗilậptrìnhviênthựchiệntrêncác module khácnhau. Khihọhoànthànhđoạn code củahọ, nhómquảnlýcấuhìnhrápchúnglạivớinhauvàchuẩnbịbiêndịch. Các tester cầnchắcrằngcác module nàybâygiờđãđượckếthợpvàlàmviệctheonhưyêucầu - tứclàphải test theonhưyêucầu).- Functional testing : làkiểu test liệumỗivàmọichứcnăngcủaứngdụngđóđanglàmviệccónhưyêucầucủatàiliệu. Nólàkiểu test chínhmà 80% côngviệc test đượcthựchiện. Trongkiểu test nàythìcáctestcaseđượcthựchiện (hoặcthihành).- System testing:Khi tester hoànthànhcôngviệc test (các tester test ứngdụngtrongcácmôitrường test, nghĩalàhọ test vớidữliệu test, không test trêndữliệuthật), ứngdụng (phầnmềm) phảiđược test trênmôitrườngthật. Nónghĩalàgì, tứclàkểtừkhicác tester test nótrongmôitrường test vớidữliệu test, chúng ta phảichắcchắnrằngứngdụnglàmviệctốttrongmôitrườngthậtvớidữliệuthật. Trongmôitrường test, mộtvàiđiềukhôngthể test hoặcthaotácgiả. Tấtcảsẽkhácnhauvàcơsởdữliệukhácnhau, mộtsốthaotáccóthểkhônglàmviệcnhưmongđợikhiứngdụngđượcchuyểntừmôitrường test sang môitrườngsảnphẩm (test enviroment to production environment).- Load testing ? Làkiểu test kiểmtrathờigianđáplạingườidùngvớiứngsốlượngngườidùngbấtkỳtrongmộtngữcảnhnàođócủacùngmộtứngdụngtạicùngmộtthờiđiểm.- Stress testing làgì? Làkiểu test kiểmtrathờigianđáplạingườidùngvớiứngsốlượngngườidùngbấtkỳtrongnhiềungữcảnhkhácnhaucủacùngmộtứngdụngtạicùngmộtthờiđiểm.- Performance testing làgì? Trongloại test này, ứngdụngđược test dựavàosứcnặngnhưsựphứctạpcủagiátrị, độdàicủađầuvào, độdàicủacáccâutruyvấn...Loại test nàykiểmtrabớtphầntải (stress/load) củaứngdụngcóthểđượcchắcchắnhơn.- User acceptance testing làgì? Trongkiểu test này, phầnmềmsẽđượcthựchiệnkiểmtratừngườidùngđểtìmranếuphầnmềmphùhợpvớisựmongđợicủangườidùngvàthựchiệnđúngnhưmongđợi. Tronggiaiđoạn test này, tester cóthểcũngthựchiệnhoặckháchhàngcócác tester củariênghọđểthựchiện.- Regression testing làgì? Khimộtchứcnăngmớiđượcthêmvàophầnmềm, chúng ta cầnchắcchắnrằngphầnchứcnăngmớiđượcthêmvàokhôngpháhỏngcácphầnkháccủaứngdụng. Hoặckhilỗiđãđượcchỉnhsửa, chúng ta cầnchắcchắnrằnglỗichỉnhsửakhôngpháhỏngcácphầnkháctrongứngdụng. Để test điềunàychúng ta thựchiệnkiểu test lặpđilặplạigọilà test hồiquy.
  • Functional Testing: kiểmthửchứcnăng hay còngọikiểmthửhộpđen (blackbox)Black box làloại test mà tester đưagiátrịđầuvàovàkiểmtragiátrịđầurakhôngquantâmbêntronghoạtđộngnhưthếnào.Chủyếukiểmtragiaodiện, chứcnăngthiếu hay không, vv-Dựavàođặctảyêucầumàđưaracác test case: vìlàloại test chỉquan tam hệthốngphầnmềmcóhoạtđộngđúngnhưtrongyêucầu hay không, khôngquantâmbêntronglàmnhưthếnào-Chỉchútrọnghành vi bênngoàicủaphầnmềm.Structural Testing: kiểmthửcấutrúc hay còngọikiểmthửhộptrắng(white box)White box làloại test mà developer dựavàomã code củamìnhmàđưaracác test case.Test dựavàođiềukhiển logic (if else switch), điềukhiểnvònglặp (for while), cấutrúcdữliệubêntrongDựavàoviệcthựcthicủaphầnmềmmàđưaracác test caseChútrọngcấutrúcbêntrongcủaphầnmềm
  • Giátrịđầuvào: 2 đồngxu, gõcâyđũa ma thuậtGiátrịđầura: con thỏBlack box: khángiả chi nhìnthấyảothuậtgiabỏ 2 đồngxu, vàgõcâyđũavàocáinón, và con thỏxuấthiệnWhite box: khinhậnđược 2 đồngxuvàthấycáinónbịgõ, ngườibêntrongđưa con thỏchoảothuậtgia
  • Tiếntrìnhkiểmthử. Kiểmthửthườngbaogồmcácbước - Thiếtkếcáccakiểmthử - Bướctạodữliệuthử + Kiêmthửvớitấtcảcácdữliệuvàolàcầnthiết. + Chọntậpcácdữliệuthửđạidiệntừmiềndữliệuvào - Bướcthựcthichươngtrìnhtrêndữliệuthử + Cungcấpdữliệuthử + Thựcthi + Ghinhậnkếtquả - Bướcquansátkếtquảkiểmthử + Thựchiệntrongkhihoặcsaukhithựcthi + So sánhkếtquảnhậnđượcvàkếtquảmongđợi
  • Unit testinglàphươngpháp test đơnvịcủa source code đểxácđịnh code đểcóhoạtđộngđúngnhưmongđợikhông.Một unit cóthểlàmột class hoặchàmcủachươngtrình
  • Có 2 giaiđoạnchính:Trướckhi code hay còngọilàphươngpháp TDD(Test Driven Development: từviệc test dẫnđếnviết code để past test đó) - Tậptrungvàoyêucầucủachươngtrình - Nghĩđếnviệcviết code sẽđượcsửdụng - Ngưng code khiđạtđượcyêucầucủachươngtrình - KhókhănlúcbắtđầuSaukhi code xonghoặctronglúc code - Test chủyếuvàonhữngphầnđã code - Nghĩvềthuậttoánvà logic - Thayđổi code nhiềuhơn - Dễlúcbắtđầu
  • - Code test phảiđộclập, cáchbiệtvới code được test - Code test phảingắngọn (khoảng 10 dòng), đơngiản, nhanhvàdễđọc. - Khôngsửdụngcáccấutrúcđiềukhiểnvàvònglặptronghàm test. Mỗicâulệnh if else nêntáchthànhnhiềuhàm test khácnhau, mỗihàmlà 1 trườnghợp test - Mộthàm test chỉnên test cho 1 trạngthái. VídụtestFormAcceptValidData
  • PHPUnit là 1 framework viếtbằng PHP bởi Sebastian Bergmann.ThuộchọxUnit framework. xUnit frameworks: these unit testing frameworks are called the xUnit frameworks because their names usually start with the first letters of the language for which they were built.You might have CppUnit for C++, Junit for Java, Nunit for .NET.ĐượctíchhợpvàhỗtrợbởiZend Studio, Zend framework hay Symfony framework, doctrine
  • Chạybằng command line: phpunitđườngdẫnđến file testChạybằng IDE: - Zend: trướchết import library vào project: Project -> Properties -> PHP Include Path -> tab Libraries -> click nút Add Library -> chọn PHPUnit 3.x -> OK. Đểchạynhấpchuộtphảilên file -> Run As ->PHPUnit, hiệnkhungkếtquảphpunit - NetBean: kiểmtraphpunitđãthêmvàochưa: Tool -> Option -> tab PHP -> tab Unit Testing -> kiểmtrađườngdẫncủaphpunit “/usr/bin/phpunit”Đểchạy file -> Run -> Test file -> chỉthưmụcchứa file test -> OKĐểchạy test suite: right click tên project -> Properties -> PHPUnit , chọn file bootstrap nếucó, chọn file configuration xml nếucó, chọn check box chạytấtcả file cótênlà Test -> OKĐểhiện coverage report: right click tên project -> Code Coverage -> show reportChạybằng Continuous Integration (CI): tíchhợpliêntụcContinuous Intergration hay CI làmộtmôitrườnghỗtrợpháttriểnphầnmềmcóchứcnănggiúpcácthànhviêntrong team tíchhợp (integrate) côngviệccủahọmộtcáchthườngxuyên, liêntục. Mỗiđiểmtíchhợpsẽđượckiểmtra (verified) bởimột qui trình build và test tựđộngđểđảmbảopháthiệnsớmnhấtnhữnglỗiphátsinhtrongquátrìnhtíchhợpđó.Giảiphápnàythựcsựgiúpchocácnhàpháttriểnphầnmềmgiảmbớtcácvấnđềphátsinhtrongquátrìnhtíchhợpvàchophépcôngviệcpháttriểnphầntrởnênmềmnhanhchóngvàgắnkếthơn. CI baohàmmộtloạtnhữngquátrìnhđượcgắnkếtvớinhaunhư: automated build, coding standard check, static analysic, unit test, depoyingvàintergation test...
  • Cácchứcnăngchínhcủaphpunit - Test dependency - Data provider - Exception - Fixture - Double - Code coverage
  • Vớiviệc test thôngthường, để test 1 hàm, chúng ta truyềnvàothamsốsauđólấykếtquảtrảvề so sánhvớikếtquảchúng ta mongmuốn, sauđóxuất reportTest nhiềugiátrịđầuvào, viết code lậplạinhiềulần, mấtthờigianvìvậysửdụng data provider
  • Data provider cungcấpdữliệuđể test. Dữliệunàycóthểlàgiátrịthamsốtruyềnvàohàmhoặcgiátrịmongmuốntrảvề, v.v
  • Yêucầuđốivớiviệc test làcácthànhphầnphảiđược test riêngrẽvớinhauđểkếtquảcủathànhphầnkhôngbịảnhhưởngbởithànhphầnkhácvídụkhichúng ta gọiđến service đểlấykếtquảvàsauđólấykếtquảđểtínhtoántiếpchocôngviệccủachúng ta thìbắtbuộckếtquảtrảvềluônluônphảiđúngđểbiếtchắcnếu test củachúng ta bị fail là do code củachúng ta chứkhôngphải do service làmsai. Đểlàmđiềuđóđôikhichúng ta phảigiảlậpnhữngthànhphầnđóđểđảmbảo test đượccôlậpvàchínhxác. Việcgiảlập 1 đốitượngđượcgọilà test doubles.Ý tưởngcủa test double chỉgiảlập 1 phầncủa object, thườnglà 1 method nàođócần test chứkhônggiảlậptoànbộ object.Test double khôngphảithiếtkếmộtchotấtcảnêntùyvàotrườnghợpmàsửdụngcácloại double khácnhau. Test double cómấyloạisau:Dummy: là 1 object màđơngiảnđượcthông qua đểthỏamãncácphươngthứccầnkiểmtra. Nólà test double đơngiảnnhấtmàbạncóthểxâydựngStub cungcấpnhữngkếtquảđóngkhiđượcgọiSpy ghilạinhữnglầngọivàthamsốđểbạncóthểkiểmtrachúngsaunàybêntronghàm testMock giốngnhư Spy nhưngkiểmtralầngọingaylậptứcdựatheonhữnggìmàbạnđãđịnhnghĩatrướcđó. Nócũngcóthểcungcấpkếtquảđóng.Fake làsựthựcthimộtcáchđơngiảnnhấtcóthểcủamột object thậtchẳnghạnnhư DAO.Trongđóchúng ta chỉchú ý đặcbiệtđến Stub và Mock vìlà 2 đốitượngthườngdùng.Stub object làbảnsaocủamột object khácđượcchúng ta địnhnghĩatrướcvàtrảvề 1 kếtquảđóngcủamộtphươngthứctrong object đócũngđượcđịnhnghĩatrướcMock : điểmkhácnhaucănbảngiữa Stub và Mock là Mock khôngchỉgiảlập object màcònchokiểmtranhữnggìbạntruyềnchonóvàcáchbạngọinó.

Transcript

  • 1. LOGO “ Add your company slogan ” Keep it Simple Stupid Presentation by: Thu.Nguyen
  • 2. CONTENT KiSS Concept Q&A Demo PHPUnit Unit Testing Software Testing
  • 3. KiSS Concept
  • 4. What is Software Testing?  Testing is the process of executing a program with intent of finding errors (The art of software testing – Glenford J.Myers) 4 Our program The output is correct? I1, I2, I3, …, In, … Expected results = ? Obtained results “Inputs” - No code inspection - No code analysis - No model checking - No bug fixing - No debugging
  • 5. Level of testing KiSS Concept Unit Testing Integration Testing Functional Testing System Testing Load/Stress Testing User Accepted Testing Regression Testing Programmer Tester
  • 6. Testing Techniques Functional Testing (Black box)  Select test cases based on the requirement or design specification  Emphasize on the external behavior of software Structural Testing (White box)  Select test cases based on the implement of software  Emphasize on the internal structure of software KiSS Concept
  • 7. Black box vs White box KiSS Concept
  • 8. Process of testing KiSS Concept Test cases Design test cases Prepare test data Run program with test data Test data Test results Test reports Compare results to test cases
  • 9. KiSS Concept
  • 10. What is unit testing? KiSS Concept  “In computer programming, unit testing is a method by which individual units of source code are tested to determine if they are fit for use. A unit is the smallest testable part of an application.” (Wikipedia)  A “unit ” is the smallest testable part of an application: a function or class method.
  • 11. Benefit of unit testing  Easy to defect error KiSS Concept
  • 12. Benefit of unit testing  Safer refactoring KiSS Concept
  • 13. Benefit of unit testing  Automated test KiSS Concept
  • 14. Benefit of unit testing  Long term of saving time and money KiSS Concept
  • 15. When do you write the test?  Focus on requirements  Thinking about how to code will be consumed  Stop coding when meet requirement  Harder initially  Focus on code  Thinking about algorithm  More refactoring  Easier initially KiSS Concept Before coding(TDD) After/During coding
  • 16. How do I test?  Isolate with the code being tested  Short, simple, fast, readable  No conditional logic or loop (if, switch, while)  One test should be one behavior KiSS Concept
  • 17. KiSS Concept
  • 18. Introduction KiSS Concept  Is a unit testing framework written in PHP, created by Sebastian Bergmann.  Part of the xUnit family of testing frameworks.  Integrated/supported • Zend Studio • Zend Framework • Symfony • Doctrine
  • 19. Installation KiSS Concept Install with PEAR: pear channel-discover pear.phpunit.de pear install phpunit/PHPUnit Update: pear upgrade phpunit/PHPUnit Xdebug: sudo apt-get install php5-xdebug php5-dev Set include path in /etc/php5/cli/php.ini include_path = “.:/usr/share/php”
  • 20. Definitions KiSS Concept Test suite Test suite Test case setUp() testMethod tearDown() /* * *@annotation */ testMethod(){ assertion } Report Test case setUp() testMethod tearDown() /* * *@annotation */ testMethod(){ assertion } Code coverage Logging
  • 21. Simple test KiSS Concept
  • 22. Running test KiSS Concept Go to command line and run: phpunit /path/to/file/test.php or phpunit classname /path/to/file/test.php
  • 23. Running test  Command line  IDE  Zend Studio  NetBean  Continuous Integration  phpUnderControl  Cruise Control KiSS Concept
  • 24. Result  OK: all tests are successful  FAILURES: test is fail or error  Result of each test: • . test succeeds • F an assertion fails • E an error • S test has been skipped • I test is marked as being incomplete or not yet implement KiSS Concept
  • 25. Features  @dataProvider  @exception  Fixture: setUp() and tearDown()  Double: stub and mock object  Database  Code coverage KiSS Concept
  • 26. Data provider  Is a method that returns an array of values to use in a test.  Makes tests shorter and more concise.  Data provider can use array or file csv. KiSS Concept
  • 27. Data provider KiSS Concept Input 1 myfunction() Report 1Result 1 Expected 1 compare Input 2 myfunction() Report 2Result 2 Expected 2 compare Input 3 myfunction() Report 3Result 3 Expected 3 compare
  • 28. Data provider KiSS Concept /* * @dataProvider */ testMethod($input, $expect) { myfunction() } Report 1 Data Providers Input 1 expect1 Input 2 expect 2 Input 3 expect 3 Report 2 Report 3
  • 29. Use array KiSS Concept
  • 30. Use csv file KiSS Concept
  • 31. Exception  Test exception are thrown.  Test expected messages of exception are thrown. KiSS Concept
  • 32. Example exception KiSS Concept
  • 33. Fixtures  Is constructor method and destructor method in test case  PHPUnit supports 2 methods: • setUp(): the function run when test methods start to run • tearDown(): the function run after test methods end KiSS Concept
  • 34. Fixtures KiSS Concept Start setUp() testOne() testTwo() testThree() tearDown() End
  • 35. KiSS Concept Example fixtures
  • 36. Test double KiSS Concept MyClass myMethod($object) { …$object->otherMethod(); … } Database Connection File system Web service Function depends on other objects, other components
  • 37. KiSS Concept MyClass myMethod() { …other Method … } Database File system Web service MyClassTest testMyMethod() { … … } Test double How to isolate environment ?
  • 38. Test double KiSS Concept MyClass myMethod() { …other Method … } Database Mock File system Mock Web service Mock MyClassTest testMyMethod() { … … } Set mocks Solution: use copy object Test double return fixed value
  • 39. Stub and Mock  Set method return values  Test state  Check method calls  Check arguments used  Test interactions KiSS Concept Stub Mock
  • 40. Example stub object KiSS Concept
  • 41. Example mock object KiSS Concept
  • 42. Database testing  Set up database connection.  Set up initial dataset.  Provide methods to get dataset from database.  Provide methods to compare two datasets.  Type of dataset  Flat XML  XML  CSV  MySQL dump KiSS Concept
  • 43. Organizing  Allow to organize tests to test suite to run one time  Use file system:  All test files end with „Test‟.  Organize directory structure.  Use configuration file: phpunit.xml KiSS Concept
  • 44. Use file system KiSS Concept
  • 45. Use phpunit.xml KiSS Concept
  • 46. Code Coverage KiSS Concept  Help to see what are executed when the tests are run.  Help to find code that is not yet tested.  Help to measure testing completeness.
  • 47. Code Coverage KiSS Concept
  • 48. Code Coverage KiSS Concept Red: code is not executedGreen: code is executed Test cases cover this line code Grey: dead code Note: dead code is source code which is executed but whose result is never used.
  • 49. Logging Test results HTML  <log type="testdox-html" target="./log/testdox.html" /> KiSS Concept
  • 50. Logging Test result XML  <log type="junit" target="./log/logfile.xml" /> KiSS Concept
  • 51. KiSS Concept
  • 52. References  PHPUnit manual  Training course PHPUnit – Nick Belhome,2010  Unit Testing with PHPUnit – Michelangelo van Dam  Ini2it Unit Testing after ZF 1.8 - Michelangelo van Dam  PHPUnit From Zero To Hero – Jeremy Cook  PHPUnit & Continous Intergration – AlexMace  Advanced PHPUnit Testing – Mike Lively  Practical PHP Testing Patterns  http://framework.zend.com/manual/1.12/ru/zend.test.phpunit.db.html KiSS Concept
  • 53. QUESTION & ANSWEAR KiSS Concept
  • 54. LOGO “ Add your company slogan ” Keep it Simple Stupid