diff options
author | Renato Filho <renato.filho@openbossa.org> | 2010-08-26 15:23:23 -0300 |
---|---|---|
committer | Renato Filho <renato.filho@openbossa.org> | 2010-08-26 16:21:41 -0300 |
commit | a2f3e249bc0543b522c7d0e516dd07326e3ea7de (patch) | |
tree | e9dc91414290d52138632821e0bcc2231cd8950b /tests | |
parent | 268bf7735b787d2310e18b3aed262bd27b9d24c6 (diff) |
Fixed slot singature parse function to keep compatibility with QSignal.
Fixes bug #319
Reviewer: Luciano Wolf <luciano.wolf@openbossa.org>
Hugo Parente Lima <hugo.pl@gmail.com>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/signals/CMakeLists.txt | 1 | ||||
-rw-r--r-- | tests/signals/bug_319.py | 35 |
2 files changed, 36 insertions, 0 deletions
diff --git a/tests/signals/CMakeLists.txt b/tests/signals/CMakeLists.txt index a69aa0610..5849dc55c 100644 --- a/tests/signals/CMakeLists.txt +++ b/tests/signals/CMakeLists.txt @@ -1,5 +1,6 @@ PYSIDE_TEST(args_dont_match_test.py) PYSIDE_TEST(bug_311.py) +PYSIDE_TEST(bug_319.py) PYSIDE_TEST(decorators_test.py) PYSIDE_TEST(invalid_callback_test.py) PYSIDE_TEST(lambda_gui_test.py) diff --git a/tests/signals/bug_319.py b/tests/signals/bug_319.py new file mode 100644 index 000000000..692b1bff7 --- /dev/null +++ b/tests/signals/bug_319.py @@ -0,0 +1,35 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +import unittest +from PySide import QtCore +from helper import UsesQCoreApplication + +class Listener(QtCore.QObject): + def __init__(self): + QtCore.QObject.__init__(self, None) + self._phrase = [] + + @QtCore.Slot(tuple) + def listen(self, words): + for w in words: + self._phrase.append(w) + +class Communicate(QtCore.QObject): + # create a new signal on the fly and name it 'speak' + speak = QtCore.Signal(tuple) + +class SignaltoSignalTest(UsesQCoreApplication): + def testBug(self): + someone = Communicate() + someone2 = Listener() + # connect signal and slot + someone.speak.connect(someone2.listen) + # emit 'speak' signal + talk = ("one","two","three") + someone.speak.emit(talk) + self.assertEqual(someone2._phrase, list(talk)) + +if __name__ == '__main__': + unittest.main() + |