summaryrefslogtreecommitdiffstats
path: root/tests/auto/qpushbutton
diff options
context:
space:
mode:
authorJani Honkonen <jani.honkonen@digia.com>2012-02-03 15:04:32 (GMT)
committerQt by Nokia <qt-info@nokia.com>2012-08-31 20:21:28 (GMT)
commit6265ac63fe85e1ff8b2d9ca3d023b3a1a8b281f0 (patch)
tree2f46656282e5d33917ae8cf2807cbd30963e4d31 /tests/auto/qpushbutton
parent1dddfaa82cadd782366ba7dc9d0995b6c9865a24 (diff)
downloadQt-6265ac63fe85e1ff8b2d9ca3d023b3a1a8b281f0.zip
Qt-6265ac63fe85e1ff8b2d9ca3d023b3a1a8b281f0.tar.gz
Qt-6265ac63fe85e1ff8b2d9ca3d023b3a1a8b281f0.tar.bz2
Fix limitting shortcuts to keypad only
The Qt::KeypadModifier modifier is internally masked away from all shortcuts. So it is not possible to set a keypad only shortcut. Changed the implementation so that first a full keysequence match is searched. Then if no match is found the same sequence is tried without the keypad modifer. Added a autotest for this also to cover the basic use cases relating to this. This is a backport of qt5 commit: 547a1bea492954d828aa0798be93384669812489 Task-number: QTBUG-20191 Change-Id: Ibb6809050ff6da23bdb1c087b93e517d1963d34c Reviewed-by: Stephen Kelly <stephen.kelly@kdab.com>
Diffstat (limited to 'tests/auto/qpushbutton')
-rw-r--r--tests/auto/qpushbutton/tst_qpushbutton.cpp47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/auto/qpushbutton/tst_qpushbutton.cpp b/tests/auto/qpushbutton/tst_qpushbutton.cpp
index 1c7c0b6..376b687 100644
--- a/tests/auto/qpushbutton/tst_qpushbutton.cpp
+++ b/tests/auto/qpushbutton/tst_qpushbutton.cpp
@@ -99,6 +99,7 @@ private slots:
void defaultAndAutoDefault();
void sizeHint_data();
void sizeHint();
+ void taskQTBUG_20191_shortcutWithKeypadModifer();
/*
void state();
void group();
@@ -702,5 +703,51 @@ void tst_QPushButton::sizeHint()
}
}
+void tst_QPushButton::taskQTBUG_20191_shortcutWithKeypadModifer()
+{
+ // setup a dialog with two buttons
+ QPushButton *button1 = new QPushButton("5");
+ QPushButton *button2 = new QPushButton("5 + KeypadModifier");
+ QVBoxLayout *layout = new QVBoxLayout();
+ layout->addWidget(button1);
+ layout->addWidget(button2);
+ QDialog dialog;
+ dialog.setLayout(layout);
+ dialog.show();
+ QTest::qWaitForWindowShown(&dialog);
+ QApplication::setActiveWindow(&dialog);
+
+ // add shortcut '5' to button1 and test with keyboard and keypad '5' keys
+ QSignalSpy spy1(button1, SIGNAL(clicked()));
+ button1->setShortcut(Qt::Key_5);
+ QTest::keyClick(&dialog, Qt::Key_5);
+ QTest::qWait(300);
+ QTest::keyClick(&dialog, Qt::Key_5, Qt::KeypadModifier);
+ QTest::qWait(300);
+ QCOMPARE(spy1.count(), 2);
+
+ // add shortcut 'keypad 5' to button2
+ spy1.clear();
+ QSignalSpy spy2(button2, SIGNAL(clicked()));
+ button2->setShortcut(Qt::Key_5 + Qt::KeypadModifier);
+ QTest::keyClick(&dialog, Qt::Key_5);
+ QTest::qWait(300);
+ QTest::keyClick(&dialog, Qt::Key_5, Qt::KeypadModifier);
+ QTest::qWait(300);
+ QCOMPARE(spy1.count(), 1);
+ QCOMPARE(spy2.count(), 1);
+
+ // remove shortcut from button1
+ spy1.clear();
+ spy2.clear();
+ button1->setShortcut(QKeySequence());
+ QTest::keyClick(&dialog, Qt::Key_5);
+ QTest::qWait(300);
+ QTest::keyClick(&dialog, Qt::Key_5, Qt::KeypadModifier);
+ QTest::qWait(300);
+ QCOMPARE(spy1.count(), 0);
+ QCOMPARE(spy2.count(), 1);
+}
+
QTEST_MAIN(tst_QPushButton)
#include "tst_qpushbutton.moc"