Framework for testing

This commit is contained in:
Kovid Goyal 2016-10-16 20:36:27 +05:30
parent a24c6ad991
commit adaf748852
4 changed files with 140 additions and 3 deletions

View File

@ -45,8 +45,7 @@ class Cursor:
class Line: class Line:
__slots__ = 'char fg bg bold italic reverse strikethrough decoration decoration_fg width'.split() __slots__ = 'char fg bg bold italic reverse strikethrough decoration decoration_fg width continued'.split()
continued = False
def __init__(self, sz: int, other=None): def __init__(self, sz: int, other=None):
if other is None: if other is None:
@ -61,6 +60,7 @@ class Line:
self.decoration = z1[:] self.decoration = z1[:]
self.decoration_fg = z4[:] self.decoration_fg = z4[:]
self.width = z1[:] self.width = z1[:]
self.continued = False
else: else:
self.char = other.char[:] self.char = other.char[:]
self.fg = other.fg[:] self.fg = other.fg[:]
@ -149,7 +149,7 @@ class Line:
self.copy_slice(src_start, dest_start, snum) self.copy_slice(src_start, dest_start, snum)
def __str__(self) -> str: def __str__(self) -> str:
return ''.join(map(ord, filter(None, self.char))) return ''.join(map(chr, filter(None, self.char)))
def __repr__(self) -> str: def __repr__(self) -> str:
return repr(str(self)) return repr(str(self))

20
kitty_tests/__init__.py Normal file
View File

@ -0,0 +1,20 @@
#!/usr/bin/env python
# vim:fileencoding=utf-8
# License: GPL v3 Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
from unittest import TestCase
class BaseTest(TestCase):
ae = TestCase.assertEqual
def set_text_in_line(line, text, offset=0):
pos = offset
for ch in text:
line.char[pos] = ord(ch)
line.width[pos] = 1
pos += 1
if pos >= len(line):
break

23
kitty_tests/datatypes.py Normal file
View File

@ -0,0 +1,23 @@
#!/usr/bin/env python
# vim:fileencoding=utf-8
# License: GPL v3 Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
from . import BaseTest, set_text_in_line
from kitty.data_types import Line
class TestDataTypes(BaseTest):
def test_line_ops(self):
t = 'Testing with simple text'
l = Line(len(t))
set_text_in_line(l, t)
self.ae(str(l), t)
self.ae(str(l.copy()), t)
l.continued = False
l2 = l.copy()
self.assertFalse(l2.continued)
self.ae(l, l2)
l2.char[1] = 23
self.assertNotEqual(l, l2)

94
test.py Executable file
View File

@ -0,0 +1,94 @@
#!/usr/bin/env python3
# vim:fileencoding=utf-8
# License: GPL v3 Copyright: 2016, Kovid Goyal <kovid at kovidgoyal.net>
import unittest
import os
import sys
import importlib
base = os.path.dirname(os.path.abspath(__file__))
def init_env():
sys.path.insert(0, base)
def itertests(suite):
stack = [suite]
while stack:
suite = stack.pop()
for test in suite:
if isinstance(test, unittest.TestSuite):
stack.append(test)
continue
if test.__class__.__name__ == 'ModuleImportFailure':
raise Exception('Failed to import a test module: %s' % test)
yield test
def find_tests_in_dir(path, excludes=('main.py',)):
package = os.path.relpath(path, base).replace(os.sep, '/').replace('/', '.')
items = os.listdir(path)
suits = []
for x in items:
if x.endswith('.py') and x not in excludes:
m = importlib.import_module(package + '.' + x.partition('.')[0])
suits.append(unittest.defaultTestLoader.loadTestsFromModule(m))
return unittest.TestSuite(suits)
def filter_tests(suite, test_ok):
ans = unittest.TestSuite()
added = set()
for test in itertests(suite):
if test_ok(test) and test not in added:
ans.addTest(test)
added.add(test)
return ans
def filter_tests_by_name(suite, *names):
names = {x if x.startswith('test_') else 'test_' + x for x in names}
def q(test):
return test._testMethodName in names
return filter_tests(suite, q)
def filter_tests_by_module(suite, *names):
names = frozenset(names)
def q(test):
m = test.__class__.__module__.rpartition('.')[-1]
return m in names
return filter_tests(suite, q)
def run_tests(find_tests, verbosity=4):
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('name', nargs='?', default=None,
help='The name of the test to run, for e.g. writing.WritingTest.many_many_basic or .many_many_basic for a shortcut')
args = parser.parse_args()
tests = find_tests()
if args.name:
if args.name.startswith('.'):
tests = filter_tests_by_name(tests, args.name[1:])
else:
tests = filter_tests_by_module(tests, args.name)
if not tests._tests:
raise SystemExit('No test named %s found' % args.name)
run_cli(tests, verbosity)
def run_cli(suite, verbosity=4):
r = unittest.TextTestRunner
r.resultclass = unittest.TextTestResult
init_env()
result = r(verbosity=verbosity).run(suite)
if not result.wasSuccessful():
raise SystemExit(1)
if __name__ == '__main__':
run_cli(find_tests_in_dir(os.path.join(base, 'kitty_tests')))