diff options
author | Renato Filho <renato.filho@openbossa.org> | 2011-05-04 17:24:14 -0300 |
---|---|---|
committer | Hugo Parente Lima <hugo.pl@gmail.com> | 2012-03-08 16:54:19 -0300 |
commit | adf13f83e978a1ef07f0052847d6e02bd1215c43 (patch) | |
tree | b36397ba16f115f00c13857985c742052fb9c48f /tests/QtCore | |
parent | f65c15ec955cc4c114142c4f022f2a2e537669e0 (diff) |
Created unit test for bug #820.
Reviewer: Lauro Moura <lauro.neto@openbossa.org>
Hugo Parente Lima <hugo.pl@gmail.com>
Diffstat (limited to 'tests/QtCore')
-rw-r--r-- | tests/QtCore/CMakeLists.txt | 1 | ||||
-rw-r--r-- | tests/QtCore/bug_820.py | 69 |
2 files changed, 70 insertions, 0 deletions
diff --git a/tests/QtCore/CMakeLists.txt b/tests/QtCore/CMakeLists.txt index 62363478b..7ee22f953 100644 --- a/tests/QtCore/CMakeLists.txt +++ b/tests/QtCore/CMakeLists.txt @@ -10,6 +10,7 @@ PYSIDE_TEST(bug_699.py) PYSIDE_TEST(bug_706.py) PYSIDE_TEST(bug_723.py) PYSIDE_TEST(bug_724.py) +PYSIDE_TEST(bug_820.py) PYSIDE_TEST(bug_826.py) PYSIDE_TEST(bug_829.py) PYSIDE_TEST(bug_834.py) diff --git a/tests/QtCore/bug_820.py b/tests/QtCore/bug_820.py new file mode 100644 index 000000000..0e721972f --- /dev/null +++ b/tests/QtCore/bug_820.py @@ -0,0 +1,69 @@ +import functools +import unittest + +from PySide.QtCore import QObject, Slot, Signal, SIGNAL + +def log_exception(): + def log_exception_decorator(func): + @functools.wraps(func) + def wrapper(*args, **kwds): + try: + return func(*args, **kwds) + except Exception: + raise + + return wrapper + + return log_exception_decorator + + +def log_exception2(): + def log_exception_decorator(func): + def wrapper(*args, **kwds): + try: + return func(*args, **kwds) + except Exception: + raise + + return wrapper + + return log_exception_decorator + +class MyObject(QObject): + + def __init__(self, parent=None): + QObject.__init__(self, parent) + self._mySlotcalled = False + self._mySlot2called = False + + @Slot() + @log_exception() + def mySlot(self): + self._mySlotcalled = True + + @Slot(name="mySlot2") + @log_exception2() + def mySlot2(self): + self._mySlot2called = True + + def poke(self): + self.events.emit() + + events = Signal() + + +class SlotWithDecoratorTest(unittest.TestCase): + def testSlots(self): + o = MyObject() + self.assert_(o.metaObject().indexOfSlot("mySlot()") > 0) + self.assert_(o.metaObject().indexOfSlot("mySlot2()") > 0) + + o.events.connect(o.mySlot) + o.events.connect(o.mySlot2) + o.poke() + self.assertTrue(o._mySlotcalled) + self.assertTrue(o._mySlot2called) + +if __name__ == '__main__': + unittest.main() + |