LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Perl (105) - Testování programových jednotek

Perl Při komplexnějších úlohách bývá zvykem testovat funkčnost jednotlivých komponent (například podprogramů). Předvedeme si jeden z nástrojů, jak na to.

15.3.2010 12:00 | Jiří Václavík | Články autora | přečteno 6143×

Testování programových jednotek (unit testing) znamená ověřování správného chodu jednotlivých úseků programu. Je to tedy metoda hledání chyb.

Testovat lze libovolný úsek programu, u kterého to má smysl. Často se například testují podprogramy nebo metody.

Záměrem je právě testovaný úsek maximálně izolovat od zbytku programu. Měl by být na okolí co možná nejnezávislejší.

Unit testing a Perl

Podívejme se na úvod na nejjednodušší možný test.

Příklad testu

Zde je zdrojový kód.

print "1..2\n";
print 1 == 1 ? "ok 1\n" : "not ok 1\n";
print 1 == 2 ? "ok 2\n" : "not ok 2\n";

Prvním řádkem avizujeme, že uděláme dva testy, které na dalších dvou řádcích následují. Tento zápis je obvyklou konvencí. Spuštěním takového programu získáme následující výstup.

1..2
ok 1
not ok 2

První test dopadl podle očekávání úspěšně, druhý nikoliv.

Testy pomocí modulu Test::More

V Perlu se dá pro usnadnění testování použít řada modulů. Podíváme se zde speciálně na modul Test::More. Naučíme se používat některé jeho funkce.

Modul Test::More zavádíme obvykle s parametrem, kterým říkáme, kolik testů budeme provádět. Zde je příklad.

use Test::More tests => 10;

Pokud zadáme jiný počet, než nakonec provedeme, program si na konci postěžuje. Modul lze také zavádět s parametrem no_plan. To znamená, že počet testů neznáme. V takovém případě se budou normálně provádět testy, na které program narazí, ale ztratíme tím některé možností.

use Test::More "no_plan";

Lepší než no_plan však často je lepší dodat počet testů na konci. Pak má program následující schéma.

use Test::More tests => 2;

# testy

done_testing(pocet_testu);

Náš první příklad bychom mohli přehledněji přepsat pomocí exportované funkce ok do následující podoby.

use Test::More tests => 2;
ok(1 == 1);
ok(1 == 2);

Spustíme-li tento program, provede se totéž jako prve, ale navíc zde přibyde nějaký závěrečný komentář o tom, kolik testů našlo chyby.

1..2
ok 1
not ok 2
#   Failed test at more.pl line 3.
# Looks like you failed 1 test of 2.

Příklad testování modulu

Vybereme si nějaký modul a ukážeme pomocí něj několik věcí, které můžeme testovat. Zvolíme například modul Math::Complex, který zavádí objekty typu komplexní číslo a provádí s nimi základní operace.

Nejprve uveďme, že funkci ok lze předat jako argument komentář, který se má objevit na výstupu.

Nyní zkusme udělat několik jednoduchých testů.

use Test::More tests=>4;
use Math::Complex;

$z1 = Math::Complex->make(1, 2);
$z2 = Math::Complex->make(3, 4);
$z3 = Math::Complex->make(4, 6);
$z4 = Math::Complex->make(-8, 10);

ok(defined $z1, "metoda make chodi. Vytvoreno: '$z1'");
ok($z1->isa("Math::Complex"), "metoda make vraci objekt typu Math::Complex");
ok($z1 + $z2 == $z3, "scitani funguje");
ok($z1 * $z2 == $z4, "nasobeni funguje");

Poslední test je ukázkou toho, že když test selže, nutně to neznamená, že je chyba v modulu. V tomto případě je chybně napsaný test a proto selhal. Horší však je, když test neselže, protože je chybně napsaný. Poučením je, že je potřeba vždy dávat pozor.

Porovnávání řetězců - vylepšení funkce ok pomocí is

Funkce is dělá téměř totéž jako ok, ale má jinou strukturu volání a vypisuje více informací. Místo výrazu jí předáme dva argumenty, které se mají porovnat pomocí operátoru eq (to jest skutečná hodnota a očekávaná hodnota). Zatímco ok se může rozhodovat pouze na základě toho, zda je argument pravdivý či nikoliv, funkce is obě porovnávané hodnoty navíc zná.

Upravme tedy testy pomocí is. První dva necháme stejné, protože zde není nic k porovnávání. Avšak na další dva is aplikovat lze.

ok(defined $z1, "metoda make chodi. Vytvoreno: '$z1'");
ok($z1->isa("Math::Complex"), "metoda make vraci objekt typu Math::Complex");
is($z1 + $z2, $z3, "scitani funguje");
is($z1 * $z2, $z4, "nasobeni funguje");

Výstup u čtvrtého testu se změnil. Test selhal a dostáváme navíc informaci o tom, jak se liší obě hodnoty.

1..4
ok 1 - metoda make chodi. Vytvoreno: '1+2i'
ok 2 - metoda make vraci objekt typu Math::Complex
ok 3 - scitani funguje
not ok 4 - nasobeni funguje
#   Failed test 'nasobeni funguje'
#   at komplex2.pl line 12.
#          got: '-5+10i'
#     expected: '-8+10i'
# Looks like you failed 1 test of 4.

