Předmět je základní jednotka výuky, jejímž prostřednictvím si student osvojí ucelenou část souboru znalostí a dovedností, potřebnou pro zvládnutí studijního oboru/specializace. Za věcný obsah předmětu zodpovídá garant předmětu. Časovou náročnost předmětu zhruba vyjadřuje atribut předmětu rozsah kontaktní výuky. Například rozsah = 2+2 značí, že předmět bude mít týdně dvě hodiny přednášek a dvě hodiny cvičení týdně. Na závěr semestru musí vyučující provést vyhodnocení, nakolik si ten který student osvojil poznatky a dovednosti, kterých měl během výuky nabýt. Jakým způsobem toto hodnocení vyučující provedou určuje atribut způsob zakončení. U předmětu lze definovat, že předmět je zakončen pouze zápočtem(Z), klasifikovaným zápočtem(KZ), pouze zkouškou(ZK), nebo zápočtem a zkouškou(Z,ZK). Náročnost úspěšného absolvování předmětu je vyjádřena ECTS kreditními body. Výuka předmětu probíhá během semestru. Opakovaně se předmět vyučuje vždy v zimním(Z), nebo v letním(L) semestru každého akademického roku. Výjimečně může předmět být nabízen studentům v obou semestrech(Z,L). Za organizační zajištění výuky zodpovídá přiřazená katedra, která zejména vytvoří časový rozvrh předmětu a zajistí pro předmět vyučující. Někteří přednáší a zkouší, jiní vedou cvičení a udělují zápočty.
Obsahová náplň a další organizační informace, týkající se předmětu je popsána pomocí různých popisných textů(anotace, týdenní osnova, literatura, apod.)
$DODATEK_POPIS
NI-APT | Pokročilé testování programů | Rozsah kontaktní výuky: | 2P+1C | ||
---|---|---|---|---|---|
Vyučující: | Donat-Bouillud P. | Způsob zakončení: | Z,ZK | ||
Zodpovědná katedra: | 18101 | ECTS Kredity: | 5 | Semestr: | Z |
Anotace:
Testování programu je nezbytné, aby bylo zajištěno, že program dodržuje svou specifikaci, že změny nezpůsobují regrese nebo bezpečnostní problémy. Cílem kurzu je představit pokročilé techniky testování programů nad rámec psaní jednotkových testů, zejména fuzzing a symbolická exekuce.
Osnovy přednášek:
1. | Úvod - testování specifikací | |
2. | Coverage - strukturální testování | |
3. | Property-based testing, random fuzzing | |
4. | Minimalizace testovacích příkladů | |
5. | Fuzzing založený na mutaci a mutační analýza | |
6. | Greybox fuzzing a fuzzing založený na vyhledávání | |
7. | Syntaktický fuzzing: fuzzing s (i pravděpodobnostními) gramatikami | |
8. | Syntaktický fuzzing: greybox fuzzing s gramatikami, mining vstupních gramatik. | |
9. | Doménově specifický fuzzing | |
10. | Konkolický fuzzing | |
11. | Symbolický fuzzing | |
12. | Praktický fuzzing: kdy přestat, infrastruktura pro fuzzing ve velkém měřítku | |
13. | Současný výzkum (např. diferenciální fuzzing pro JS runtimy ) |
Osnovy cvičení:
1. | Coverage a nástroje pro coverage kódu | |
2. | Minimalizace testovacích příkladů | |
3. | Greybox fuzzer | |
4. | Greybox fuzzer s gramatikou | |
5. | Konkolický fuzzing | |
6. | Konzultace projektu |
Literatura:
Aniche, Maurício. Effective Software Testing: A developer's guide. Simon and Schuster, 2022. ; Zeller, Andreas, et al. "The fuzzing book." (2019).
Pezz?, Mauro, and Michal Young. Software testing and analysis: process, principles, and techniques. John Wiley & Sons, 2008.
Baldoni, Roberto, Emilio Coppa, Daniele Cono D?elia, Camil Demetrescu, and Irene Finocchi. ?A Survey of Symbolic Execution Techniques.? (2018).
The Fuzzing Book<https://www.fuzzingbook.org/>.
Požadavky:
Předpokládá se, že studenti znají základní pojmy z oblasti testování, například jednotkové testování (jak je prezentováno v BI-OOP).
|
Předmět je zahrnut do těchto studijních plánů:
Stránka vytvořena 28. 4. 2024, semestry: Z/2021-2, Z/2022-3, Z/2019-20, L/2022-3, Z/2023-4, L/2019-20, L/2021-2, Z/2020-1, L/2023-4, Z/2024-5, L/2020-1, připomínky k informační náplni zasílejte správci studijních plánů | Návrh a realizace: J. Novák, I. Halaška |