Testowanie nosa - narzędzia
Moduł nose.tools zapewnia szereg pomocy testowych, które mogą okazać się przydatne, w tym dekoratory do ograniczania czasu wykonywania testów i testowania pod kątem wyjątków oraz wszystkie te same metody assertX, które można znaleźć w unittest.TestCase.
nose.tools.ok_(expr, msg = None) - Skrót do potwierdzenia.
nose.tools.eq_(a, b, msg = None) - Skrót dla „assert a == b,„% r! =% R ”% (a, b)
nose.tools.make_decorator(func) - Zawija dekorator testu, aby poprawnie odtworzyć metadane dekorowanej funkcji, w tym dodatkowe elementy nosa (mianowicie ustawienie i rozerwanie).
nose.tools.raises(*exceptions) - Test musi wywołać jeden z oczekiwanych wyjątków, aby przejść.
nose.tools.timed(limit) - Test musi zakończyć się w określonym czasie, aby zdał
nose.tools.istest(func) - Dekorator do oznaczania funkcji lub metody jako testu
nose.tools.nottest(func) - Dekorator, aby oznaczyć funkcję lub metodę jako niebędącą testem
Testowanie parametryczne
Struktura testowa Pythona, unittest, nie ma prostego sposobu uruchamiania sparametryzowanych przypadków testowych. Innymi słowy, nie można łatwo przekazać argumentów do plikuunittest.TestCase z zewnątrz.
Jednak pytest testuje parametryzację portów modułu na kilka dobrze zintegrowanych sposobów -
pytest.fixture() pozwala na zdefiniowanie parametryzacji na poziomie funkcji opraw.
@pytest.mark.parametrizeumożliwia zdefiniowanie parametryzacji na poziomie funkcji lub klasy. Zapewnia wiele zestawów argumentów / urządzeń dla określonej funkcji testowej lub klasy.
pytest_generate_tests umożliwia implementację własnego schematu lub rozszerzeń dynamicznej parametryzacji.
Zewnętrzny moduł „parametryzowany nosem” umożliwia sparametryzowane testowanie w dowolnej strukturze testowej Pythona. Można go pobrać z tego linku -https://github.com/wolever/nose-parameterized