diff options
Diffstat (limited to 'sources/pyside6/tests/QtTest')
-rw-r--r-- | sources/pyside6/tests/QtTest/CMakeLists.txt | 9 | ||||
-rw-r--r-- | sources/pyside6/tests/QtTest/QtTest.pyproject | 7 | ||||
-rw-r--r-- | sources/pyside6/tests/QtTest/click_test.py | 38 | ||||
-rw-r--r-- | sources/pyside6/tests/QtTest/eventfilter_test.py | 57 | ||||
-rw-r--r-- | sources/pyside6/tests/QtTest/qsignalspy_test.py | 42 | ||||
-rw-r--r-- | sources/pyside6/tests/QtTest/qvalidator_test.py | 122 | ||||
-rw-r--r-- | sources/pyside6/tests/QtTest/touchevent_test.py | 63 |
7 files changed, 338 insertions, 0 deletions
diff --git a/sources/pyside6/tests/QtTest/CMakeLists.txt b/sources/pyside6/tests/QtTest/CMakeLists.txt new file mode 100644 index 000000000..21a585ea4 --- /dev/null +++ b/sources/pyside6/tests/QtTest/CMakeLists.txt @@ -0,0 +1,9 @@ +# Copyright (C) 2023 The Qt Company Ltd. +# SPDX-License-Identifier: BSD-3-Clause + +PYSIDE_TEST(click_test.py) +PYSIDE_TEST(eventfilter_test.py) +# The test is currently permanently broken, needs to be fixed. +#PYSIDE_TEST(touchevent_test.py) +PYSIDE_TEST(qsignalspy_test.py) +PYSIDE_TEST(qvalidator_test.py) diff --git a/sources/pyside6/tests/QtTest/QtTest.pyproject b/sources/pyside6/tests/QtTest/QtTest.pyproject new file mode 100644 index 000000000..151c0ef08 --- /dev/null +++ b/sources/pyside6/tests/QtTest/QtTest.pyproject @@ -0,0 +1,7 @@ +{ + "files": ["click_test.py", + "eventfilter_test.py", + "qsignalspy_test.py", + "qvalidator_test.py", + "touchevent_test.py"] +} diff --git a/sources/pyside6/tests/QtTest/click_test.py b/sources/pyside6/tests/QtTest/click_test.py new file mode 100644 index 000000000..da8b2dcf6 --- /dev/null +++ b/sources/pyside6/tests/QtTest/click_test.py @@ -0,0 +1,38 @@ +# Copyright (C) 2022 The Qt Company Ltd. +# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 + +'''QtTest mouse click functionalities''' + +import os +import sys +import unittest + +from pathlib import Path +sys.path.append(os.fspath(Path(__file__).resolve().parents[1])) +from init_paths import init_test_paths +init_test_paths(False) + +from PySide6.QtCore import Qt, QObject +from PySide6.QtWidgets import QPushButton, QLineEdit +from PySide6.QtTest import QTest + +from helper.usesqapplication import UsesQApplication + + +class MouseClickTest(UsesQApplication): + + def testBasic(self): + '''QTest.mouseClick with QCheckBox''' + button = QPushButton() + button.setCheckable(True) + button.setChecked(False) + + QTest.mouseClick(button, Qt.LeftButton) + self.assertTrue(button.isChecked()) + + QTest.mouseClick(button, Qt.LeftButton) + self.assertFalse(button.isChecked()) + + +if __name__ == '__main__': + unittest.main() diff --git a/sources/pyside6/tests/QtTest/eventfilter_test.py b/sources/pyside6/tests/QtTest/eventfilter_test.py new file mode 100644 index 000000000..c57974c0d --- /dev/null +++ b/sources/pyside6/tests/QtTest/eventfilter_test.py @@ -0,0 +1,57 @@ +# Copyright (C) 2022 The Qt Company Ltd. +# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 + +'''Tests for QKeyEvent''' + +import os +import sys +import unittest + +from pathlib import Path +sys.path.append(os.fspath(Path(__file__).resolve().parents[1])) +from init_paths import init_test_paths +init_test_paths(False) + +from PySide6.QtCore import Qt, QObject, QEvent +from PySide6.QtGui import QKeyEvent +from PySide6.QtWidgets import QLineEdit +from PySide6.QtTest import QTest + +from helper.usesqapplication import UsesQApplication + + +class KeyEventFilter(QObject): + + def __init__(self, widget, eventType, key): + super().__init__() + + self.widget = widget + self.eventType = eventType + self.key = key + + self.processed = False + + def eventFilter(self, obj, event): + if self.widget == obj and event.type() == self.eventType and \ + isinstance(event, QKeyEvent) and event.key() == self.key: + self.processed = True + return True + + return False + + +class EventFilterTest(UsesQApplication): + + def testKeyEvent(self): + widget = QLineEdit() + key = Qt.Key_A + eventFilter = KeyEventFilter(widget, QEvent.KeyPress, key) + widget.installEventFilter(eventFilter) + + QTest.keyClick(widget, key) + + self.assertTrue(eventFilter.processed) + + +if __name__ == '__main__': + unittest.main() diff --git a/sources/pyside6/tests/QtTest/qsignalspy_test.py b/sources/pyside6/tests/QtTest/qsignalspy_test.py new file mode 100644 index 000000000..06f05b4b8 --- /dev/null +++ b/sources/pyside6/tests/QtTest/qsignalspy_test.py @@ -0,0 +1,42 @@ +# Copyright (C) 2022 The Qt Company Ltd. +# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 + +'''QtTest QSignalSpy''' + +import os +import sys +import unittest + +from pathlib import Path +sys.path.append(os.fspath(Path(__file__).resolve().parents[1])) +from init_paths import init_test_paths +init_test_paths(False) + +from PySide6.QtCore import Qt, QObject, SIGNAL +from PySide6.QtGui import QStandardItem, QStandardItemModel +from PySide6.QtTest import QTest, QSignalSpy + +from helper.usesqapplication import UsesQApplication + + +class QSignalSpyTest(UsesQApplication): + + def setUp(self): + super().setUp() + self._model = QStandardItemModel(0, 1) + self._model.appendRow(QStandardItem('text1')) + + def testStringBased(self): + s = SIGNAL('dataChanged(QModelIndex,QModelIndex,QList<int>)') + spy = QSignalSpy(self._model, s) + self._model.item(0, 0).setText('text2') + self.assertEqual(spy.count(), 1) + + def testSignal(self): + spy = QSignalSpy(self._model.dataChanged) + self._model.item(0, 0).setText('text3') + self.assertEqual(spy.count(), 1) + + +if __name__ == '__main__': + unittest.main() diff --git a/sources/pyside6/tests/QtTest/qvalidator_test.py b/sources/pyside6/tests/QtTest/qvalidator_test.py new file mode 100644 index 000000000..2382b8605 --- /dev/null +++ b/sources/pyside6/tests/QtTest/qvalidator_test.py @@ -0,0 +1,122 @@ +# Copyright (C) 2022 The Qt Company Ltd. +# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 + +import os +import sys +import unittest + +from pathlib import Path +sys.path.append(os.fspath(Path(__file__).resolve().parents[1])) +from init_paths import init_test_paths +init_test_paths(False) + +from PySide6.QtCore import QTimer, Qt +from PySide6.QtGui import QValidator +from PySide6.QtWidgets import QLineEdit +from PySide6.QtTest import QTest +from helper.usesqapplication import UsesQApplication + + +class MyValidator1(QValidator): + def fixup(self, input): + return "fixed" + + def validate(self, input, pos): + return (QValidator.Acceptable, "fixed", 1) + + +class MyValidator2(QValidator): + def fixup(self, input): + return "fixed" + + def validate(self, input, pos): + return (QValidator.Acceptable, "fixed") + + +class MyValidator3(QValidator): + def fixup(self, input): + return "fixed" + + def validate(self, input, pos): + return (QValidator.Acceptable,) + + +class MyValidator4(QValidator): + def fixup(self, input): + return "fixed" + + def validate(self, input, pos): + return QValidator.Acceptable + + +class MyValidator5(QValidator): + def validate(self, input, pos): + if input.islower(): + return (QValidator.Intermediate, input, pos) + else: + return (QValidator.Acceptable, input, pos) + + def fixup(self, input): + return "22" + + +class QValidatorTest(UsesQApplication): + def testValidator1(self): + line = QLineEdit() + line.setValidator(MyValidator1()) + line.show() + line.setText("foo") + + QTimer.singleShot(0, line.close) + self.app.exec() + + self.assertEqual(line.text(), "fixed") + self.assertEqual(line.cursorPosition(), 1) + + def testValidator2(self): + line = QLineEdit() + line.setValidator(MyValidator2()) + line.show() + line.setText("foo") + + QTimer.singleShot(0, line.close) + self.app.exec() + + self.assertEqual(line.text(), "fixed") + self.assertEqual(line.cursorPosition(), 3) + + def testValidator3(self): + line = QLineEdit() + line.setValidator(MyValidator3()) + line.show() + line.setText("foo") + + QTimer.singleShot(0, line.close) + self.app.exec() + + self.assertEqual(line.text(), "foo") + self.assertEqual(line.cursorPosition(), 3) + + def testValidator4(self): + line = QLineEdit() + line.setValidator(MyValidator4()) + line.show() + line.setText("foo") + + QTimer.singleShot(0, line.close) + self.app.exec() + + self.assertEqual(line.text(), "foo") + self.assertEqual(line.cursorPosition(), 3) + + def testValidator5(self): + line = QLineEdit() + line.show() + line.setValidator(MyValidator5()) + line.setText("foo") + QTest.keyClick(line, Qt.Key_Return) + self.assertEqual(line.text(), "22") + + +if __name__ == '__main__': + unittest.main() diff --git a/sources/pyside6/tests/QtTest/touchevent_test.py b/sources/pyside6/tests/QtTest/touchevent_test.py new file mode 100644 index 000000000..bc07c25ed --- /dev/null +++ b/sources/pyside6/tests/QtTest/touchevent_test.py @@ -0,0 +1,63 @@ +# Copyright (C) 2022 The Qt Company Ltd. +# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 + +import gc +import os +import sys +import unittest + +from pathlib import Path +sys.path.append(os.fspath(Path(__file__).resolve().parents[1])) +from init_paths import init_test_paths +init_test_paths(False) + +from helper.usesqapplication import UsesQApplication + +from PySide6.QtWidgets import QWidget +from PySide6.QtCore import QPoint, QTimer, Qt, QEvent +from PySide6.QtGui import QTouchDevice +from PySide6.QtTest import QTest + + +class MyWidget(QWidget): + def __init__(self, parent=None): + QWidget.__init__(self, parent) + self._sequence = [] + # Fixme (Qt 5): The device needs to be registered (using + # QWindowSystemInterface::registerTouchDevice()) for the test to work + self._device = QTouchDevice() + self.setAttribute(Qt.WA_AcceptTouchEvents) + QTimer.singleShot(200, self.generateEvent) + + def event(self, e): + self._sequence.append(e.type()) + return QWidget.event(self, e) + + def generateEvent(self): + o = QTest.touchEvent(self, self._device) + o.press(0, QPoint(10, 10)) + o.commit() + del o + # PYSIDE-535: Need to collect garbage in PyPy to trigger deletion + gc.collect() + + QTest.touchEvent(self, self._device).press(0, QPoint(10, 10)) + QTest.touchEvent(self, self._device).stationary(0).press(1, QPoint(40, 10)) + QTest.touchEvent(self, self._device).move(0, QPoint(12, 12)).move(1, QPoint(45, 5)) + QTest.touchEvent(self, self._device).release(0, QPoint(12, 12)).release(1, QPoint(45, 5)) + QTimer.singleShot(200, self.deleteLater) + + +class TouchEventTest(UsesQApplication): + def testCreateEvent(self): + w = MyWidget() + w.show() + self.app.exec() + # same values as C++ + self.assertEqual(w._sequence.count(QEvent.Type.TouchBegin), 2) + self.assertEqual(w._sequence.count(QEvent.Type.TouchUpdate), 2) + self.assertEqual(w._sequence.count(QEvent.Type.TouchEnd), 1) + + +if __name__ == '__main__': + unittest.main() |