from time import time
import unittest


class TimingTestResult(unittest.TextTestResult):
    def startTest(self, test):
        self._start_time = time.perf_counter()
        super().startTest(test)

    def stopTest(self, test):
        elapsed = time.perf_counter() - self._start_time
        print(f"{elapsed:.3f}s - {self.getDescription(test)}")
        super().stopTest(test)

class TimingTestRunner(unittest.TextTestRunner):
    def _makeResult(self):
        return TimingTestResult(self.stream, self.descriptions, self.verbosity)

# Discover and load all tests in the 'tests' directory
test_loader = unittest.TestLoader()
test_suite = test_loader.discover('tests')

# Run the test suite
# test_runner = TimingTestRunner(verbosity=0)
test_runner = unittest.TextTestRunner()
test_runner.run(test_suite)
