From 71726ccf676ef0921ef557c7162d2d87563066fb Mon Sep 17 00:00:00 2001 From: Pekka Vuorela Date: Tue, 24 Jan 2012 17:44:38 +0200 Subject: Renamed QInputPanel as QInputMethod QInputMethod better describes what the class is about, input methods in general, be they panels or just composing input from key events. Compatability headers added for old name. Not bulletproof but should be enough to get transition done. Change-Id: Iefde6e7ccb1ec4a3b226cef3469089e751c60fc1 Reviewed-by: Joona Petrell --- tests/auto/gui/kernel/kernel.pro | 2 +- .../auto/gui/kernel/qinputmethod/qinputmethod.pro | 4 + .../gui/kernel/qinputmethod/tst_qinputmethod.cpp | 342 +++++++++++++++++++++ tests/auto/gui/kernel/qinputpanel/qinputpanel.pro | 4 - .../gui/kernel/qinputpanel/tst_qinputpanel.cpp | 342 --------------------- 5 files changed, 347 insertions(+), 347 deletions(-) create mode 100644 tests/auto/gui/kernel/qinputmethod/qinputmethod.pro create mode 100644 tests/auto/gui/kernel/qinputmethod/tst_qinputmethod.cpp delete mode 100644 tests/auto/gui/kernel/qinputpanel/qinputpanel.pro delete mode 100644 tests/auto/gui/kernel/qinputpanel/tst_qinputpanel.cpp (limited to 'tests/auto/gui') diff --git a/tests/auto/gui/kernel/kernel.pro b/tests/auto/gui/kernel/kernel.pro index 9465b0ae3b..1adae128cf 100644 --- a/tests/auto/gui/kernel/kernel.pro +++ b/tests/auto/gui/kernel/kernel.pro @@ -6,7 +6,7 @@ SUBDIRS=\ qfileopenevent \ qguimetatype \ qguivariant \ - qinputpanel \ + qinputmethod \ qkeysequence \ qmouseevent \ qmouseevent_modal \ diff --git a/tests/auto/gui/kernel/qinputmethod/qinputmethod.pro b/tests/auto/gui/kernel/qinputmethod/qinputmethod.pro new file mode 100644 index 0000000000..015cc782eb --- /dev/null +++ b/tests/auto/gui/kernel/qinputmethod/qinputmethod.pro @@ -0,0 +1,4 @@ +CONFIG += testcase +TARGET = tst_qinputmethod +SOURCES += tst_qinputmethod.cpp +QT += core-private gui-private testlib diff --git a/tests/auto/gui/kernel/qinputmethod/tst_qinputmethod.cpp b/tests/auto/gui/kernel/qinputmethod/tst_qinputmethod.cpp new file mode 100644 index 0000000000..c10d954489 --- /dev/null +++ b/tests/auto/gui/kernel/qinputmethod/tst_qinputmethod.cpp @@ -0,0 +1,342 @@ +/**************************************************************************** +** +** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/ +** +** 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 + +#include +#include +#include + +class PlatformInputContext : public QPlatformInputContext +{ +public: + PlatformInputContext() : + m_animating(false), + m_visible(false), + m_updateCallCount(0), + m_resetCallCount(0), + m_commitCallCount(0), + m_localeCallCount(0), + m_inputDirectionCallCount(0), + m_lastQueries(Qt::ImhNone), + m_action(QInputMethod::Click), + m_cursorPosition(0), + m_lastEventType(QEvent::None) + {} + + virtual QRectF keyboardRect() const { return m_keyboardRect; } + virtual bool isAnimating() const { return m_animating; } + virtual void reset() { m_resetCallCount++; } + virtual void commit() { m_commitCallCount++; } + + virtual void update(Qt::InputMethodQueries queries) + { + m_updateCallCount++; + m_lastQueries = queries; + } + virtual void invokeAction(QInputMethod::Action action, int cursorPosition) + { + m_action = action; + m_cursorPosition = cursorPosition; + } + virtual bool filterEvent(const QEvent *event) + { + m_lastEventType = event->type(); return false; + } + virtual void showInputPanel() + { + m_visible = true; + } + virtual void hideInputPanel() + { + m_visible = false; + } + virtual bool isInputPanelVisible() const + { + return m_visible; + } + virtual QLocale locale() const + { + m_localeCallCount++; + return QLocale::c(); + } + virtual Qt::LayoutDirection inputDirection() const + { + m_inputDirectionCallCount++; + return Qt::LeftToRight; + } + + bool m_animating; + bool m_visible; + int m_updateCallCount; + int m_resetCallCount; + int m_commitCallCount; + mutable int m_localeCallCount; + mutable int m_inputDirectionCallCount; + Qt::InputMethodQueries m_lastQueries; + QInputMethod::Action m_action; + int m_cursorPosition; + int m_lastEventType; + QRectF m_keyboardRect; +}; + +class InputItem : public QObject +{ + Q_OBJECT +public: + bool event(QEvent *event) + { + if (event->type() == QEvent::InputMethodQuery) { + QInputMethodQueryEvent *query = static_cast(event); + if (query->queries() & Qt::ImCursorRectangle) + query->setValue(Qt::ImCursorRectangle, QRectF(1, 2, 3, 4)); + if (query->queries() & Qt::ImPreferredLanguage) + query->setValue(Qt::ImPreferredLanguage, QString("English")); + m_lastQueries = query->queries(); + query->accept(); + return true; + } + return false; + } + Qt::InputMethodQueries m_lastQueries; +}; + +class tst_qinputmethod : public QObject +{ + Q_OBJECT +public: + tst_qinputmethod() {} + virtual ~tst_qinputmethod() {} +private slots: + void initTestCase(); + void visible(); + void animating(); + void keyboarRectangle(); + void inputItem(); + void inputItemTransform(); + void cursorRectangle(); + void invokeAction(); + void reset(); + void commit(); + void update(); + void query(); + void inputDirection(); +private: + InputItem m_inputItem; + PlatformInputContext m_platformInputContext; +}; + +void tst_qinputmethod::initTestCase() +{ + QInputMethodPrivate *inputMethodPrivate = QInputMethodPrivate::get(qApp->inputMethod()); + inputMethodPrivate->testContext = &m_platformInputContext; +} + +void tst_qinputmethod::visible() +{ + QCOMPARE(qApp->inputMethod()->visible(), false); + qApp->inputMethod()->show(); + QCOMPARE(qApp->inputMethod()->visible(), true); + + qApp->inputMethod()->hide(); + QCOMPARE(qApp->inputMethod()->visible(), false); + + qApp->inputMethod()->setVisible(true); + QCOMPARE(qApp->inputMethod()->visible(), true); + + qApp->inputMethod()->setVisible(false); + QCOMPARE(qApp->inputMethod()->visible(), false); +} + +void tst_qinputmethod::animating() +{ + QCOMPARE(qApp->inputMethod()->isAnimating(), false); + + m_platformInputContext.m_animating = true; + QCOMPARE(qApp->inputMethod()->isAnimating(), true); + + m_platformInputContext.m_animating = false; + QCOMPARE(qApp->inputMethod()->isAnimating(), false); + + QSignalSpy spy(qApp->inputMethod(), SIGNAL(animatingChanged())); + m_platformInputContext.emitAnimatingChanged(); + QCOMPARE(spy.count(), 1); +} + +void tst_qinputmethod::keyboarRectangle() +{ + QCOMPARE(qApp->inputMethod()->keyboardRectangle(), QRectF()); + + m_platformInputContext.m_keyboardRect = QRectF(10, 20, 30, 40); + QCOMPARE(qApp->inputMethod()->keyboardRectangle(), QRectF(10, 20, 30, 40)); + + QSignalSpy spy(qApp->inputMethod(), SIGNAL(keyboardRectangleChanged())); + m_platformInputContext.emitKeyboardRectChanged(); + QCOMPARE(spy.count(), 1); +} + +void tst_qinputmethod::inputItem() +{ + QVERIFY(!qApp->inputMethod()->inputItem()); + QSignalSpy spy(qApp->inputMethod(), SIGNAL(inputItemChanged())); + + qApp->inputMethod()->setInputItem(&m_inputItem); + + QCOMPARE(qApp->inputMethod()->inputItem(), &m_inputItem); + QCOMPARE(spy.count(), 1); + + // reset + qApp->inputMethod()->setInputItem(0); +} + +void tst_qinputmethod::inputItemTransform() +{ + QCOMPARE(qApp->inputMethod()->inputItemTransform(), QTransform()); + QSignalSpy spy(qApp->inputMethod(), SIGNAL(cursorRectangleChanged())); + + QTransform transform; + transform.translate(10, 10); + transform.scale(2, 2); + transform.shear(2, 2); + qApp->inputMethod()->setInputItemTransform(transform); + + QCOMPARE(qApp->inputMethod()->inputItemTransform(), transform); + QCOMPARE(spy.count(), 1); + + // reset + qApp->inputMethod()->setInputItemTransform(QTransform()); +} + +void tst_qinputmethod::cursorRectangle() +{ + QCOMPARE(qApp->inputMethod()->cursorRectangle(), QRectF()); + + QTransform transform; + transform.translate(10, 10); + transform.scale(2, 2); + transform.shear(2, 2); + qApp->inputMethod()->setInputItemTransform(transform); + qApp->inputMethod()->setInputItem(&m_inputItem); + + QCOMPARE(qApp->inputMethod()->cursorRectangle(), transform.mapRect(QRectF(1, 2, 3, 4))); + + // reset + qApp->inputMethod()->setInputItem(0); + qApp->inputMethod()->setInputItemTransform(QTransform()); +} + +void tst_qinputmethod::invokeAction() +{ + QCOMPARE(m_platformInputContext.m_action, QInputMethod::Click); + QCOMPARE(m_platformInputContext.m_cursorPosition, 0); + + qApp->inputMethod()->invokeAction(QInputMethod::ContextMenu, 5); + QCOMPARE(m_platformInputContext.m_action, QInputMethod::ContextMenu); + QCOMPARE(m_platformInputContext.m_cursorPosition, 5); +} + +void tst_qinputmethod::reset() +{ + QCOMPARE(m_platformInputContext.m_resetCallCount, 0); + + qApp->inputMethod()->reset(); + QCOMPARE(m_platformInputContext.m_resetCallCount, 1); + + qApp->inputMethod()->reset(); + QCOMPARE(m_platformInputContext.m_resetCallCount, 2); +} + +void tst_qinputmethod::commit() +{ + QCOMPARE(m_platformInputContext.m_commitCallCount, 0); + + qApp->inputMethod()->commit(); + QCOMPARE(m_platformInputContext.m_commitCallCount, 1); + + qApp->inputMethod()->commit(); + QCOMPARE(m_platformInputContext.m_commitCallCount, 2); +} + +void tst_qinputmethod::update() +{ + qApp->inputMethod()->setInputItem(&m_inputItem); + QCOMPARE(m_platformInputContext.m_updateCallCount, 0); + QCOMPARE(int(m_platformInputContext.m_lastQueries), int(Qt::ImhNone)); + + qApp->inputMethod()->update(Qt::ImQueryInput); + QCOMPARE(m_platformInputContext.m_updateCallCount, 1); + QCOMPARE(int(m_platformInputContext.m_lastQueries), int(Qt::ImQueryInput)); + + qApp->inputMethod()->update(Qt::ImQueryAll); + QCOMPARE(m_platformInputContext.m_updateCallCount, 2); + QCOMPARE(int(m_platformInputContext.m_lastQueries), int(Qt::ImQueryAll)); + + QCOMPARE(qApp->inputMethod()->keyboardRectangle(), QRectF(10, 20, 30, 40)); + + // reset + qApp->inputMethod()->setInputItem(0); +} + +void tst_qinputmethod::query() +{ + QInputMethodQueryEvent query(Qt::InputMethodQueries(Qt::ImPreferredLanguage | Qt::ImCursorRectangle)); + QGuiApplication::sendEvent(&m_inputItem, &query); + + QString language = query.value(Qt::ImPreferredLanguage).toString(); + QCOMPARE(language, QString("English")); + + QRect cursorRectangle = query.value(Qt::ImCursorRectangle).toRect(); + QCOMPARE(cursorRectangle, QRect(1,2,3,4)); +} + +void tst_qinputmethod::inputDirection() +{ + QCOMPARE(m_platformInputContext.m_inputDirectionCallCount, 0); + qApp->inputMethod()->inputDirection(); + QCOMPARE(m_platformInputContext.m_inputDirectionCallCount, 1); + + QCOMPARE(m_platformInputContext.m_localeCallCount, 0); + qApp->inputMethod()->locale(); + QCOMPARE(m_platformInputContext.m_localeCallCount, 1); +} + +QTEST_MAIN(tst_qinputmethod) +#include "tst_qinputmethod.moc" diff --git a/tests/auto/gui/kernel/qinputpanel/qinputpanel.pro b/tests/auto/gui/kernel/qinputpanel/qinputpanel.pro deleted file mode 100644 index 5e3f4b1504..0000000000 --- a/tests/auto/gui/kernel/qinputpanel/qinputpanel.pro +++ /dev/null @@ -1,4 +0,0 @@ -CONFIG += testcase -TARGET = tst_qinputpanel -SOURCES += tst_qinputpanel.cpp -QT += core-private gui-private testlib diff --git a/tests/auto/gui/kernel/qinputpanel/tst_qinputpanel.cpp b/tests/auto/gui/kernel/qinputpanel/tst_qinputpanel.cpp deleted file mode 100644 index 04b4ea54f7..0000000000 --- a/tests/auto/gui/kernel/qinputpanel/tst_qinputpanel.cpp +++ /dev/null @@ -1,342 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies). -** Contact: http://www.qt-project.org/ -** -** 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 - -#include -#include -#include - -class PlatformInputContext : public QPlatformInputContext -{ -public: - PlatformInputContext() : - m_animating(false), - m_visible(false), - m_updateCallCount(0), - m_resetCallCount(0), - m_commitCallCount(0), - m_localeCallCount(0), - m_inputDirectionCallCount(0), - m_lastQueries(Qt::ImhNone), - m_action(QInputPanel::Click), - m_cursorPosition(0), - m_lastEventType(QEvent::None) - {} - - virtual QRectF keyboardRect() const { return m_keyboardRect; } - virtual bool isAnimating() const { return m_animating; } - virtual void reset() { m_resetCallCount++; } - virtual void commit() { m_commitCallCount++; } - - virtual void update(Qt::InputMethodQueries queries) - { - m_updateCallCount++; - m_lastQueries = queries; - } - virtual void invokeAction(QInputPanel::Action action, int cursorPosition) - { - m_action = action; - m_cursorPosition = cursorPosition; - } - virtual bool filterEvent(const QEvent *event) - { - m_lastEventType = event->type(); return false; - } - virtual void showInputPanel() - { - m_visible = true; - } - virtual void hideInputPanel() - { - m_visible = false; - } - virtual bool isInputPanelVisible() const - { - return m_visible; - } - virtual QLocale locale() const - { - m_localeCallCount++; - return QLocale::c(); - } - virtual Qt::LayoutDirection inputDirection() const - { - m_inputDirectionCallCount++; - return Qt::LeftToRight; - } - - bool m_animating; - bool m_visible; - int m_updateCallCount; - int m_resetCallCount; - int m_commitCallCount; - mutable int m_localeCallCount; - mutable int m_inputDirectionCallCount; - Qt::InputMethodQueries m_lastQueries; - QInputPanel::Action m_action; - int m_cursorPosition; - int m_lastEventType; - QRectF m_keyboardRect; -}; - -class InputItem : public QObject -{ - Q_OBJECT -public: - bool event(QEvent *event) - { - if (event->type() == QEvent::InputMethodQuery) { - QInputMethodQueryEvent *query = static_cast(event); - if (query->queries() & Qt::ImCursorRectangle) - query->setValue(Qt::ImCursorRectangle, QRectF(1, 2, 3, 4)); - if (query->queries() & Qt::ImPreferredLanguage) - query->setValue(Qt::ImPreferredLanguage, QString("English")); - m_lastQueries = query->queries(); - query->accept(); - return true; - } - return false; - } - Qt::InputMethodQueries m_lastQueries; -}; - -class tst_qinputpanel : public QObject -{ - Q_OBJECT -public: - tst_qinputpanel() {} - virtual ~tst_qinputpanel() {} -private slots: - void initTestCase(); - void visible(); - void animating(); - void keyboarRectangle(); - void inputItem(); - void inputItemTransform(); - void cursorRectangle(); - void invokeAction(); - void reset(); - void commit(); - void update(); - void query(); - void inputDirection(); -private: - InputItem m_inputItem; - PlatformInputContext m_platformInputContext; -}; - -void tst_qinputpanel::initTestCase() -{ - QInputPanelPrivate *inputPanelPrivate = QInputPanelPrivate::get(qApp->inputPanel()); - inputPanelPrivate->testContext = &m_platformInputContext; -} - -void tst_qinputpanel::visible() -{ - QCOMPARE(qApp->inputPanel()->visible(), false); - qApp->inputPanel()->show(); - QCOMPARE(qApp->inputPanel()->visible(), true); - - qApp->inputPanel()->hide(); - QCOMPARE(qApp->inputPanel()->visible(), false); - - qApp->inputPanel()->setVisible(true); - QCOMPARE(qApp->inputPanel()->visible(), true); - - qApp->inputPanel()->setVisible(false); - QCOMPARE(qApp->inputPanel()->visible(), false); -} - -void tst_qinputpanel::animating() -{ - QCOMPARE(qApp->inputPanel()->isAnimating(), false); - - m_platformInputContext.m_animating = true; - QCOMPARE(qApp->inputPanel()->isAnimating(), true); - - m_platformInputContext.m_animating = false; - QCOMPARE(qApp->inputPanel()->isAnimating(), false); - - QSignalSpy spy(qApp->inputPanel(), SIGNAL(animatingChanged())); - m_platformInputContext.emitAnimatingChanged(); - QCOMPARE(spy.count(), 1); -} - -void tst_qinputpanel::keyboarRectangle() -{ - QCOMPARE(qApp->inputPanel()->keyboardRectangle(), QRectF()); - - m_platformInputContext.m_keyboardRect = QRectF(10, 20, 30, 40); - QCOMPARE(qApp->inputPanel()->keyboardRectangle(), QRectF(10, 20, 30, 40)); - - QSignalSpy spy(qApp->inputPanel(), SIGNAL(keyboardRectangleChanged())); - m_platformInputContext.emitKeyboardRectChanged(); - QCOMPARE(spy.count(), 1); -} - -void tst_qinputpanel::inputItem() -{ - QVERIFY(!qApp->inputPanel()->inputItem()); - QSignalSpy spy(qApp->inputPanel(), SIGNAL(inputItemChanged())); - - qApp->inputPanel()->setInputItem(&m_inputItem); - - QCOMPARE(qApp->inputPanel()->inputItem(), &m_inputItem); - QCOMPARE(spy.count(), 1); - - // reset - qApp->inputPanel()->setInputItem(0); -} - -void tst_qinputpanel::inputItemTransform() -{ - QCOMPARE(qApp->inputPanel()->inputItemTransform(), QTransform()); - QSignalSpy spy(qApp->inputPanel(), SIGNAL(cursorRectangleChanged())); - - QTransform transform; - transform.translate(10, 10); - transform.scale(2, 2); - transform.shear(2, 2); - qApp->inputPanel()->setInputItemTransform(transform); - - QCOMPARE(qApp->inputPanel()->inputItemTransform(), transform); - QCOMPARE(spy.count(), 1); - - // reset - qApp->inputPanel()->setInputItemTransform(QTransform()); -} - -void tst_qinputpanel::cursorRectangle() -{ - QCOMPARE(qApp->inputPanel()->cursorRectangle(), QRectF()); - - QTransform transform; - transform.translate(10, 10); - transform.scale(2, 2); - transform.shear(2, 2); - qApp->inputPanel()->setInputItemTransform(transform); - qApp->inputPanel()->setInputItem(&m_inputItem); - - QCOMPARE(qApp->inputPanel()->cursorRectangle(), transform.mapRect(QRectF(1, 2, 3, 4))); - - // reset - qApp->inputPanel()->setInputItem(0); - qApp->inputPanel()->setInputItemTransform(QTransform()); -} - -void tst_qinputpanel::invokeAction() -{ - QCOMPARE(m_platformInputContext.m_action, QInputPanel::Click); - QCOMPARE(m_platformInputContext.m_cursorPosition, 0); - - qApp->inputPanel()->invokeAction(QInputPanel::ContextMenu, 5); - QCOMPARE(m_platformInputContext.m_action, QInputPanel::ContextMenu); - QCOMPARE(m_platformInputContext.m_cursorPosition, 5); -} - -void tst_qinputpanel::reset() -{ - QCOMPARE(m_platformInputContext.m_resetCallCount, 0); - - qApp->inputPanel()->reset(); - QCOMPARE(m_platformInputContext.m_resetCallCount, 1); - - qApp->inputPanel()->reset(); - QCOMPARE(m_platformInputContext.m_resetCallCount, 2); -} - -void tst_qinputpanel::commit() -{ - QCOMPARE(m_platformInputContext.m_commitCallCount, 0); - - qApp->inputPanel()->commit(); - QCOMPARE(m_platformInputContext.m_commitCallCount, 1); - - qApp->inputPanel()->commit(); - QCOMPARE(m_platformInputContext.m_commitCallCount, 2); -} - -void tst_qinputpanel::update() -{ - qApp->inputPanel()->setInputItem(&m_inputItem); - QCOMPARE(m_platformInputContext.m_updateCallCount, 0); - QCOMPARE(int(m_platformInputContext.m_lastQueries), int(Qt::ImhNone)); - - qApp->inputPanel()->update(Qt::ImQueryInput); - QCOMPARE(m_platformInputContext.m_updateCallCount, 1); - QCOMPARE(int(m_platformInputContext.m_lastQueries), int(Qt::ImQueryInput)); - - qApp->inputPanel()->update(Qt::ImQueryAll); - QCOMPARE(m_platformInputContext.m_updateCallCount, 2); - QCOMPARE(int(m_platformInputContext.m_lastQueries), int(Qt::ImQueryAll)); - - QCOMPARE(qApp->inputPanel()->keyboardRectangle(), QRectF(10, 20, 30, 40)); - - // reset - qApp->inputPanel()->setInputItem(0); -} - -void tst_qinputpanel::query() -{ - QInputMethodQueryEvent query(Qt::InputMethodQueries(Qt::ImPreferredLanguage | Qt::ImCursorRectangle)); - QGuiApplication::sendEvent(&m_inputItem, &query); - - QString language = query.value(Qt::ImPreferredLanguage).toString(); - QCOMPARE(language, QString("English")); - - QRect cursorRectangle = query.value(Qt::ImCursorRectangle).toRect(); - QCOMPARE(cursorRectangle, QRect(1,2,3,4)); -} - -void tst_qinputpanel::inputDirection() -{ - QCOMPARE(m_platformInputContext.m_inputDirectionCallCount, 0); - qApp->inputPanel()->inputDirection(); - QCOMPARE(m_platformInputContext.m_inputDirectionCallCount, 1); - - QCOMPARE(m_platformInputContext.m_localeCallCount, 0); - qApp->inputPanel()->locale(); - QCOMPARE(m_platformInputContext.m_localeCallCount, 1); -} - -QTEST_MAIN(tst_qinputpanel) -#include "tst_qinputpanel.moc" -- cgit v1.2.3