From dd4a4145c5e43b191d54fdddbc16b037a5d7345e Mon Sep 17 00:00:00 2001 From: hut Date: Wed, 20 Jan 2010 00:18:18 +0100 Subject: fixed unit tests --- test/__init__.py | 6 +-- test/tc_displayable.py | 132 ++++++++++++++++++++++++++++--------------------- test/tc_keyapi.py | 4 +- test/tc_ui.py | 2 +- 4 files changed, 82 insertions(+), 62 deletions(-) (limited to 'test') diff --git a/test/__init__.py b/test/__init__.py index 3043ba18..86557b6a 100644 --- a/test/__init__.py +++ b/test/__init__.py @@ -9,9 +9,9 @@ def init(): class Fake(object): def __getattr__(self, attrname): - if not hasattr(self, attrname): - setattr(self, attrname, Fake()) - return self.__dict__[attrname] + val = Fake() + self.__dict__[attrname] = val + return val def __call__(self, *_): return Fake() diff --git a/test/tc_displayable.py b/test/tc_displayable.py index 493b0ef8..b9538a59 100644 --- a/test/tc_displayable.py +++ b/test/tc_displayable.py @@ -7,20 +7,25 @@ from random import randint from ranger.gui.displayable import Displayable, DisplayableContainer from test import Fake, OK, raise_ok -class TestDisplayable(unittest.TestCase): +class TestWithFakeCurses(unittest.TestCase): def setUp(self): self.win = Fake() self.fm = Fake() self.env = Fake() self.settings = Fake() - self.disp = Displayable( win=self.win, - env=self.env, fm=self.fm, settings=self.settings) + self.initdict = {'win': self.win, 'settings': self.settings, + 'fm': self.fm, 'env': self.env} + + self.disp = Displayable(**self.initdict) + self.disc = DisplayableContainer(**self.initdict) + self.disc.add_child(self.disp) hei, wid = 100, 100 self.env.termsize = (hei, wid) def tearDown(self): self.disp.destroy() + self.disc.destroy() def test_colorscheme(self): # Using a color method implies change of window attributes @@ -33,6 +38,57 @@ class TestDisplayable(unittest.TestCase): self.assertRaises(OK, disp.color_at, 0, 0, 0, 'a', 'b') self.assertRaises(OK, disp.color_reset) + def test_focused_object(self): + d1 = Displayable(**self.initdict) + d2 = DisplayableContainer(**self.initdict) + for obj in (Displayable(**self.initdict) for x in range(5)): + d2.add_child(obj) + d3 = DisplayableContainer(**self.initdict) + for obj in (Displayable(**self.initdict) for x in range(5)): + d3.add_child(obj) + + for obj in (d1, d2, d3): + self.disc.add_child(obj) + + d3.container[3].focused = True + + self.assertEqual(self.disc._get_focused_obj(), d3.container[3]) + + d3.container[3].focused = False + d2.container[0].focused = True + + self.assertEqual(self.disc._get_focused_obj(), d2.container[0]) + +gWin = None + +class TestDisplayableWithCurses(unittest.TestCase): + def setUp(self): + global gWin + if not gWin: + gWin = curses.initscr() + self.win = gWin + curses.cbreak() + curses.noecho() + curses.start_color() + curses.use_default_colors() + + self.fm = Fake() + self.env = Fake() + self.settings = Fake() + self.initdict = {'win': self.win, 'settings': self.settings, + 'fm': self.fm, 'env': self.env} + self.disp = Displayable(**self.initdict) + self.disc = DisplayableContainer(**self.initdict) + self.disc.add_child(self.disp) + + self.env.termsize = self.win.getmaxyx() + + def tearDown(self): + self.disp.destroy() + curses.nocbreak() + curses.echo() + curses.endwin() + def test_boundaries(self): disp = self.disp hei, wid = self.env.termsize @@ -42,8 +98,10 @@ class TestDisplayable(unittest.TestCase): self.assertRaises(ValueError, disp.resize, -1, 0, hei, wid) self.assertRaises(ValueError, disp.resize, 0, -1, hei, wid) - box = (randint(10, 20), randint(30, 40), \ - randint(30, 40), randint(10, 20)) + box = [int(randint(0, hei) * 0.2), 0, + int(randint(0, wid) * 0.2), 0] + box[1] = randint(box[0], hei) + box[1] = randint(box[0], hei) def in_box(y, x): return (x >= box[1] and x < box[1] + box[3]) and \ @@ -61,64 +119,26 @@ class TestDisplayable(unittest.TestCase): point2.y = y self.assertEqual(is_in_box, point2 in disp) -class TestDisplayableContainer(unittest.TestCase): - def setUp(self): - self.win = Fake() - self.fm = Fake() - self.env = Fake() - self.settings = Fake() - - self.initdict = {'win': self.win, 'settings': self.settings, - 'fm': self.fm, 'env': self.env} - - self.disp = Displayable(**self.initdict) - self.disc = DisplayableContainer(**self.initdict) - self.disc.add_child(self.disp) - - hei, wid = (100, 100) - self.env.termsize = (hei, wid) - - def tearDown(self): - self.disc.destroy() - - def test_container(self): - self.assertTrue(self.disp in self.disc.container) - def test_click(self): self.disp.click = raise_ok - self.disc.resize(0, 0, 50, 50) - self.disp.resize(0, 0, 20, 20) - fakepos = Fake() - - fakepos.x = 10 - fakepos.y = 10 - self.assertRaises(OK, self.disc.click, fakepos) - - fakepos.x = 30 - fakepos.y = 10 - self.disc.click(fakepos) - - def test_focused_object(self): - d1 = Displayable(**self.initdict) - d2 = DisplayableContainer(**self.initdict) - for obj in (Displayable(**self.initdict) for x in range(5)): - d2.add_child(obj) - d3 = DisplayableContainer(**self.initdict) - for obj in (Displayable(**self.initdict) for x in range(5)): - d3.add_child(obj) - - for obj in (d1, d2, d3): - self.disc.add_child(obj) + hei, wid = self.env.termsize - d3.container[3].focused = True + for i in range(50): + winwid = randint(2, wid-1) + winhei = randint(2, hei-1) + self.disc.resize(0, 0, hei, wid) + self.disp.resize(0, 0, winhei, winwid) + fakepos = Fake() - self.assertEqual(self.disc._get_focused_obj(), d3.container[3]) + fakepos.x = winwid - 2 + fakepos.y = winhei - 2 + self.assertRaises(OK, self.disc.click, fakepos) - d3.container[3].focused = False - d2.container[0].focused = True + fakepos.x = winwid + fakepos.y = winhei + self.disc.click(fakepos) - self.assertEqual(self.disc._get_focused_obj(), d2.container[0]) if __name__ == '__main__': unittest.main() diff --git a/test/tc_keyapi.py b/test/tc_keyapi.py index d6c32271..3cd5da0a 100644 --- a/test/tc_keyapi.py +++ b/test/tc_keyapi.py @@ -7,12 +7,12 @@ class Test(TestCase): from ranger.keyapi import Wrapper class dummyfm(object): - def move(relative): + def move(self, relative): return "I move down by {0}".format(relative) class commandarg(object): def __init__(self): - self.fm = dummyfm + self.fm = dummyfm() self.n = None arg = commandarg() diff --git a/test/tc_ui.py b/test/tc_ui.py index eb503c5d..d7b2de7c 100644 --- a/test/tc_ui.py +++ b/test/tc_ui.py @@ -13,7 +13,7 @@ class Test(unittest.TestCase): def setUp(self): self.fm = Fake() - self.ui = ui.UI(env=Fake(), fm=self.fm) + self.ui = ui.UI(env=Fake(), fm=self.fm, commandlist=Fake()) def fakesetup(): self.ui.widget = Fake() -- cgit 1.4.1-2-gfad0