Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen der Seite angezeigt.
Beide Seiten, vorherige Überarbeitung Vorherige Überarbeitung Nächste Überarbeitung | Vorherige Überarbeitung | ||
talit:python_testing [2024-03-04 14:24] – [Aufgabe A] hof | talit:python_testing [2024-03-04 14:38] (aktuell) – [Pytest] hof | ||
---|---|---|---|
Zeile 8: | Zeile 8: | ||
Ein _Unit Test_ überprüft die Funktionsweise eines Moduls ($\approx$ einer Python-Datei). | Ein _Unit Test_ überprüft die Funktionsweise eines Moduls ($\approx$ einer Python-Datei). | ||
+ | |||
### Sorting Example | ### Sorting Example | ||
Zeile 44: | Zeile 45: | ||
#### Aufgabe A | #### Aufgabe A | ||
Schreibe einen Test-Case für den rapportierten Fehler. Flicke anschliessend die `is_sorted` Funktion, bis alle Tests wieder durchlaufen. | Schreibe einen Test-Case für den rapportierten Fehler. Flicke anschliessend die `is_sorted` Funktion, bis alle Tests wieder durchlaufen. | ||
- | |||
### Pytest | ### Pytest | ||
Um in grösseren Projekten nicht den Überblick zu verlieren, ist es Usus, ein Test-Framework zu verwenden, um alle Tests im Projekt auszuführen. Die beste Wahl für Python ist [[https:// | Um in grösseren Projekten nicht den Überblick zu verlieren, ist es Usus, ein Test-Framework zu verwenden, um alle Tests im Projekt auszuführen. Die beste Wahl für Python ist [[https:// | ||
Zeile 50: | Zeile 50: | ||
Installation: | Installation: | ||
- | Pytest sucht überall im Ordner nach Dateien, die mit `test_` beginnen, und führt darin alle Funktionen aus, die mit dem gleichen Präfix `test_` anfangen | + | Pytest sucht überall im Ordner nach Dateien, die mit `test_` beginnen, und führt darin alle Funktionen aus, die mit dem gleichen Präfix `test_` anfangen. |
Wir müssen dafür also unseren Test leicht verändern: | Wir müssen dafür also unseren Test leicht verändern: | ||
+ | <code python test_sorting.py> | ||
+ | from sorting import * | ||
+ | |||
+ | def test_sorted(): | ||
+ | assert is_sorted([' | ||
+ | assert not is_sorted([' | ||
+ | |||
+ | |||
+ | def test_sorted_bug(): | ||
+ | assert not is_sorted([' | ||
+ | </ | ||
+ | |||
+ | Die Ausführung von `pytest` findet die Datei und die zwei Testfunktionen und fasst die Resultate zusammen: | ||
+ | |||
+ | <code bash> | ||
+ | $ pytest | ||
+ | ============================================= test session starts ============================================== | ||
+ | platform darwin -- Python 3.11.7, pytest-8.1.0, | ||
+ | rootdir: / | ||
+ | collected 2 items | ||
+ | |||
+ | test_sorted.py .. [100%] | ||
+ | |||
+ | ============================================== 2 passed in 0.00s =============================================== | ||
+ | </ | ||
+ | |||
+ | Pytest wird auch von VSCode unterstützt (ev. muss in der Sidebar die _Tests_-Ansicht geöffnet werden: | ||
+ | |||
+ | {{: | ||
+ | #### Aufgabe B | ||
+ | Ändere deinen Unit-Test, damit er von pytest gefunden wird, und führe die Tests im Terminal und auch in VSCode aus. | ||
## Integration Tests | ## Integration Tests |