125 lines
3.7 KiB
Python
Raw Normal View History

2023-02-15 11:31:36 +08:00
import PikaStdLib
mem = PikaStdLib.MemChecker()
2022-08-06 23:26:04 +08:00
class TestResult:
def __init__(self):
2022-08-06 23:26:04 +08:00
self.errorsNum = 0
self.failuresNum = 0
self.skippedNum = 0
self.testsRun = 0
self.errors = []
self.failures = []
self.skipped = []
self._newFailures = 0
2022-08-06 23:26:04 +08:00
def wasSuccessful(self):
return self.errorsNum == 0 and self.failuresNum == 0
def __str__(self):
# Format is compatible with CPython.
return "<unittest.result.TestResult run=%d, errors=%d, failures=%d,skipped=%d>" % (
self.testsRun, self.errorsNum, self.failuresNum, self.skippedNum)
2022-08-06 23:26:04 +08:00
class TestCase:
2022-08-06 21:19:23 +08:00
def assertEqual(self, x, y):
msg = "%r vs (expected) %r" % (x, y)
assert x == y, msg
2022-08-06 21:19:23 +08:00
def assertNotEqual(self, x, y):
msg = "%r not expected to be equal %r" % (x, y)
assert x != y, msg
2022-08-06 21:19:23 +08:00
def assertLessEqual(self, x, y):
msg = "%r is expected to be <= %r" % (x, y)
assert x <= y, msg
2022-08-06 21:19:23 +08:00
def assertGreaterEqual(self, x, y):
msg = "%r is expected to be >= %r" % (x, y)
assert x >= y, msg
2022-08-06 21:19:23 +08:00
def assertTrue(self, x):
msg = "Expected %r to be True" % x
assert x, msg
2022-08-06 21:19:23 +08:00
def assertFalse(self, x):
msg = "Expected %r to be False" % x
assert not x, msg
def assertIs(self, x, y):
msg = "%r is not %r" % (x, y)
assert x is y, msg
def assertIsNot(self, x, y):
msg = "%r is %r" % (x, y)
assert x is not y, msg
def assertIsNone(self, x):
msg = "%r is not None" % x
assert x is None, msg
def assertIsNotNone(self, x):
msg = "%r is None" % x
assert x is not None, msg
def assertIn(self, x, y):
msg = "Expected %r to be in %r" % (x, y)
assert x in y, msg
2023-03-26 20:49:10 +08:00
def assertNotIn(self, x, y):
msg = "Expected %r not to be in %r" % (x, y)
assert x not in y, msg
def run(self, result: TestResult, suite_name):
for name in dir(self):
if name.startswith("test"):
result.testsRun += 1
self.test_fn = getattr(self, name)
print("[ RUN ] %s.%s" % (suite_name, name))
2022-08-11 18:32:53 +08:00
try:
2023-02-15 11:31:36 +08:00
mem_before = 0.0
mem_after = 0.0
mem_before = mem.getNow()
2022-08-11 18:32:53 +08:00
self.test_fn()
2023-02-15 11:31:36 +08:00
mem_after = mem.getNow()
2023-03-15 16:20:59 +08:00
print("\x1b[1m\x1b[32m[ OK ] %s.%s\x1b[0m" % (suite_name, name))
2023-02-15 11:31:36 +08:00
if mem_after != mem_before:
2023-03-15 16:20:59 +08:00
print("\x1b[33m[ MEM LACK ]", mem_after - mem_before,"\x1b[0m")
2022-08-11 18:32:53 +08:00
except:
2023-03-15 16:20:59 +08:00
print("\x1b[1m\x1b[31m[ FAILED ]\x1b[0m %s.%s" % (suite_name, name))
2022-08-11 18:32:53 +08:00
result.errorsNum += 1
2022-08-06 23:26:04 +08:00
class TestSuite:
2022-08-06 21:19:23 +08:00
def __init__(self, name):
self._tests = []
self.name = name
2022-08-06 23:26:04 +08:00
def addTest(self, case):
self._tests.append(case)
def run(self, result: TestResult):
2022-08-06 23:26:04 +08:00
for case in self._tests:
case.run(result, self.name)
return result
2022-08-06 23:26:04 +08:00
class TextTestRunner:
def run(self, suite: TestSuite):
res = TestResult()
2022-08-11 19:21:53 +08:00
print("[----------] tests from %s" % suite.name)
2022-08-06 23:26:04 +08:00
_ = suite.run(res)
2022-08-11 19:21:53 +08:00
print("[----------] %d tests from %s" % res.testsRun, suite.name)
print('')
print('[==========]')
if res.failuresNum > 0 or res.errorsNum > 0:
2023-03-15 16:20:59 +08:00
print("\x1b[1m\x1b[31m[ FAILED ](%d errors, %d failures)\x1b[0m" % (res.errorsNum, res.failuresNum))
else:
2022-08-11 19:21:53 +08:00
msg = ""
if res.skippedNum > 0:
msg += " (skipped=%d)" % res.skippedNum
print(msg)
2023-03-15 16:20:59 +08:00
print("\x1b[1m\x1b[32m[ PASSED ] %d tests\x1b[0m" % res.testsRun)
return res