diff options
author | Jo Asplin <jo.asplin@nokia.com> | 2011-11-25 09:30:03 +0100 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2011-11-30 09:30:22 +0100 |
commit | 9acec431c360379a21cdbe36d8e342083f344c3c (patch) | |
tree | dcd0e4d4d60f7f9cfb6f6d210b6ebaf016573d1b /tests/auto/other/qfocusevent | |
parent | 75b66dc8b036c4f4ef3ff8ea109efd698b72732d (diff) | |
download | qtbase-9acec431c360379a21cdbe36d8e342083f344c3c.tar.gz |
Moved integrationtests/* into other/
Currently there seems to be no precise definition of what
an integrationtest is in the context of Qt testing.
To avoid confusion, the tests under integrationtests/ are
moved into other/ (which is effectively where we keep
tests that don't clearly fit into any other category).
Tests can be moved back into an integrationtests/ directory
at a later point, should an unambiguous definition be established.
Change-Id: I3bb289be2dc2aca11b51a8ce8fcc5942f06d6c5c
Reviewed-by: Jason McDonald <jason.mcdonald@nokia.com>
Diffstat (limited to 'tests/auto/other/qfocusevent')
-rw-r--r-- | tests/auto/other/qfocusevent/.gitignore | 1 | ||||
-rw-r--r-- | tests/auto/other/qfocusevent/qfocusevent.pro | 5 | ||||
-rw-r--r-- | tests/auto/other/qfocusevent/tst_qfocusevent.cpp | 394 |
3 files changed, 400 insertions, 0 deletions
diff --git a/tests/auto/other/qfocusevent/.gitignore b/tests/auto/other/qfocusevent/.gitignore new file mode 100644 index 0000000000..f189d8aeb9 --- /dev/null +++ b/tests/auto/other/qfocusevent/.gitignore @@ -0,0 +1 @@ +tst_qfocusevent diff --git a/tests/auto/other/qfocusevent/qfocusevent.pro b/tests/auto/other/qfocusevent/qfocusevent.pro new file mode 100644 index 0000000000..ee2cf22a6a --- /dev/null +++ b/tests/auto/other/qfocusevent/qfocusevent.pro @@ -0,0 +1,5 @@ +CONFIG += testcase +TARGET = tst_qfocusevent +QT += widgets testlib +SOURCES += tst_qfocusevent.cpp +mac: CONFIG += insignificant_test # QTBUG-22815 diff --git a/tests/auto/other/qfocusevent/tst_qfocusevent.cpp b/tests/auto/other/qfocusevent/tst_qfocusevent.cpp new file mode 100644 index 0000000000..cc58b6212c --- /dev/null +++ b/tests/auto/other/qfocusevent/tst_qfocusevent.cpp @@ -0,0 +1,394 @@ +/**************************************************************************** +** +** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: Nokia Corporation (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** GNU Lesser General Public License Usage +** This file may be used under the terms of the GNU Lesser General Public +** License version 2.1 as published by the Free Software Foundation and +** appearing in the file LICENSE.LGPL included in the packaging of this +** file. Please review the following information to ensure the GNU Lesser +** General Public License version 2.1 requirements will be met: +** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Nokia gives you certain additional +** rights. These rights are described in the Nokia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU General +** Public License version 3.0 as published by the Free Software Foundation +** and appearing in the file LICENSE.GPL included in the packaging of this +** file. Please review the following information to ensure the GNU General +** Public License version 3.0 requirements will be met: +** http://www.gnu.org/copyleft/gpl.html. +** +** Other Usage +** Alternatively, this file may be used in accordance with the terms and +** conditions contained in a signed written agreement between you and Nokia. +** +** +** +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + + +#include <QtTest/QtTest> +#include <qapplication.h> +#include <qlineedit.h> +#include <qmenu.h> +#include <qlabel.h> +#include <qdialog.h> +#include <qevent.h> +#include <qlineedit.h> +#include <QBoxLayout> + +QT_FORWARD_DECLARE_CLASS(QWidget) + +//TESTED_CLASS= +//TESTED_FILES=gui/kernel/qevent.h gui/kernel/qevent.cpp + +class FocusLineEdit : public QLineEdit +{ +public: + FocusLineEdit( QWidget* parent = 0, const char* name = 0 ) : QLineEdit(name, parent) {} + int focusInEventReason; + int focusOutEventReason; + bool focusInEventRecieved; + bool focusInEventGotFocus; + bool focusOutEventRecieved; + bool focusOutEventLostFocus; +protected: + virtual void keyPressEvent( QKeyEvent *e ) + { +// qDebug( QString("keyPressEvent: %1").arg(e->key()) ); + QLineEdit::keyPressEvent( e ); + } + void focusInEvent( QFocusEvent* e ) + { + QLineEdit::focusInEvent( e ); + focusInEventReason = e->reason(); + focusInEventGotFocus = e->gotFocus(); + focusInEventRecieved = TRUE; + } + void focusOutEvent( QFocusEvent* e ) + { + QLineEdit::focusOutEvent( e ); + focusOutEventReason = e->reason(); + focusOutEventLostFocus = !e->gotFocus(); + focusOutEventRecieved = TRUE; + } +}; + +class tst_QFocusEvent : public QObject +{ + Q_OBJECT + +public: + tst_QFocusEvent(); + virtual ~tst_QFocusEvent(); + + + void initWidget(); + +public slots: + void initTestCase(); + void cleanupTestCase(); + void init(); + void cleanup(); +private slots: + void checkReason_Tab(); + void checkReason_ShiftTab(); + void checkReason_BackTab(); + void checkReason_Popup(); + void checkReason_focusWidget(); + void checkReason_Shortcut(); + void checkReason_ActiveWindow(); + +private: + QWidget* testFocusWidget; + FocusLineEdit* childFocusWidgetOne; + FocusLineEdit* childFocusWidgetTwo; +}; + +tst_QFocusEvent::tst_QFocusEvent() +{ +} + +tst_QFocusEvent::~tst_QFocusEvent() +{ + +} + +void tst_QFocusEvent::initTestCase() +{ + testFocusWidget = new QWidget( 0 ); + childFocusWidgetOne = new FocusLineEdit( testFocusWidget ); + childFocusWidgetOne->setGeometry( 10, 10, 180, 20 ); + childFocusWidgetTwo = new FocusLineEdit( testFocusWidget ); + childFocusWidgetTwo->setGeometry( 10, 50, 180, 20 ); + + //qApp->setMainWidget( testFocusWidget ); Qt4 + testFocusWidget->resize( 200,100 ); + testFocusWidget->show(); +// Applications don't get focus when launched from the command line on Mac. +#ifdef Q_WS_MAC + testFocusWidget->raise(); +#endif +} + +void tst_QFocusEvent::cleanupTestCase() +{ + delete testFocusWidget; +} + +void tst_QFocusEvent::init() +{ +} + +void tst_QFocusEvent::cleanup() +{ + childFocusWidgetTwo->setGeometry( 10, 50, 180, 20 ); +} + +void tst_QFocusEvent::initWidget() +{ + // On X11 we have to ensure the event was processed before doing any checking, on Windows + // this is processed straight away. + QApplication::setActiveWindow(childFocusWidgetOne); + + for (int i = 0; i < 1000; ++i) { + if (childFocusWidgetOne->isActiveWindow() && childFocusWidgetOne->hasFocus()) + break; + childFocusWidgetOne->activateWindow(); + childFocusWidgetOne->setFocus(); + qApp->processEvents(); + QTest::qWait(100); + } + + // The first lineedit should have focus + QVERIFY( childFocusWidgetOne->hasFocus() ); + + childFocusWidgetOne->focusInEventRecieved = FALSE; + childFocusWidgetOne->focusInEventGotFocus = FALSE; + childFocusWidgetOne->focusInEventReason = -1; + childFocusWidgetOne->focusOutEventRecieved = FALSE; + childFocusWidgetOne->focusOutEventLostFocus = FALSE; + childFocusWidgetOne->focusOutEventReason = -1; + childFocusWidgetTwo->focusInEventRecieved = FALSE; + childFocusWidgetTwo->focusInEventGotFocus = FALSE; + childFocusWidgetTwo->focusInEventReason = -1; + childFocusWidgetTwo->focusOutEventRecieved = FALSE; + childFocusWidgetTwo->focusOutEventLostFocus = FALSE; + childFocusWidgetTwo->focusOutEventReason = -1; +} + +void tst_QFocusEvent::checkReason_Tab() +{ + initWidget(); + + // Now test the tab key + QTest::keyClick( childFocusWidgetOne, Qt::Key_Tab ); + + QVERIFY(childFocusWidgetOne->focusOutEventRecieved); + QVERIFY(childFocusWidgetTwo->focusInEventRecieved); + QVERIFY(childFocusWidgetOne->focusOutEventLostFocus); + QVERIFY(childFocusWidgetTwo->focusInEventGotFocus); + + QVERIFY( childFocusWidgetTwo->hasFocus() ); + QCOMPARE( childFocusWidgetOne->focusOutEventReason, (int) Qt::TabFocusReason ); + QCOMPARE( childFocusWidgetTwo->focusInEventReason, (int) Qt::TabFocusReason ); +} + +void tst_QFocusEvent::checkReason_ShiftTab() +{ + initWidget(); + + // Now test the shift + tab key + QTest::keyClick( childFocusWidgetOne, Qt::Key_Tab, Qt::ShiftModifier ); + + QVERIFY(childFocusWidgetOne->focusOutEventRecieved); + QVERIFY(childFocusWidgetTwo->focusInEventRecieved); + QVERIFY(childFocusWidgetOne->focusOutEventLostFocus); + QVERIFY(childFocusWidgetTwo->focusInEventGotFocus); + + QVERIFY( childFocusWidgetTwo->hasFocus() ); + QCOMPARE( childFocusWidgetOne->focusOutEventReason, (int)Qt::BacktabFocusReason ); + QCOMPARE( childFocusWidgetTwo->focusInEventReason, (int)Qt::BacktabFocusReason ); + +} + +/*! + In this test we verify that the Qt::KeyBacktab key is handled in a qfocusevent +*/ +void tst_QFocusEvent::checkReason_BackTab() +{ +#ifdef Q_OS_WIN32 // key is not supported on Windows + QSKIP( "Backtab is not supported on Windows"); +#else + initWidget(); + QVERIFY( childFocusWidgetOne->hasFocus() ); + + // Now test the backtab key + QTest::keyClick( childFocusWidgetOne, Qt::Key_Backtab ); + QTest::qWait(200); + + QTRY_VERIFY(childFocusWidgetOne->focusOutEventRecieved); + QVERIFY(childFocusWidgetTwo->focusInEventRecieved); + QVERIFY(childFocusWidgetOne->focusOutEventLostFocus); + QVERIFY(childFocusWidgetTwo->focusInEventGotFocus); + + QVERIFY( childFocusWidgetTwo->hasFocus() ); + QCOMPARE( childFocusWidgetOne->focusOutEventReason, int(Qt::BacktabFocusReason) ); + QCOMPARE( childFocusWidgetTwo->focusInEventReason, int(Qt::BacktabFocusReason) ); +#endif +} + +void tst_QFocusEvent::checkReason_Popup() +{ + initWidget(); + + // Now test the popup reason + QMenu* popupMenu = new QMenu( testFocusWidget ); + popupMenu->addMenu( "Test" ); + popupMenu->popup( QPoint(0,0) ); + QTest::qWait(50); + + QTRY_VERIFY(childFocusWidgetOne->focusOutEventLostFocus); + + QTRY_VERIFY( childFocusWidgetOne->hasFocus() ); + QVERIFY( !childFocusWidgetOne->focusInEventRecieved ); + QVERIFY( childFocusWidgetOne->focusOutEventRecieved ); + QVERIFY( !childFocusWidgetTwo->focusInEventRecieved ); + QVERIFY( !childFocusWidgetTwo->focusOutEventRecieved ); + QCOMPARE( childFocusWidgetOne->focusOutEventReason, int(Qt::PopupFocusReason)); + + popupMenu->hide(); + + QVERIFY(childFocusWidgetOne->focusInEventRecieved); + QVERIFY(childFocusWidgetOne->focusInEventGotFocus); + + QVERIFY( childFocusWidgetOne->hasFocus() ); + QVERIFY( childFocusWidgetOne->focusInEventRecieved ); + QVERIFY( childFocusWidgetOne->focusOutEventRecieved ); + QVERIFY( !childFocusWidgetTwo->focusInEventRecieved ); + QVERIFY( !childFocusWidgetTwo->focusOutEventRecieved ); +} + +#ifdef Q_WS_MAC +QT_BEGIN_NAMESPACE + extern void qt_set_sequence_auto_mnemonic(bool); +QT_END_NAMESPACE +#endif + +void tst_QFocusEvent::checkReason_Shortcut() +{ + initWidget(); +#ifdef Q_WS_MAC + qt_set_sequence_auto_mnemonic(true); +#endif + QLabel* label = new QLabel( "&Test", testFocusWidget ); + label->setBuddy( childFocusWidgetTwo ); + label->setGeometry( 10, 50, 90, 20 ); + childFocusWidgetTwo->setGeometry( 105, 50, 95, 20 ); + label->show(); + + QVERIFY( childFocusWidgetOne->hasFocus() ); + QVERIFY( !childFocusWidgetTwo->hasFocus() ); + + QTest::keyClick( label, Qt::Key_T, Qt::AltModifier ); + + QVERIFY(childFocusWidgetOne->focusOutEventRecieved); + QVERIFY(childFocusWidgetTwo->focusInEventRecieved); + QVERIFY(childFocusWidgetOne->focusOutEventLostFocus); + QVERIFY(childFocusWidgetTwo->focusInEventGotFocus); + + QVERIFY( childFocusWidgetTwo->hasFocus() ); + QVERIFY( !childFocusWidgetOne->focusInEventRecieved ); + QVERIFY( childFocusWidgetOne->focusOutEventRecieved ); + QCOMPARE( childFocusWidgetOne->focusOutEventReason, (int)Qt::ShortcutFocusReason ); + QVERIFY( childFocusWidgetTwo->focusInEventRecieved ); + QCOMPARE( childFocusWidgetTwo->focusInEventReason, (int)Qt::ShortcutFocusReason ); + QVERIFY( !childFocusWidgetTwo->focusOutEventRecieved ); + + label->hide(); + QVERIFY( childFocusWidgetTwo->hasFocus() ); + QVERIFY( !childFocusWidgetOne->hasFocus() ); +#ifdef Q_WS_MAC + qt_set_sequence_auto_mnemonic(false); +#endif +} + +void tst_QFocusEvent::checkReason_focusWidget() +{ + // This test checks that a widget doesn't loose + // its focuswidget just because the focuswidget looses focus. + QWidget window1; + QWidget frame1; + QWidget frame2; + QLineEdit edit1; + QLineEdit edit2; + + QVBoxLayout outerLayout; + outerLayout.addWidget(&frame1); + outerLayout.addWidget(&frame2); + window1.setLayout(&outerLayout); + + QVBoxLayout leftLayout; + QVBoxLayout rightLayout; + leftLayout.addWidget(&edit1); + rightLayout.addWidget(&edit2); + frame1.setLayout(&leftLayout); + frame2.setLayout(&rightLayout); + window1.show(); + + edit1.setFocus(); + QTest::qWait(100); + edit2.setFocus(); + + QVERIFY(frame1.focusWidget() != 0); + QVERIFY(frame2.focusWidget() != 0); +} + +void tst_QFocusEvent::checkReason_ActiveWindow() +{ + initWidget(); + + QDialog* d = new QDialog( testFocusWidget ); + d->show(); + d->activateWindow(); // ### CDE + QApplication::setActiveWindow(d); + QTest::qWaitForWindowShown(d); + + QTRY_VERIFY(childFocusWidgetOne->focusOutEventRecieved); + QVERIFY(childFocusWidgetOne->focusOutEventLostFocus); + + QVERIFY( !childFocusWidgetOne->focusInEventRecieved ); + QVERIFY( childFocusWidgetOne->focusOutEventRecieved ); + QCOMPARE( childFocusWidgetOne->focusOutEventReason, (int)Qt::ActiveWindowFocusReason); + QVERIFY( !childFocusWidgetOne->hasFocus() ); + + d->hide(); + QTest::qWait(100); + +#if defined(Q_OS_IRIX) + QEXPECT_FAIL("", "IRIX requires explicit activateWindow(), so this test does not make any sense.", Abort); +#endif + QTRY_VERIFY(childFocusWidgetOne->focusInEventRecieved); + QVERIFY(childFocusWidgetOne->focusInEventGotFocus); + + QVERIFY( childFocusWidgetOne->hasFocus() ); + QVERIFY( childFocusWidgetOne->focusInEventRecieved ); + QCOMPARE( childFocusWidgetOne->focusInEventReason, (int)Qt::ActiveWindowFocusReason); +} + + +QTEST_MAIN(tst_QFocusEvent) +#include "tst_qfocusevent.moc" |