summaryrefslogtreecommitdiffstats
path: root/tests/auto/widgets
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auto/widgets')
-rw-r--r--tests/auto/widgets/kernel/qwidget/tst_qwidget.cpp22
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)