Debugging Sucks! Testing Rocks!

Tale članek sem se spravil pisat že dobro leto nazaj. Vmes sem tudi sformatiral disk in so šle stvari v tri … Kljub temu da je članek še vedno nedokončan sem se odločil da ga objavim, saj bo marsikomu v pomoč pri prvih korakih TDD-ja.

Prvi odziv programerjev ob omembi Test-Driven Developmenta je ponavadi negativen, saj pomislijo le na eno: “Tole mi bo pa vzelo dodatnih 50% več časa pri razvoju aplikacij.” Podoben odziv sem pred kratkim doživel pri “naših” programerjih, ko sem jim kazal kako naredimo “Acceptance Test” z uporabo Selenium RC-ja.[1]
Zgornja trditev bi načeloma veljala samo če bi se življenski cikel aplikacije zaključil z prvo produkcijsko verzijo, ter ob klasičnem razvoju Dizajn-Implementacija-Testiranje[2]. To zgodbo najverjetneje vsi poznamo:
“Imamo dva programerja, ki vsak zase nadgrajujeta svoj del že žive aplikacije. Ob združitvi kode, zgleda kot, da je vse ok. Čez čas dobita klic[3], da določene stvari ne delajo, čeprav so prej delale. Vsak posebej za iskanje in razhroščevanje kode porabita polovico dneva.”
Take in podobne zgodbe so lahko preteklost. Rešitev je TDD.

Kaj je TDD

Test-Triven Development (TDD) je razvojna tehnika za softver. Z TDD tehniko stvari postavimo malce na “glavo”. Teste pišemo preden začnemo pisat implementacijsko kodo!. Test pelje oziroma diktira kodo ki se razvija.[4]
TDD cikel pri razvoju aplikacij izgleda nekako takole:

  • Dizajn: Pogruntamo kaj želimo narediti
  • Test: Napišemo test, ki izraža naš dizajn.
    • Test ne bi smel uspeti – FAIL
  • Implementacija: Napišemo kodo
  • Test: ponovno
    • Test bi moral uspeti – PASS
  • Refactoring po potrebi
  • Ponavljaj

Še vedno vas je strah da bo več dela. Malce pa res. :)
Tri različne študije (Microsoft, IBM, John Deere / Ericsson) so pokazale:

  • TDD projekti imajo dva krat večjo kvaliteto kode.
  • Pisanje testov vzame le 15% več časa – dolgoročno gledano.
  • Število hroščev in defektov je manjše za 40%.
  • Skupinska produktivnost se poveča za 16%.

Testiranje

Kaj potrebuje testiranje?
- Backend: programska logika in ponovno uporabljene komponente
- Frontend: procesiranje form, templatov, bogata vsebina z uporabo “AJAX-a#, JSON, RSS Feed, Web Servisi

Kako testiramo?
- Backend: test funkcionalnosti programske logike z Unit Testi
- Frontend: “Acceptance” in Sistemski testi, ki se izvajajo na brskalniku, Testiranje RSS Feedov, Web servisov z Unit Testi, Kompatibilnostni testi …

Acceptance testing

je testiranje na določenem sistemu po principu “črne škatle“. Acceptance test zagotavlja da koda počna to kar želi “stranka”[5], ne pa pričakovanj razvijalca! Temu testiranja bi lahko preprosto rekli tudi testiranje funkcionalnosti. Pa poglejmo kako implementirati Acceptance Test z “ubijalsko kombinacijo” PHPUnit in Selenium.

Priprave na testiranje

Zahteve:

V tem članku uporabljamo PHPUnit, kateri od verzije 3.0 naprej, vsebuje PHPUnit_Extensions_SeleniumTestCase razred, katerega lahko uporabljamo za definicijo Acceptance testov. Sam razred pa za opravljanje testov potrebuje Selenium Core. Zelo pomembno je, da ne pozabimo da to NI Unit testiranje. PHPUnit je knjižnica za “Unit Testing”, med drugim pa je framework prav tako uporaben za integracijske ter acceptance teste.

