summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorJohn Layt <jlayt@kde.org>2013-02-07 18:08:39 +0000
committerThe Qt Project <gerrit-noreply@qt-project.org>2013-09-23 01:13:58 +0200
commit8af776d4140c19baccb8e2767ed8b57cc79ccb06 (patch)
tree1bebf823c2f8cd915ace4ee841d1b665481b6b59 /tests
parent7ed7d66b5a420f70d056a95a63c9be5de1af3191 (diff)
QTimeZone - Add Windows backend
Add backend implementation for Windows times zones. Change-Id: I30946f6672488c3f1d1d05754e9479aa62cce46f Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp109
1 files changed, 84 insertions, 25 deletions
diff --git a/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp b/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp
index bd1f57a105..ed08bcefbf 100644
--- a/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp
+++ b/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp
@@ -63,6 +63,7 @@ private slots:
void icuTest();
void tzTest();
void macTest();
+ void winTest();
private:
void printTimeZone(const QTimeZone tz);
@@ -710,36 +711,94 @@ void tst_QTimeZone::macTest()
QMacTimeZonePrivate tzp("Europe/Berlin");
QVERIFY(tzp.isValid());
- // Test display names by type
- QLocale enUS("en_US");
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::LongName, enUS),
- QString("Central European Standard Time"));
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::ShortName, enUS),
- QString("GMT+01:00"));
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::OffsetName, enUS),
- QString("UTC+01:00"));
- QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::LongName, enUS),
- QString("Central European Summer Time"));
- QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::ShortName, enUS),
- QString("GMT+02:00"));
- QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::OffsetName, enUS),
- QString("UTC+02:00"));
- // ICU C api does not support Generic Time yet, C++ api does
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::LongName, enUS),
- QString("Central European Time"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, enUS),
- QString("Germany Time"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName, enUS),
- QString("UTC+01:00"));
-
- // Test Abbreviations
- QCOMPARE(tzp.abbreviation(std), QString("CET"));
- QCOMPARE(tzp.abbreviation(dst), QString("CEST"));
+ // Only test names in debug mode, names used can vary by version
+ if (debug) {
+ // Test display names by type
+ QLocale enUS("en_US");
+ QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::LongName, enUS),
+ QString("Central European Standard Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::ShortName, enUS),
+ QString("GMT+01:00"));
+ QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::OffsetName, enUS),
+ QString("UTC+01:00"));
+ QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::LongName, enUS),
+ QString("Central European Summer Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::ShortName, enUS),
+ QString("GMT+02:00"));
+ QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::OffsetName, enUS),
+ QString("UTC+02:00"));
+ // ICU C api does not support Generic Time yet, C++ api does
+ QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::LongName, enUS),
+ QString("Central European Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, enUS),
+ QString("Germany Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName, enUS),
+ QString("UTC+01:00"));
+
+ // Test Abbreviations
+ QCOMPARE(tzp.abbreviation(std), QString("CET"));
+ QCOMPARE(tzp.abbreviation(dst), QString("CEST"));
+ }
testCetPrivate(tzp);
#endif // Q_OS_MAC
}
+void tst_QTimeZone::winTest()
+{
+#if defined(QT_BUILD_INTERNAL) && defined(Q_OS_WIN)
+ // Known datetimes
+ qint64 std = QDateTime(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::UTC).toMSecsSinceEpoch();
+ qint64 dst = QDateTime(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC).toMSecsSinceEpoch();
+
+ // Test default constructor
+ QWinTimeZonePrivate tzpd;
+ if (debug)
+ qDebug() << "System ID = " << tzpd.id()
+ << tzpd.displayName(QTimeZone::StandardTime, QTimeZone::LongName, QLocale())
+ << tzpd.displayName(QTimeZone::GenericTime, QTimeZone::LongName, QLocale());
+ QVERIFY(tzpd.isValid());
+
+ // Test invalid constructor
+ QWinTimeZonePrivate tzpi("Gondwana/Erewhon");
+ QCOMPARE(tzpi.isValid(), false);
+
+ // Test named constructor
+ QWinTimeZonePrivate tzp("Europe/Berlin");
+ QVERIFY(tzp.isValid());
+
+ // Only test names in debug mode, names used can vary by version
+ if (debug) {
+ // Test display names by type
+ QLocale enUS("en_US");
+ QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::LongName, enUS),
+ QString("W. Europe Standard Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::ShortName, enUS),
+ QString("W. Europe Standard Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::OffsetName, enUS),
+ QString("UTC+01:00"));
+ QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::LongName, enUS),
+ QString("W. Europe Daylight Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::ShortName, enUS),
+ QString("W. Europe Daylight Time"));
+ QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::OffsetName, enUS),
+ QString("UTC+02:00"));
+ QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::LongName, enUS),
+ QString("(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna"));
+ QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, enUS),
+ QString("(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna"));
+ QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName, enUS),
+ QString("UTC+01:00"));
+
+ // Test Abbreviations
+ QCOMPARE(tzp.abbreviation(std), QString("W. Europe Standard Time"));
+ QCOMPARE(tzp.abbreviation(dst), QString("W. Europe Daylight Time"));
+ }
+
+ testCetPrivate(tzp);
+#endif // Q_OS_WIN
+}
+
#ifdef QT_BUILD_INTERNAL
// Test each private produces the same basic results for CET
void tst_QTimeZone::testCetPrivate(const QTimeZonePrivate &tzp)