I created Runner for these purposes.
And now I can execute tests in parallel by modules, classes and methods.
import unittest
from concurrent.futures import ThreadPoolExecutor
class Runner():
def parallel_execution(self, *name, options='by_module'):
"""
name - name of the class with tests or module with classes that contain tests
modules - name of the module with tests or with class that contains tests
options:
by_method - gather all tests methods in the class/classes and execute in parallel
by_module - gather all tests from modules in parallel
by_class - will execute all classes (with tests) in parallel
"""
suite = unittest.TestSuite()
if (options=='by_method'):
for object in name:
for method in dir(object):
if (method.startswith('test')):
suite.addTest(object(method))
elif (options=='by_class'):
for object in name:
suite.addTest(unittest.TestLoader().loadTestsFromTestCase(object))
elif (options=='by_module'):
for module in name:
suite.addTest(unittest.TestLoader().loadTestsFromModule(module))
else:
raise ValueError("Parameter 'options' is incorrect."
"Available options: 'by_method', 'by_class', 'by_module'")
with ThreadPoolExecutor(max_workers=10) as executor:
list_of_suites = list(suite)
for test in range(len(list_of_suites)):
test_name = str(list_of_suites[test])
executor.submit(unittest.TextTestRunner().run, list_of_suites[test])
EXAMPLES:
#by_methods
Runner().parallel_execution(Test1.Test1, Test2.Test22, Test2.Test33, options='by_method')
#by_class
Runner().parallel_execution(Test1.Test1, Test2.Test22, Test2.Test33, options='by_class')
#by_modules
Runner().parallel_execution(Test1, Test2)