Inštalacija PHPUnit:
Priročnik PHPUnit-a priporoča inštalacijo frameworka z uporabo PEAR Installer-ja. PEAR kanal (pear.phpunit.de), kateri se uporablja za distribucijo PHPUnit-a bora biti registriran z lokalnim PEAR okoljem.[7] Ko to enkrat naredimo, uporabimo PEAR za inštalacijo paketa od PHPUnit kanala.
Inštalacija PHPUnita
Inštalacija PHPUnita
PHPUnit dokumentacijo za Selenium najdete na http://www.phpunit.de/pocket_guide/3.2/en/selenium.html. Sedaj nam preostane še da iz PEAR kanala inštaliramo Testing_Selenium paket, ki ga potrebuje PHPUnit Selenium podaljšek.


Inštalacija paketa Testing_Selenium
Inštalacija paketa Testing_Selenium

Selenium:
je paket orodij za avtomatsko testiranje spletnih aplikacij. Vsebuje kar nekaj paketov, med drugim Selenium Core, Selenium RC, Selenium IDE, … Selenium Core opravlja aktivnosti uporabnika, izvaja test in obvešča o rezultatih testa. Selenium RC je dodatni serverski proces, ki ga rabimo, če želimo izvajati teste z PHPUnit podaljškom za Selenium. Njegov glavni namen je da omogoča izbranemu programskemu jeziku interakcijo z Selenium Core ki laufa na brskalniku z uporabo preprostega HTTP GET klica do RC strežnika. Komplicirano?!
Najnovejši Selenium RC dobite na http://selenium-rc.openqa.org/download.html. Po tem ko raspakiramo paket v njem najdemo kar nekaj map. V eni izmed njih je Selenium server, ostali so client driverji za različne programske jezike. Mi smo ga za PHP že inštalirali preko PEAR instalerja. Selenium RC zaženemo preprosto iz command lina:

java -jar selenium-server.jar -interactive

Še prej pa smo seveda inštalirali Javo. :)

Inštalacija Xdebug-a:
Xdebug je podaljšek za PHP, ki primarno služi za “debugging” – razhroščevanje kode, pri čemer je sposoben navrčt celo paleto koristnih informacij. Zna pa še narediti profil – “profiling” skripte in analizo pokritosti kode – “code coverage analysis”. Prav slednjo zadevo bomo pokazali v našem članku. Velja si zapomniti, da Xdebug ni potreben za izvajanje testov in da ga ne morete imeti naloženega skupaj z Zend Debuggerjem.
Najlažje je Xdebug inštalirati preko PEAR/PECL kanala.

pecl install xdebug

V php.ini dodamo tole klobaso[8] za temeljit izpis informacij, remote debugging ter profiling na triger:

[Xdebug]
zend_extension="/opt/local/lib/php/extensions/no-debug-non-zts-20060613/xdebug.so"
;General
xdebug.default_enable=On
xdebug.show_exception_trace=Off
xdebug.show_local_vars=1
xdebug.max_nesting_level=50
xdebug.var_display_max_data=3072
xdebug.var_display_max_depth=12
xdebug.dump_once=On
xdebug.dump_globals=On
xdebug.dump_undefined=On
xdebug.dump.REQUEST=*
xdebug.dump.SERVER=REQUEST_METHOD,REQUEST_URI,HTTP_USER_AGENT
xdebug.collect_params=4
xdebug.collect_includes=On
xdebug.collect_return=On
xdebug.show_mem_delta=On

;Remote debugging
xdebug.remote_enable=On
xdebug.remote_host="localhost"
xdebug.remote_port=9000
xdebug.remote_handler="dbgp"

;Profiling
; Turns it off by default
xdebug.profiler_enable=0
; Turns xdebug on when ?XDEBUG_PROFILE=true is in GET or POST
xdebug.profiler_enable_trigger=1
; Your output directory - you'll eventually point webgrind at this
xdebug.profiler_output_dir="/tmp"