Existuje také funkce isnt (pro puntičkáře též varianta s apostrofem isn't), což je negace is. Lze ji užít například následovně k testu neprázdnosti proměnné nebo rozdílnosti dvou proměnných.

isnt($data, "", "mame data");
isnt($a, $b, "a, b se lisi");

Může se hodit též funkce is_deeply, která pomocí porovnává do hloubky datové struktury.

Porovnávání obecně - vylepšení funkce ok pomocí cmp_ok

Podobně funguje funkce cmp_ok. Zde je ale navíc potřeba zadat explicitně operátor, protože máme univerzálnější použití.

cmp_ok($promenna, "==", $ocekavano, "plati rovnost");
cmp_ok($p, "&&", $q, "plati p && q");

Regulární výrazy - vylepšení funkce ok pomocí like

like zjistí, zda předaná hodnota vyhovuje regulárnímu výrazu.

like($cislo, "/^\w+$/", "cislo je korektne zadane");

Lze použít i unlike. Postup je analogický jako v předchozích dvou případech

Testování existence metod

Funkce can_ok otestuje, zda v nějakém modulu existují dané metody. Zde je příklad použití.

can_ok("Modul", qw(metoda1 metoda2 metoda3));

Jiné platformy a přeskakování testů

Pokud některé testy nebudeme moci provést na určitém operačním systému (například nebude obsahovat některé k tomu nezbytné nástroje nebo budeme mít přednastavené jiné hodnoty), můžeme je přeskakovat.

Existuje funkce skip, která přeskočí požadovaný počet testů. Pokud budeme skutečně chtít podmiňovat vykonání testů operačním systémem, pravděpodobně sáhneme po proměnné $^O (alternativně $OSNAME). Její hodnoty jsou například linux, MSWin32, MacOs. Chceme-li rozlišit mezi různými verzemi operačního systému, musíme už využít nějakého externího modulu. To se může stát zejména s různými verzemi Windows, které se mohou výrazně lišit. V takovém případě užijeme například funkci GetOSName v modulu Win32.

SKIP: {
    skip("Nelze testovat na operacnich systemech Windows.", 1) if $^O eq "MSWin32";

    is(...);
}

Subtesty

Jen na okraj poznamenejme, že lze dělat též subtesty.

use Test::More tests => 2;
ok(1);
subtest "subtest" => sub {
      plan tests => 1;
      ok(1);
};

Tento program vyprodukuje následující výstup.

1..2
ok 1
    1..1
    ok 1
ok 2 - subtest

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

8.5.2016 17:19 /Redakce Linuxsoft.cz
PR: Dne 26.5.2016 proběhne v Praze konference Cloud computing v praxi. Tématy bude např. nejnovější trendy v oblasti cloudu a cloudových řešení, cloudové služby, infrastruktura cloudu, efektivní využití cloudu, možné nástrahy cloudů a jak se jim vyhnout
Přidat komentář

21.4.2016 8:01 /František Kučera
Spolek OpenAlt zve na 127. distribuovaný sraz příznivců svobodného softwaru a otevřených technologií (hardware, 3D tisk, SDR, DIY, makers…), který se bude konat ve čtvrtek 28. dubna od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

2.3.2016 22:41 /Ondřej Čečák
Letošní ročník konference InstallFest již tento víkend!
Přidat komentář

14.2.2016 16:39 /Redakce Linuxsoft.cz
O víkendu 5. a 6. března 2016 proběhne na pražském Strahově 8. ročník tradiční konference InstallFest. Celkem za dva dny uvidíte ​30 přednášek​ a ​6 workshopů.
Přidat komentář

5.2.2016 17:38 /Petr Ježek
Utilitka z XFce "xfce4-power-manager" nejen umožňuje nastavení lhůty pro uspání či hybernaci, ale i zapínání a vypínání prezentačního módu pro nerušené sledování videí. Stačí ji nastavit v každém vybavenějším panelu a v jakémkoli nontiled WM/DE.
Přidat komentář

10.1.2016 11:32 /Pavel `Goldenfish' Kysilka
LinuxMarket změnil provozovatele. Nově jej provozuje Marek Pszczolka. Více info a detaily #1 a #2.
Přidat komentář

29.12.2015 11:38 /Ondřej Čečák
Ještě posledních pár dní můžete přidávat příspěvky nebo nápady na Install Fest 2016, který se bude konat 5. a 6. března 2016.
Přidat komentář

8.12.2015 11:36 /Petr Ježek
Logické se stává realitou. LibreOffice a Thunderbird se mají dle článku na Redditu stát protiváhou MS řešení (MS Office a Outlook).
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

10.6.2016 21:10 / pavel riha
FreeBSD 10.3 a virtualizace

8.6.2016 21:56 / Milan Gallas
Nevalidní prefix m

7.5.2016 14:58 / Teodor Komárek
Soubory

20.4.2016 0:07 / Jakub Cleing
Sázkový panel PHP FUSION

9.4.2016 9:43 / jiwopene@gmail.com
Re: problém s dpkg a nemožností instalovat

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2016) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze