--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/auto/qfontmetrics/tst_qfontmetrics.cpp Mon Jan 11 14:00:40 2010 +0000
@@ -0,0 +1,242 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 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$
+** 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 Technology Preview License Agreement accompanying
+** this package.
+**
+** 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.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** If you have questions regarding the use of this file, please contact
+** Nokia at qt-info@nokia.com.
+**
+**
+**
+**
+**
+**
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+
+#include <QtTest/QtTest>
+#include <qfont.h>
+#include <qfontmetrics.h>
+#include <qfontdatabase.h>
+#include <qstringlist.h>
+#include <qlist.h>
+
+
+
+//TESTED_CLASS=
+//TESTED_FILES=
+
+class tst_QFontMetrics : public QObject
+{
+Q_OBJECT
+
+public:
+ tst_QFontMetrics();
+ virtual ~tst_QFontMetrics();
+
+public slots:
+ void init();
+ void cleanup();
+private slots:
+ void same();
+ void metrics();
+ void boundingRect();
+ void elidedText_data();
+ void elidedText();
+ void veryNarrowElidedText();
+ void averageCharWidth();
+ void elidedMultiLength();
+ void bearingIncludedInBoundingRect();
+};
+
+tst_QFontMetrics::tst_QFontMetrics()
+
+{
+}
+
+tst_QFontMetrics::~tst_QFontMetrics()
+{
+
+}
+
+void tst_QFontMetrics::init()
+{
+}
+
+void tst_QFontMetrics::cleanup()
+{
+}
+
+void tst_QFontMetrics::same()
+{
+ QFont font;
+ font.setBold(true);
+ QFontMetrics fm(font);
+ const QString text = QLatin1String("Some stupid STRING");
+ QCOMPARE(fm.size(0, text), fm.size(0, text)) ;
+}
+
+
+void tst_QFontMetrics::metrics()
+{
+ QFont font;
+ QFontDatabase fdb;
+
+ // Query the QFontDatabase for a specific font, store the
+ // result in family, style and size.
+ QStringList families = fdb.families();
+ if (families.isEmpty())
+ return;
+
+ QStringList::ConstIterator f_it, f_end = families.end();
+ for (f_it = families.begin(); f_it != f_end; ++f_it) {
+ const QString &family = *f_it;
+
+ QStringList styles = fdb.styles(family);
+ QStringList::ConstIterator s_it, s_end = styles.end();
+ for (s_it = styles.begin(); s_it != s_end; ++s_it) {
+ const QString &style = *s_it;
+
+ if (fdb.isSmoothlyScalable(family, style)) {
+ // smoothly scalable font... don't need to load every pointsize
+ font = fdb.font(family, style, 12);
+
+ QFontMetrics fontmetrics(font);
+ QCOMPARE(fontmetrics.ascent() + fontmetrics.descent() + 1,
+ fontmetrics.height());
+
+ QCOMPARE(fontmetrics.height() + fontmetrics.leading(),
+ fontmetrics.lineSpacing());
+ } else {
+ QList<int> sizes = fdb.pointSizes(family, style);
+ QVERIFY(!sizes.isEmpty());
+ QList<int>::ConstIterator z_it, z_end = sizes.end();
+ for (z_it = sizes.begin(); z_it != z_end; ++z_it) {
+ const int size = *z_it;
+
+ // Initialize the font, and check if it is an exact match
+ font = fdb.font(family, style, size);
+
+ QFontMetrics fontmetrics(font);
+ QCOMPARE(fontmetrics.ascent() + fontmetrics.descent() + 1,
+ fontmetrics.height());
+ QCOMPARE(fontmetrics.height() + fontmetrics.leading(),
+ fontmetrics.lineSpacing());
+ }
+ }
+ }
+ }
+}
+
+void tst_QFontMetrics::boundingRect()
+{
+ QFont f;
+ f.setPointSize(24);
+ QFontMetrics fm(f);
+ QRect r = fm.boundingRect(QChar('Y'));
+ QVERIFY(r.top() < 0);
+ r = fm.boundingRect(QString("Y"));
+ QVERIFY(r.top() < 0);
+}
+
+void tst_QFontMetrics::elidedText_data()
+{
+ QTest::addColumn<QFont>("font");
+ QTest::addColumn<QString>("text");
+
+ QTest::newRow("helvetica hello") << QFont("helvetica",10) << QString("hello") ;
+ QTest::newRow("helvetica hello &Bye") << QFont("helvetica",10) << QString("hello&Bye") ;
+}
+
+
+void tst_QFontMetrics::elidedText()
+{
+ QFETCH(QFont, font);
+ QFETCH(QString, text);
+ QFontMetrics fm(font);
+ int w = fm.width(text);
+ QString newtext = fm.elidedText(text,Qt::ElideRight,w+1, 0);
+ QCOMPARE(text,newtext); // should not elide
+ newtext = fm.elidedText(text,Qt::ElideRight,w-1, 0);
+ QVERIFY(text != newtext); // should elide
+}
+
+void tst_QFontMetrics::veryNarrowElidedText()
+{
+ QFont f;
+ QFontMetrics fm(f);
+ QString text("hello");
+ QCOMPARE(fm.elidedText(text, Qt::ElideRight, 0), QString());
+}
+
+void tst_QFontMetrics::averageCharWidth()
+{
+ QFont f;
+ QFontMetrics fm(f);
+ QVERIFY(fm.averageCharWidth() != 0);
+ QFontMetricsF fmf(f);
+ QVERIFY(fmf.averageCharWidth() != 0);
+}
+
+void tst_QFontMetrics::elidedMultiLength()
+{
+ QString text1 = "Long Text 1\x9cShorter\x9csmall";
+ QString text1_long = "Long Text 1";
+ QString text1_short = "Shorter";
+ QString text1_small = "small";
+ QFontMetrics fm = QFontMetrics(QFont());
+ int width_long = fm.size(0, text1_long).width();
+ QCOMPARE(fm.elidedText(text1,Qt::ElideRight, 8000), text1_long);
+ QCOMPARE(fm.elidedText(text1,Qt::ElideRight, width_long + 1), text1_long);
+ QCOMPARE(fm.elidedText(text1,Qt::ElideRight, width_long - 1), text1_short);
+ int width_short = fm.size(0, text1_short).width();
+ QCOMPARE(fm.elidedText(text1,Qt::ElideRight, width_short + 1), text1_short);
+ QCOMPARE(fm.elidedText(text1,Qt::ElideRight, width_short - 1), text1_small);
+
+ // Not even wide enough for "small" - should use ellipsis
+ QChar ellipsisChar(0x2026);
+ QString text1_el = QString::fromLatin1("s") + ellipsisChar;
+ int width_small = fm.width(text1_el);
+ QCOMPARE(fm.elidedText(text1,Qt::ElideRight, width_small + 1), text1_el);
+
+}
+
+void tst_QFontMetrics::bearingIncludedInBoundingRect()
+{
+ QFont font;
+ font.setItalic(true);
+ QRect brectItalic = QFontMetrics(font).boundingRect("ITALIC");
+ font.setItalic(false);
+ QRect brectNormal = QFontMetrics(font).boundingRect("ITALIC");
+
+ QVERIFY(brectItalic.width() > brectNormal.width());
+}
+
+QTEST_MAIN(tst_QFontMetrics)
+#include "tst_qfontmetrics.moc"