O samem orodju podrobno kdaj drugič. Gremo nazaj na testiranje.

Pisanje in zagon acceptance testov

Osnovna forma za acceptance test z PHPUnit in Selenium RC je zelo preprosta.

/** PHPUnit_Extensions_SeleniumTestCase */
require_once 'PHPUnit/Extensions/SeleniumTestCase.php';

class MonetaOrderTest extends PHPUnit_Extensions_SeleniumTestCase
{
    protected function setUp()
    {
        /**
         * '*firefox' => Firefox 1 or 2
         * '*iexplore' => Internet Explorer (all)
         * '*custom /path/to/browser/binary => Other browsers (incl. Firefox on Linux)
         * '*iehta' => Experimental Embedded IE
         * '*chrome' => Experimental Firefox profile
         */
        $this->setBrowser(*firefox /Applications/Firefox2.app/Contents/MacOS/firefox-bin);
        $this->setBrowserUrl(http://gateway.home.internet-solutions.si);
    }

    /**
     * Test if
     * label First Name exists
     * element firstName exists
     *
     */
    public function testFirstNameExists()
    {
        //open test/moneta
  	$this->open(http://gateway.home.internet-solutions.si/test/moneta');
  	/** First Name */
  	//label exist
        try {
            $this->assertEquals("First Name", $this->getText("//form[@id='moneta']/dl/dt[1]/label"));
        } catch (PHPUnit_Framework_AssertionFailedError $e) {
            array_push($this->verificationErrors, $e->toString());
        }
        //element present
        $this->assertTrue($this->isElementPresent("firstName"));
    }
}

Metoda setUp() se uporablja za “zagon” testa. Tukaj definiramo kateri brskalnik se naj koristi. Firefox je le ena od možnih opcij. V primeru da Selenium RC ne vsebuje privzete reference za vaš priljubljeni brskalnik[9] lahko uporabite prefix “*custom” pri kateremu določite pot do vašega izbranega brskalnika. Metoda setBrowserUrl() nastavi URL iz katerega potekajo vsi testi.

Če vas zanima še kaj o test driven developmentu me kontaktirajte.

Happy blogging(coding)!

  1. podrobno bom predtavil testiranje z Selenium RC v današnjem članku []
  2. če je sploh kaj testiranja pred produkcijo []
  3. ponavadi od stranke, katero pa opozorijo uporabniki []
  4. Sedaj vemo od kod ime Test-Driven Development []
  5. uporabnik, brskalnik []
  6. opcijsko – ni pogoj za izvajanje testov []
  7. predvidevajmo da imate PEAR že inštaliran []
  8. v njej prilagodite pot do podaljška []
  9. v kar dvomim ;) []

Sorodni zapisi:

september 16th, 2008Enostavno je težje

Simple Is Hard

Med pucanjem pošte sem naletel na link, ki me je pripeljal do slidov Rasmusa Lerdorfa. Prezentacija je iz avgustovske Drupal konference, ki je potekala pri naših sosedih.
Programerji smo baje čudna bitja. :) Odvisni smo od kompleksnosti in dostikrat ne znamo poiskati enostavno in očitno rešitev danega problema. To potem škodi performansi, skalabilnosti in varnosti aplikacij.[1]

Avtor nam na primeru Laconice[2] nazorno pokaže kako z enostavnimi, preprostimi prijemi izboljšamo performans aplikacije.
Read the rest of this entry »

  1. največ pa živcem nadrejenih []
  2. odprto kodna platforma za mikrobloging []

Sorodni zapisi:

Dan D

Skoraj 10 let je od tega odkar sem napisal svojo prvo “aplikacijo” v PHP-ju. Skriptica je bila napisana v verziji 3[1]. Brala je novice iz tekstovne datoteke in jih prikazovala na spletni strani, Amerika ;)
Prav toliko let je minilo da sem jo le dočakal … Koga pa?
Prvo slovensko PHP konferenco, ki se je pripetila 5 julija 2008 v prostorih Instituta Jožef Stefan v Ljubljani. Glavni krivec za njeno splavitev je Anže Žnidaršič, vodja tima razvijalcev na PRO PLUS d.o.o. (POP TV / Kanal A). Posebna zahvala gre še podjetju Domenci, partnerju in glavnemu pokrovitelju konference.
Glavni namen konference je bil vsekakor deliti znanje[2] ter nabirati nova spoznanstva. To je bil vsekakor dober povod za udeležbo, čeprav ste mogoče že stari maček v znanju PHP-ja. Vedno je zanimivo slišati videnja ter način razmišljanja prekaljenih PHP razvojnikov.
Kljub temu, da sem bil z samo vsebino predavanj (Eclipse, Subversion, PHP frameworki, Template sistemi, Mootools, Unit in sistemsko testiranje kode, optimizacijo PHP kode …) že precej seznanjen[3], sem pridno in pozorno poslušal predavatelje :)
Zatopljen v predavanja ...
Zatopljen v predavanja …

Read the rest of this entry »

  1. 4 je bila še v zametkih []
  2. podobno kot se jaz trudim na blogu – za narodov blagor ;) []
  3. trenutno uporabljam, jo uporabljal v preteklosti ali vsaj testiral []

Sorodni zapisi:

Zend Studio

Pred nekaj dnevi sem želel preizkusiti nov Zend Studio For Eclipse 6.0.1. O samem PHP IDE-ju ne bi preveč razglabljal. Profesionalno orodje za bolj zahtevne uporabnike. Meni osebno je najbolj všeč Code Assist, integriran Debuging, Source Control z lokalno zgodovino, ter podpora za PHPUnit testing.
Beseda, dve o debugerju. Zend Studio omogoča lokalno in oddaljeno (na serverju) debugiranje. Za remote debugging rabite “Web Server Debugger”, kar je za Server-Client arhitekturo nekaj samoumevnega. Obstajata dva načina za to:

Inštalacija slednjega je elegantnejša in manj boleča za Apache in PHP :)

Read the rest of this entry »

Sorodni zapisi:

Pred dobrim tednom sem si omislil VPS (virtual private server). Potreba po VPS-ju izhaja predvsem po želji izboljšati znanje Linux-a in administracije strežnikov.
Izbira ponudnika spletnega gostovanja je kar teška odločitev, saj jih je kot gob po dežju. Izbral sem Host Europe, prvensteveno zaradi nizke cene 20 EUR.
V drugem planu pa me je pritegnila dodatna ponudba: Hardware, lastna izbira operacijskega sistema (Debian, Ubuntu, SUSE). Do sedaj sem imel opravka z Debianom in Ubuntujem.
Ker sem slednjega malenkost več uporabljal, sem se odločil za Ubuntu brez Pleska. Prvotno veselje je malce popustilo, ko sem pogruntal da je distribucija Ubuntuja, ki je inštalirana na VPS-ju trenutno še verzija 6.06 iz junija 2006, kar dejansko pomeni da so softverski paketi že malce zastareli. Next time read FAQ! :)
Read the rest of this entry »

Sorodni zapisi:

januar 11th, 2008Creatoor išče programerje

O podjetju:
Podjetje Creatoor d.o.o. je hitro rastoče podjetje ter član tehnološkega parka Ljubljana. Podjetje, ki je v lanskem letu zabeležilo 100% rast.
Ukvarjamo se z izdelavo naprednih spletnih in namiznih aplikacij ter izdelavo spletnih strani in portalov.

Zaradi povečanega obsega dela, ter širjenja na nove trge iščemo več novih sodelavcev.

Opis delovnega mesta:
Iščemo kreativne, izkušene ter predvsem proaktivne sodelavce, ki bodo skupaj z nami ustvarjali napredne spletne rešitve. Iščemo ljudi, ki si želijo izzivov in so željni novih znanj.

