diff options
author | axis <qt-info@nokia.com> | 2009-04-24 11:34:15 (GMT) |
---|---|---|
committer | axis <qt-info@nokia.com> | 2009-04-24 11:34:15 (GMT) |
commit | 8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76 (patch) | |
tree | a17e1a767a89542ab59907462206d7dcf2e504b2 /tests/auto/qfontdialog | |
download | Qt-8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76.zip Qt-8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76.tar.gz Qt-8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76.tar.bz2 |
Long live Qt for S60!
Diffstat (limited to 'tests/auto/qfontdialog')
-rw-r--r-- | tests/auto/qfontdialog/.gitignore | 1 | ||||
-rw-r--r-- | tests/auto/qfontdialog/qfontdialog.pro | 7 | ||||
-rw-r--r-- | tests/auto/qfontdialog/tst_qfontdialog.cpp | 156 | ||||
-rw-r--r-- | tests/auto/qfontdialog/tst_qfontdialog_mac_helpers.mm | 26 |
4 files changed, 190 insertions, 0 deletions
diff --git a/tests/auto/qfontdialog/.gitignore b/tests/auto/qfontdialog/.gitignore new file mode 100644 index 0000000..5bd48d4 --- /dev/null +++ b/tests/auto/qfontdialog/.gitignore @@ -0,0 +1 @@ +tst_qfontdialog diff --git a/tests/auto/qfontdialog/qfontdialog.pro b/tests/auto/qfontdialog/qfontdialog.pro new file mode 100644 index 0000000..8a4485d --- /dev/null +++ b/tests/auto/qfontdialog/qfontdialog.pro @@ -0,0 +1,7 @@ +load(qttest_p4) +SOURCES += tst_qfontdialog.cpp + +mac { + OBJECTIVE_SOURCES += tst_qfontdialog_mac_helpers.mm + LIBS += -framework Cocoa +} diff --git a/tests/auto/qfontdialog/tst_qfontdialog.cpp b/tests/auto/qfontdialog/tst_qfontdialog.cpp new file mode 100644 index 0000000..c0a1cc5 --- /dev/null +++ b/tests/auto/qfontdialog/tst_qfontdialog.cpp @@ -0,0 +1,156 @@ +/**************************************************************************** +** +** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). +** Contact: Qt Software Information (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** No Commercial Usage +** This file contains pre-release code and may not be distributed. +** You may use this file in accordance with the terms and conditions +** contained in the either Technology Preview License Agreement or the +** Beta Release License Agreement. +** +** GNU Lesser General Public License Usage +** Alternatively, 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.0, 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. +** +** If you are unsure which license is appropriate for your use, please +** contact the sales department at qt-sales@nokia.com. +** $QT_END_LICENSE$ +** +****************************************************************************/ + + +#include <QtTest/QtTest> + + +#include <qapplication.h> +#include <qfontinfo.h> +#include <qtimer.h> +#include <qmainwindow.h> +#include "qfontdialog.h" + +//TESTED_CLASS= +//TESTED_FILES= + +QT_FORWARD_DECLARE_CLASS(QtTestEventThread) + +class tst_QFontDialog : public QObject +{ + Q_OBJECT + +public: + tst_QFontDialog(); + virtual ~tst_QFontDialog(); + + +public slots: + void postKeyReturn(); + +public slots: + void initTestCase(); + void cleanupTestCase(); + void init(); + void cleanup(); +private slots: + void defaultOkButton(); + void setFont(); +}; + +tst_QFontDialog::tst_QFontDialog() +{ +} + +tst_QFontDialog::~tst_QFontDialog() +{ +} + +void tst_QFontDialog::initTestCase() +{ +} + +void tst_QFontDialog::cleanupTestCase() +{ +} + +void tst_QFontDialog::init() +{ +} + +void tst_QFontDialog::cleanup() +{ +} + + +void tst_QFontDialog::postKeyReturn() { +#ifndef Q_WS_MAC + QWidgetList list = QApplication::topLevelWidgets(); + for (int i=0; i<list.count(); ++i) { + QFontDialog *dialog = qobject_cast<QFontDialog*>(list[i]); + if (dialog) { + QTest::keyClick( list[i], Qt::Key_Return, Qt::NoModifier ); + return; + } + } +#else + extern void click_cocoa_button(); + click_cocoa_button(); +#endif +} + +void tst_QFontDialog::defaultOkButton() +{ + bool ok = FALSE; + QTimer::singleShot(2000, this, SLOT(postKeyReturn())); + QFontDialog::getFont(&ok); + QVERIFY(ok == TRUE); +} + + +void tst_QFontDialog::setFont() +{ + /* The font should be the same before as it is after if nothing changed + while the font dialog was open. + Task #27662 + */ + bool ok = FALSE; +#if defined Q_OS_HPUX + QString fontName = "Courier"; + int fontSize = 25; +#elif defined Q_OS_AIX + QString fontName = "Charter"; + int fontSize = 13; +#else + QString fontName = "Arial"; + int fontSize = 24; +#endif + QFont f1(fontName, fontSize); + f1.setPixelSize(QFontInfo(f1).pixelSize()); + QTimer::singleShot(2000, this, SLOT(postKeyReturn())); + QFont f2 = QFontDialog::getFont(&ok, f1); + QCOMPARE(QFontInfo(f2).pointSize(), QFontInfo(f1).pointSize()); +} + + + +QTEST_MAIN(tst_QFontDialog) +#include "tst_qfontdialog.moc" diff --git a/tests/auto/qfontdialog/tst_qfontdialog_mac_helpers.mm b/tests/auto/qfontdialog/tst_qfontdialog_mac_helpers.mm new file mode 100644 index 0000000..fbd6817 --- /dev/null +++ b/tests/auto/qfontdialog/tst_qfontdialog_mac_helpers.mm @@ -0,0 +1,26 @@ +#include <private/qt_mac_p.h> +#include <AppKit/AppKit.h> + +void click_cocoa_button() +{ + QMacCocoaAutoReleasePool pool; + NSArray *windows = [NSApp windows]; + for (NSWindow *window in windows) { + // This is NOT how one should do RTTI, but since I don't want to leak the class too much... + if ([[window delegate] respondsToSelector:@selector(qtFont)]) { + NSArray *subviews = [[window contentView] subviews]; + for (NSView *view in subviews) { + if ([view isKindOfClass:[NSButton class]] + && [[static_cast<NSButton *>(view) title] isEqualTo:@"OK"]) { + [static_cast<NSButton *>(view) performClick:view]; + [NSApp postEvent:[NSEvent otherEventWithType:NSApplicationDefined location:NSZeroPoint + modifierFlags:0 timestamp:0. windowNumber:0 context:0 + subtype:SHRT_MAX data1:0 data2:0] atStart:NO]; + + break; + } + } + break; + } + } +} |