Angeregt durch yarkee, kombinierte ich es mit einigem der Code, den ich bereits hatte. Sie können dies auch von einem anderen Skript aus aufrufen, indem Sie einfach die Funktion run_unit_tests()
aufrufen, ohne den Befehlszeile zu verwenden, oder rufen Sie es einfach von der Befehlszeile aus mit python3 my_test_file.py
.
import my_test_file
my_test_file.run_unit_tests()
Leider funktioniert dies nur für Python 3.3 oder höher:
import unittest
class LineBalancingUnitTests(unittest.TestCase):
@classmethod
def setUp(self):
self.maxDiff = None
def test_it_is_sunny(self):
self.assertTrue("a" == "a")
def test_it_is_hot(self):
self.assertTrue("a" != "b")
Runner-Code:
#! /usr/bin/env python3
# -*- coding: utf-8 -*-
import unittest
from .somewhere import LineBalancingUnitTests
def create_suite(classes, unit_tests_to_run):
suite = unittest.TestSuite()
unit_tests_to_run_count = len( unit_tests_to_run )
for _class in classes:
_object = _class()
for function_name in dir( _object ):
if function_name.lower().startswith( "test" ):
if unit_tests_to_run_count > 0 \
and function_name not in unit_tests_to_run:
continue
suite.addTest( _class( function_name ) )
return suite
def run_unit_tests():
runner = unittest.TextTestRunner()
classes = [
LineBalancingUnitTests,
]
# Kommentiere alle Testnamen in dieser Liste aus, um alle Unit-Tests durchzuführen
unit_tests_to_run = [
"test_it_is_sunny",
# "test_it_is_hot",
]
runner.run( create_suite( classes, unit_tests_to_run ) )
if __name__ == "__main__":
print( "\n\n" )
run_unit_tests()
Wenn Sie den Code ein wenig bearbeiten, können Sie ein Array mit allen zu aufrufenden Unit-Tests übergeben:
...
def run_unit_tests(unit_tests_to_run):
runner = unittest.TextTestRunner()
classes = \
[
LineBalancingUnitTests,
]
runner.run( suite( classes, unit_tests_to_run ) )
...
Und eine andere Datei:
import my_test_file
# Kommentiere alle Testnamen in dieser Liste aus, um alle Unit-Tests durchzuführen
unit_tests_to_run = \
[
"test_it_is_sunny",
# "test_it_is_hot",
]
my_test_file.run_unit_tests( unit_tests_to_run )
Alternativ können Sie das load_tests-Protokoll verwenden und die folgende Methode in Ihrem Testmodul/-datei definieren:
def load_tests(loader, standard_tests, pattern):
suite = unittest.TestSuite()
# Um einen einzelnen Test aus dieser Datei hinzuzufügen
suite.addTest( LineBalancingUnitTests( 'test_it_is_sunny' ) )
# Um eine einzelne Testklasse aus dieser Datei hinzuzufügen
suite.addTests( unittest.TestLoader().loadTestsFromTestCase( LineBalancingUnitTests ) )
return suite
Wenn Sie die Ausführung auf eine einzige Testdatei beschränken möchten, müssen Sie nur das Test-Discovery-Muster auf die einzige Datei setzen, in der Sie die load_tests()
-Funktion definiert haben.
#! /usr/bin/env python3
# -*- coding: utf-8 -*-
import os
import sys
import unittest
test_pattern = 'mytest/module/name.py'
PACKAGE_ROOT_DIRECTORY = os.path.dirname( os.path.realpath( __file__ ) )
loader = unittest.TestLoader()
start_dir = os.path.join( PACKAGE_ROOT_DIRECTORY, 'testing' )
suite = loader.discover( start_dir, test_pattern )
runner = unittest.TextTestRunner( verbosity=2 )
results = runner.run( suite )
print( "results: %s" % results )
print( "results.wasSuccessful: %s" % results.wasSuccessful() )
sys.exit( not results.wasSuccessful() )
Referenzen:
- Problem mit sys.argv[1] wenn das unittest-Modul in einem Skript ist
- Gibt es einen Weg, um alle Funktionen in einer Python-Klasse zu durchlaufen und auszuführen?
- Durchlaufen aller Member-Variablen einer Klasse in Python
Alternativ zum letzten Hauptprogramm-Beispiel kam ich nach der Lektüre der unittest.main()
-Methodenimplementierung auf folgende Variation:
-
https://github.com/python/cpython/blob/master/Lib/unittest/main.py#L65
! /usr/bin/env python3
-- coding: utf-8 --
import os
import sys
import unittest
PACKAGE_ROOT_DIRECTORY = os.path.dirname( os.path.realpath( file ) )
start_dir = os.path.join( PACKAGE_ROOT_DIRECTORY, 'testing' )
from testing_package import main_unit_tests_module
testNames = ["TestCaseClassName.test_nameHelloWorld"]
loader = unittest.TestLoader()
suite = loader.loadTestsFromNames( testNames, main_unit_tests_module )
runner = unittest.TextTestRunner(verbosity=2)
results = runner.run( suite )
print( "results: %s" % results )
print( "results.wasSuccessful: %s" % results.wasSuccessful() )
sys.exit( not results.wasSuccessful() )