Pričakujemo izkušnje s področij:

  • Programiranje v PHP 5 (objektno)
  • Znanje s področja MySQL-a
  • HTML, CSS, JavaScript

Zaželjeno je tudi poznavanje:

Nudimo ter pričakujemo:
Ponujamo vam prijetno delovno okolje, delo v odličnem mladem in ambicioznem timu. Možnost redne zaposlitve, dobro plačilo ter redna izobraževanja s področja programiranja (tečaji, seminarji, delavnice,…).

Od vas pričakujemo, delavnost, izkušnje, odgovornost, proaktivnost, veselje do dela v timu in predvsem željo po razvijanju naprednih spletnih rešitev.

Sorodni zapisi:

november 13th, 2007Zakaj obožujem Zend Framework?

A je to framework?
Pred kratkim sem web programerjem iz podjetja Creatoor, predaval o Zend Frameworku. Prva stvar ki jo najprej izpostavim, ko govorim o Zend Frameworku je ta, da za mene to ni “framework”, vsaj ne po tistem kar pravi definicija. To najprej povzroči zmedenost in nerazumevanje kaj sploh Zend Framework je. Za mene je to le “knjižica”[1] skript. Med množico modulov, lahko enostavno izberemo in uporabimo le tistega, ki ga rabimo. Čeprav so določeni moduli med sabo odvisni, se da ta lastnost v večini primerih povoziti.[2] Zadevi, ki sta mene najbolj pritegnili oziroma “prisilili” da sem upokojil lastne napisane knjižice sta:

Read the rest of this entry »

  1. Library []
  2. overriding, subclassing []

Sorodni zapisi:

Napake 404, 403, 500 …
Del vsadanjika, ki ga preživim za računalnikom, med drugim namenim izdelavi “skeleton” web aplikaciji, ki jo bom v prihodnje uporabljal pri vseh mojih spletnih projektih. V želji, da bi bil izdelek čim bolj robusten in uporabniku prijazen, sem že v začetku precej razmišljal o morebitnih napakah, ki se lahko pojavijo, ter ustreznemu reagiranju na njih. Nastal je “Error Handler” ki skrbi za dve[1] najbolj pogosti napaki spletnega protokola HTTP.
Read the rest of this entry »

  1. v bistvu handlam tri []

Sorodni zapisi:

oktober 16th, 2007SQL Server 2005 driver za PHP

Čudna so pota gospodova ;)

Že nekaj časa je znano da sta Zend in Microsoft staknila skupaj glave. Slednjim je najbrž “kapnilo” kako velik je “PHP Community” in so si zaželeli svoj delež pogače. Rezultat je ganc[1] novi SQL Server 2005 (CTP) gonilnik za PHP. Res lepo darilo nam PHP developerjem.
SQL gonilnik za PHP bo s svojim API-jem omogočal zanesljivo integracijo z SQL strežnikom za PHP aplikacije razvite na Windows platformi. Sam gonilnik je PHP 5 “extension”. Deluje na vseh izdajah SQL Server 2005 in SQL Server 2000[2].
Read the rest of this entry »

  1. čisto []
  2. tudi Express Edition []

Sorodni zapisi:

Obvestila, opozorila !?
Prav čudno zveni ta naslov v prevodu ;) Bom kar po domače povedal: pretvorba PHP “notices” in “warnings” v “Exceptions”. Najverjetneje je sedaj slika malce bolj jasna. Po planu nisem imel namena objavit tega prispevka, ker pa ravno delam “skeleton” za eno aplikacijo sem izkoristil priložnost. Namig o konvertiranju opozoril in obvestil sem zasledil na netu že kar nekaj časa nazaj. Pred dnevi sem med arhiviranje starih mailov naletel na “reminder” in sem na brzino pokukal na omenjeni post. Dobil sem idejo, da lahko zadevo uporabim s svojo “debug” funkcijo za “handlanje” izjem – Exceptions.
Read the rest of this entry »

Sorodni zapisi:


© 2007 Internet Solutions | iKon Wordpress Theme by TextNData | rakCha web directory