Testování na základě klíčových slov - Keyword-driven testing

Testování na základě klíčových slov, také známý jako akční slovní testování (nezaměňovat s akční testování), je testování softwaru metodika vhodná pro oba manuál a automatizované testování. Tato metoda odděluje dokumentaci testovací případy - včetně údajů a funkcí, které se mají použít - od předpisu způsobu provádění testovacích případů. Ve výsledku odděluje proces vytváření testu do dvou odlišných fází: fáze návrhu a vývoje a fáze provádění. Návrhová podnož pokrývá analýza požadavků a hodnocení a analýza dat, definice a populace.

Přehled

Tato metodika používá klíčová slova (nebo akční slova) k symbolizaci funkčnosti, která má být testována, například Zadejte klienta. Klíčové slovo Zadejte klienta je definována jako sada akcí, které musí být provedeny pro vstup nového klienta do databáze. Jeho dokumentace klíčových slov by obsahovala:

  • počáteční stav testovaného systému (SUT)
  • okno nebo nabídku, ze které chcete začít
  • klávesami nebo kliknutím myši se dostanete do správného okna pro zadávání dat
  • názvy polí, která se mají vyhledat, a argumenty, které se mají zadat
  • akce, které je třeba provést v případě, že se objeví další dialogová okna (například potvrzení)
  • tlačítko pro odeslání
  • tvrzení o tom, jaký by měl být stav SUT po dokončení akcí

Syntaxe testování na základě klíčových slov uvádí testovací případy (data a slova akcí) ve formátu tabulky (viz příklad níže). První sloupec (sloupec A) obsahuje klíčové slovo Enter Client, což je testovaná funkce. Zbývající sloupce B-E pak obsahují data potřebná k provedení klíčového slova: Jméno, Adresa, PSČ a Město.

ABCDE
.názevAdresaPSČMěsto
Zadejte klientaJane SmithHigh Street 6SE25 6EPLondýn

Chcete-li zadat jiného klienta, tester by vytvořil další řádek v tabulce s klíčovým slovem Zadat klienta a s údaji nového klienta v následujících sloupcích. Není třeba znovu zahrnout všechny zahrnuté akce.

V něm můžete navrhnout své testovací případy podle:

  • Označení kroků na vysoké úrovni potřebných pro interakci s aplikací a systémem, aby bylo možné provést test.
  • Označení toho, jak ověřit a ověřit, že funkce fungují správně.
  • Stanovení předpokladů pro zkoušku.
  • Stanovení kritérií pro přijetí testu.

Vzhledem k iterativní povaze vývoje softwaru je návrh testu obvykle abstraktnější (méně konkrétní) než manuální implementace testu, ale může se snadno vyvinout v jeden.

Výhody

Testování pomocí klíčových slov snižuje citlivost na údržbu způsobenou změnami v Testovaném systému / softwaru (SUT). Pokud se rozvržení obrazovky změní nebo je systém migrován na jiný OS, je téměř nemožné provést nějaké změny v testovacích případech: změny budou provedeny v dokumentaci klíčových slov, jeden dokument pro každé klíčové slovo, bez ohledu na to, kolikrát je klíčové slovo použito testovací případy, což znamená hluboký proces návrhu testu.

Kvůli velmi podrobnému popisu způsobu provedení klíčového slova (v dokumentaci klíčového slova) může test provést téměř kdokoli. Testování na základě klíčových slov lze tedy použít pro oba ruční testování a automatizované testování.[1]

Kromě toho je tento přístup otevřeným a rozšiřitelným rámcem, který spojuje všechny nástroje, aktiva a data související s testovacím úsilím a související. V rámci tohoto jednotného rámce mohou všichni účastníci testovacího úsilí definovat a upřesnit cíle kvality, na kterých pracují. To je místo, kde tým definuje plán, který bude implementovat, aby splnil tyto cíle. A co je nejdůležitější, poskytuje celému týmu jedno místo, kam kdykoli zjistit stav systému.

Testování je mechanismus zpětné vazby v procesu vývoje softwaru. Říká vám, kde je třeba provést opravy, abyste zůstali v kurzu při jakékoli dané iteraci vývojového úsilí. Také vám řekne o aktuální kvalitě vyvíjeného systému. Činnost implementace testů zahrnuje návrh a vývoj opakovaně použitelných testovacích skriptů, které implementují testovací případ. Po implementaci může být přidružen k testovacímu případu.

