diff options
Diffstat (limited to 'tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp')
-rw-r--r-- | tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp b/tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp index 2a5e59f825..432950b8ec 100644 --- a/tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp +++ b/tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp @@ -392,6 +392,7 @@ private slots: void nativeChildFocus(); void grab(); void grabMouse(); + void grabKeyboard(); void touchEventSynthesizedMouseEvent(); @@ -9412,6 +9413,27 @@ void tst_QWidget::grabMouse() QCOMPARE(log, expectedLog); } +void tst_QWidget::grabKeyboard() +{ + QWidget w; + w.setObjectName(QLatin1String("tst_qwidget_grabKeyboard")); + w.setWindowTitle(w.objectName()); + QLayout *layout = new QVBoxLayout(&w); + QLineEdit *grabber = new QLineEdit(&w); + layout->addWidget(grabber); + QLineEdit *nonGrabber = new QLineEdit(&w); + layout->addWidget(nonGrabber); + w.show(); + qApp->setActiveWindow(&w); + QVERIFY(QTest::qWaitForWindowActive(&w)); + nonGrabber->setFocus(); + grabber->grabKeyboard(); + QTest::keyClick(w.windowHandle(), Qt::Key_A); + grabber->releaseKeyboard(); + QCOMPARE(grabber->text().toLower(), QStringLiteral("a")); + QVERIFY(nonGrabber->text().isEmpty()); +} + class TouchMouseWidget : public QWidget { public: explicit TouchMouseWidget(QWidget *parent = 0) |