Implementace se v každém testovacím projektu liší. V jednom projektu se můžete rozhodnout postavit obojí automatizované testovací skripty a ruční testovací skripty.[2] Navrhování testů je místo toho iterační proces. Můžete začít navrhovat testy před jakoukoli implementací systému založením návrhu testu na specifikacích případu použití, požadavcích, prototypech atd. Jakmile bude systém jasněji specifikován a budete mít sestavení systému, se kterými můžete pracovat, můžete rozvinout podrobnosti návrhu. Činnost navrhování testů odpovídá na otázku: „Jak provedu testování?“ Kompletní návrh testu informuje čtenáře o tom, jaké kroky je třeba se systémem provést a jaké chování a vlastnosti by měli očekávat, pokud budou správně fungovat.

Návrh testu se liší od návrhové práce, která by měla být provedena při určování způsobu sestavení implementace testu.

Metodologie

Metodika testování na základě klíčových slov rozděluje provádění testovacího procesu do několika fází:

  1. Modelový základ / prototypování: analýza a posouzení požadavků.
  2. Definice testovacího modelu: při hodnocení požadavků na výsledek přistupte k vlastnímu softwarovému modelu.
  3. Definice testovacích dat: na základě definovaného vlastního modelu spusťte klíčové slovo a definici dat hlavního / doplňku.
  4. Příprava na zkoušku: základ zkoušky příjmu atd
  5. Návrh testu: analýza základu testu, návrh testovacího případu / postupu, návrh dat testu.
  6. Ruční provedení testu: ruční provedení testovacích případů pomocí dokumentace klíčových slov jako vodítka provedení.
  7. Automatizace provádění testu: vytvoření automatizovaného skriptu, který provádí akce podle dokumentace klíčových slov.
  8. Automatizované provádění testu.

Definice

Klíčové slovo nebo slovo akce je definovaná kombinace akcí na testovacím objektu, která popisuje, jak musí být testovací řádky provedeny. Slovo akce obsahuje argumenty a je definováno analytikem testu.

Test je klíčovým krokem v jakémkoli procesu vývoje a musí na objekt aplikovat řadu testů nebo kontrol (test systému / SW - SUT). Vždy si pamatujte, že test může ukázat pouze přítomnost chyb, nikoli jejich nepřítomnost. V testu systému RT nestačí zkontrolovat, zda SUT produkuje správné výstupy. Musí také ověřit, že čas potřebný k vytvoření tohoto výstupu je podle očekávání. Kromě toho načasování těchto výstupů může také záviset na načasování vstupů. Z výstupů je zase určeno načasování použitelných budoucích vstupů.[2]

Automatizace provádění testu

Fáze implementace se liší v závislosti na nástroji nebo rámci. Automatizační inženýři často implementují rámec, který poskytuje klíčová slova jako „zkontrolovat“ a „zadat“.[1] Testeři nebo návrháři testů (kteří nepotřebují umět programovat) píší testovací případy na základě klíčových slov definovaných ve fázi plánování, která byla implementována inženýry. Test se provádí pomocí ovladače, který načte klíčová slova a provede odpovídající kód.

Jiné metodiky používají fázi implementace „vše v jednom“. Namísto oddělení úkolů návrhu testu a zkušebního inženýrství, designu testu je automatizace testu. Klíčová slova, například „upravit“ nebo „zkontrolovat“, se vytvářejí pomocí nástrojů, ve kterých je potřebný kód již napsán. Tím se odstraní potřeba dalších techniků v procesu testování, protože implementace klíčových slov je již součástí nástroje. Mezi příklady patří GUIdancer a QTP.

Profesionálové

  • Z dlouhodobého hlediska je údržba nízká:
    • Testovací případy jsou stručné
    • Testovací případy jsou pro zúčastněné strany čitelné
    • Testovací případy lze snadno upravit
    • Nové testovací případy mohou snadněji znovu použít stávající klíčová slova
  • Opakované použití klíčových slov ve více testovacích případech
  • Nezávisí na konkrétním nástroji nebo programovacím jazyce
  • Dělba práce
    • Konstrukce testovacích případů vyžaduje silnější odborné znalosti domény - menší dovednosti v oblasti nástrojů a programování
    • Implementace klíčových slov vyžaduje silnější dovednosti v oblasti nástrojů / programování - s relativně nižšími dovednostmi v doméně
  • Abstrakce vrstev

Nevýhody

  • Delší čas nakupovat (ve srovnání s manuálním testováním nebo technikou záznamu a přehrávání)
  • Zpočátku mírně vysoká křivka učení

Viz také

Reference

  1. ^ A b Faught, Danny R. (listopad 2004). „Testování na základě klíčových slov“. Sticky Minds. Softwarové kvalitní inženýrství. Citováno 12. září 2012.
  2. ^ A b Mandurrino, José L. (červenec 2014). „Gestione e accccio alla validazione in sistemi RT (Real-Time)“. UTIU. Chybějící nebo prázdný | url = (Pomoc)

externí odkazy