summaryrefslogtreecommitdiffstats
path: root/tests/auto/corelib/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auto/corelib/tools')
-rw-r--r--tests/auto/corelib/tools/collections/tst_collections.cpp95
-rw-r--r--tests/auto/corelib/tools/containerapisymmetry/tst_containerapisymmetry.cpp723
-rw-r--r--tests/auto/corelib/tools/qalgorithms/tst_qalgorithms.cpp22
-rw-r--r--tests/auto/corelib/tools/qarraydata/tst_qarraydata.cpp46
-rw-r--r--tests/auto/corelib/tools/qbytearray/tst_qbytearray.cpp35
-rw-r--r--tests/auto/corelib/tools/qbytearraylist/tst_qbytearraylist.cpp14
-rw-r--r--tests/auto/corelib/tools/qcollator/tst_qcollator.cpp6
-rw-r--r--tests/auto/corelib/tools/qcommandlineparser/tst_qcommandlineparser.cpp79
-rw-r--r--tests/auto/corelib/tools/qcontiguouscache/tst_qcontiguouscache.cpp4
-rw-r--r--tests/auto/corelib/tools/qdate/.gitignore1
-rw-r--r--tests/auto/corelib/tools/qdate/qdate.pro4
-rw-r--r--tests/auto/corelib/tools/qdate/tst_qdate.cpp1505
-rw-r--r--tests/auto/corelib/tools/qdatetime/.gitignore1
-rw-r--r--tests/auto/corelib/tools/qdatetime/BLACKLIST2
-rw-r--r--tests/auto/corelib/tools/qdatetime/qdatetime.pro17
-rw-r--r--tests/auto/corelib/tools/qdatetime/tst_qdatetime.cpp3490
-rw-r--r--tests/auto/corelib/tools/qdatetime/tst_qdatetime_mac.mm70
-rw-r--r--tests/auto/corelib/tools/qeasingcurve/tst_qeasingcurve.cpp39
-rw-r--r--tests/auto/corelib/tools/qhash/tst_qhash.cpp4
-rw-r--r--tests/auto/corelib/tools/qhashfunctions/tst_qhashfunctions.cpp36
-rw-r--r--tests/auto/corelib/tools/qlatin1string/tst_qlatin1string.cpp42
-rw-r--r--tests/auto/corelib/tools/qline/tst_qline.cpp2
-rw-r--r--tests/auto/corelib/tools/qlinkedlist/tst_qlinkedlist.cpp2
-rw-r--r--tests/auto/corelib/tools/qlist/tst_qlist.cpp12
-rw-r--r--tests/auto/corelib/tools/qlocale/tst_qlocale.cpp3
-rw-r--r--tests/auto/corelib/tools/qmap/tst_qmap.cpp4
-rw-r--r--tests/auto/corelib/tools/qpair/qpair.pro3
-rw-r--r--tests/auto/corelib/tools/qpair/tst_qpair.cpp26
-rw-r--r--tests/auto/corelib/tools/qscopedpointer/tst_qscopedpointer.cpp42
-rw-r--r--tests/auto/corelib/tools/qscopedvaluerollback/tst_qscopedvaluerollback.cpp13
-rw-r--r--tests/auto/corelib/tools/qset/tst_qset.cpp12
-rw-r--r--tests/auto/corelib/tools/qsharedpointer/tst_qsharedpointer.cpp157
-rw-r--r--tests/auto/corelib/tools/qstring/tst_qstring.cpp152
-rw-r--r--tests/auto/corelib/tools/qstringapisymmetry/tst_qstringapisymmetry.cpp564
-rw-r--r--tests/auto/corelib/tools/qstringlist/tst_qstringlist.cpp42
-rw-r--r--tests/auto/corelib/tools/qstringmatcher/tst_qstringmatcher.cpp6
-rw-r--r--tests/auto/corelib/tools/qstringview/tst_qstringview.cpp43
-rw-r--r--tests/auto/corelib/tools/qtime/.gitignore1
-rw-r--r--tests/auto/corelib/tools/qtime/qtime.pro4
-rw-r--r--tests/auto/corelib/tools/qtime/tst_qtime.cpp802
-rw-r--r--tests/auto/corelib/tools/qtimezone/BLACKLIST171
-rw-r--r--tests/auto/corelib/tools/qtimezone/qtimezone.pro12
-rw-r--r--tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp1333
-rw-r--r--tests/auto/corelib/tools/qtimezone/tst_qtimezone_darwin.mm68
-rw-r--r--tests/auto/corelib/tools/qvarlengtharray/tst_qvarlengtharray.cpp4
-rw-r--r--tests/auto/corelib/tools/qvector/tst_qvector.cpp73
-rw-r--r--tests/auto/corelib/tools/qversionnumber/tst_qversionnumber.cpp19
-rw-r--r--tests/auto/corelib/tools/tools.pro5
48 files changed, 1986 insertions, 7824 deletions
diff --git a/tests/auto/corelib/tools/collections/tst_collections.cpp b/tests/auto/corelib/tools/collections/tst_collections.cpp
index b40b1f0624..b911be3ffb 100644
--- a/tests/auto/corelib/tools/collections/tst_collections.cpp
+++ b/tests/auto/corelib/tools/collections/tst_collections.cpp
@@ -76,7 +76,7 @@ void foo()
#include "qlist.h"
#include "qmap.h"
#include "qpair.h"
-#include "qregexp.h"
+#include "qregularexpression.h"
#include "qset.h"
#include "qstack.h"
#include "qstring.h"
@@ -105,7 +105,9 @@ private slots:
void map();
void bitArray();
void cache();
+#if QT_CONFIG(regularexpression)
void regexp();
+#endif
void pair();
void sharableQList();
void sharableQLinkedList();
@@ -580,73 +582,73 @@ void tst_Collections::list()
list1 << 0 << 1 << 2 << 3;
list1.removeFirst();
- list1.swap(0, 0);
+ list1.swapItemsAt(0, 0);
QVERIFY(list1 == QList<int>() << 1 << 2 << 3);
- list1.swap(1, 1);
+ list1.swapItemsAt(1, 1);
QVERIFY(list1 == QList<int>() << 1 << 2 << 3);
- list1.swap(2, 2);
+ list1.swapItemsAt(2, 2);
QVERIFY(list1 == QList<int>() << 1 << 2 << 3);
- list1.swap(0, 1);
+ list1.swapItemsAt(0, 1);
QVERIFY(list1 == QList<int>() << 2 << 1 << 3);
- list1.swap(0, 2);
+ list1.swapItemsAt(0, 2);
QVERIFY(list1 == QList<int>() << 3 << 1 << 2);
- list1.swap(1, 2);
+ list1.swapItemsAt(1, 2);
QVERIFY(list1 == QList<int>() << 3 << 2 << 1);
- list1.swap(1, 2);
+ list1.swapItemsAt(1, 2);
QVERIFY(list1 == QList<int>() << 3 << 1 << 2);
QList<QString> list2;
list2 << "1" << "2" << "3";
- list2.swap(0, 0);
+ list2.swapItemsAt(0, 0);
QVERIFY(list2 == QList<QString>() << "1" << "2" << "3");
- list2.swap(1, 1);
+ list2.swapItemsAt(1, 1);
QVERIFY(list2 == QList<QString>() << "1" << "2" << "3");
- list2.swap(2, 2);
+ list2.swapItemsAt(2, 2);
QVERIFY(list2 == QList<QString>() << "1" << "2" << "3");
- list2.swap(0, 1);
+ list2.swapItemsAt(0, 1);
QVERIFY(list2 == QList<QString>() << "2" << "1" << "3");
- list2.swap(0, 2);
+ list2.swapItemsAt(0, 2);
QVERIFY(list2 == QList<QString>() << "3" << "1" << "2");
- list2.swap(1, 2);
+ list2.swapItemsAt(1, 2);
QVERIFY(list2 == QList<QString>() << "3" << "2" << "1");
- list2.swap(1, 2);
+ list2.swapItemsAt(1, 2);
QVERIFY(list2 == QList<QString>() << "3" << "1" << "2");
QList<double> list3;
list3 << 1.0 << 2.0 << 3.0;
- list3.swap(0, 0);
+ list3.swapItemsAt(0, 0);
QVERIFY(list3 == QList<double>() << 1.0 << 2.0 << 3.0);
- list3.swap(1, 1);
+ list3.swapItemsAt(1, 1);
QVERIFY(list3 == QList<double>() << 1.0 << 2.0 << 3.0);
- list3.swap(2, 2);
+ list3.swapItemsAt(2, 2);
QVERIFY(list3 == QList<double>() << 1.0 << 2.0 << 3.0);
- list3.swap(0, 1);
+ list3.swapItemsAt(0, 1);
QVERIFY(list3 == QList<double>() << 2.0 << 1.0 << 3.0);
- list3.swap(0, 2);
+ list3.swapItemsAt(0, 2);
QVERIFY(list3 == QList<double>() << 3.0 << 1.0 << 2.0);
- list3.swap(1, 2);
+ list3.swapItemsAt(1, 2);
QVERIFY(list3 == QList<double>() << 3.0 << 2.0 << 1.0);
- list3.swap(1, 2);
+ list3.swapItemsAt(1, 2);
QVERIFY(list3 == QList<double>() << 3.0 << 1.0 << 2.0);
}
@@ -2285,13 +2287,15 @@ void tst_Collections::cache()
}
+#if QT_CONFIG(regularexpression)
void tst_Collections::regexp()
{
- QRegExp rx("^\\d\\d?$");
- QVERIFY(rx.indexIn("123") == -1);
- QVERIFY(rx.indexIn("-6") == -1);
- QVERIFY(rx.indexIn("6") == 0) ;
+ QRegularExpression rx("^\\d\\d?$");
+ QVERIFY(!rx.match("123").hasMatch());
+ QVERIFY(!rx.match("-6").hasMatch());
+ QVERIFY(rx.match("6").hasMatch()) ;
}
+#endif
void tst_Collections::pair()
{
@@ -2425,7 +2429,7 @@ void testContainer()
c1 = newInstance<Container>();
QVERIFY(c1.size() == 4);
QVERIFY(c1 == newInstance<Container>());
- Container c2 = qMove(c1);
+ Container c2 = std::move(c1);
QVERIFY(c2.size() == 4);
QVERIFY(c2 == newInstance<Container>());
}
@@ -2531,14 +2535,18 @@ void tst_Collections::conversions()
QCOMPARE(list2.size(), 4);
QVERIFY(list2 == (QList<QString>() << STUFF));
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
QSet<QString> set1 = list1.toSet();
+#else
+ QSet<QString> set1(list1.begin(), list1.end());
+#endif
QCOMPARE(set1.size(), 3);
QVERIFY(set1.contains("A"));
QVERIFY(set1.contains("B"));
QVERIFY(set1.contains("C"));
QVERIFY(!set1.contains("D"));
- QList<QString> list3 = set1.toList();
+ QList<QString> list3 = set1.values();
QCOMPARE(list3.size(), 3);
QVERIFY(list3.contains("A"));
QVERIFY(list3.contains("B"));
@@ -2546,9 +2554,11 @@ void tst_Collections::conversions()
QVERIFY(!list3.contains("D"));
QVERIFY(QList<int>().toVector().isEmpty());
- QVERIFY(QList<int>().toSet().isEmpty());
QVERIFY(QVector<int>().toList().isEmpty());
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
+ QVERIFY(QList<int>().toSet().isEmpty());
QVERIFY(QSet<int>().toList().isEmpty());
+#endif
}
{
@@ -2563,14 +2573,22 @@ void tst_Collections::conversions()
QCOMPARE(list2.size(), 4);
QVERIFY(list2 == (QList<QString>() << STUFF));
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
QSet<QString> set1 = QSet<QString>::fromList(list1);
+#else
+ QSet<QString> set1(list1.begin(), list1.end());
+#endif
QCOMPARE(set1.size(), 3);
QVERIFY(set1.contains("A"));
QVERIFY(set1.contains("B"));
QVERIFY(set1.contains("C"));
QVERIFY(!set1.contains("D"));
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
QList<QString> list3 = QList<QString>::fromSet(set1);
+#else
+ QList<QString> list3 = set1.values();
+#endif
QCOMPARE(list3.size(), 3);
QVERIFY(list3.contains("A"));
QVERIFY(list3.contains("B"));
@@ -2578,9 +2596,11 @@ void tst_Collections::conversions()
QVERIFY(!list3.contains("D"));
QVERIFY(QVector<int>::fromList(QList<int>()).isEmpty());
- QVERIFY(QSet<int>::fromList(QList<int>()).isEmpty());
QVERIFY(QList<int>::fromVector(QVector<int>()).isEmpty());
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
+ QVERIFY(QSet<int>::fromList(QList<int>()).isEmpty());
QVERIFY(QList<int>::fromSet(QSet<int>()).isEmpty());
+#endif
}
#undef STUFF
}
@@ -2776,15 +2796,21 @@ void tst_Collections::vector_stl()
for (int i = 0; i < elements.count(); ++i)
vector << elements.at(i);
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
std::vector<QString> stdVector = vector.toStdVector();
-
+#else
+ std::vector<QString> stdVector(vector.begin(), vector.end());
+#endif
QCOMPARE(int(stdVector.size()), elements.size());
std::vector<QString>::const_iterator it = stdVector.begin();
for (uint j = 0; j < stdVector.size() && it != stdVector.end(); ++j, ++it)
QCOMPARE(*it, vector[j]);
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
QCOMPARE(QVector<QString>::fromStdVector(stdVector), vector);
+#endif
+ QCOMPARE(QVector<QString>(stdVector.begin(), stdVector.end()), vector);
}
void tst_Collections::linkedlist_stl_data()
@@ -2830,7 +2856,11 @@ void tst_Collections::list_stl()
for (int i = 0; i < elements.count(); ++i)
list << elements.at(i);
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
std::list<QString> stdList = list.toStdList();
+#else
+ std::list<QString> stdList(list.begin(), list.end());
+#endif
QCOMPARE(int(stdList.size()), elements.size());
@@ -2838,7 +2868,10 @@ void tst_Collections::list_stl()
for (uint j = 0; j < stdList.size() && it != stdList.end(); ++j, ++it)
QCOMPARE(*it, list[j]);
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
QCOMPARE(QList<QString>::fromStdList(stdList), list);
+#endif
+ QCOMPARE(QList<QString>(stdList.begin(), stdList.end()), list);
}
template <typename T>
diff --git a/tests/auto/corelib/tools/containerapisymmetry/tst_containerapisymmetry.cpp b/tests/auto/corelib/tools/containerapisymmetry/tst_containerapisymmetry.cpp
index 3b8111f1a3..4b085d387d 100644
--- a/tests/auto/corelib/tools/containerapisymmetry/tst_containerapisymmetry.cpp
+++ b/tests/auto/corelib/tools/containerapisymmetry/tst_containerapisymmetry.cpp
@@ -34,13 +34,446 @@
#include "qstring.h"
#include "qvarlengtharray.h"
#include "qvector.h"
+#include "qhash.h"
+#include "qdebug.h"
+#include <algorithm>
+#include <functional>
#include <vector> // for reference
+#include <list>
+#include <set>
+#include <map>
+
+// MSVC has these containers from the Standard Library, but it lacks
+// a __has_include mechanism (that we need to use for other stdlibs).
+// For the sake of increasing our test coverage, work around the issue.
+
+#ifdef Q_CC_MSVC
+#define COMPILER_HAS_STDLIB_INCLUDE(x) 1
+#else
+#define COMPILER_HAS_STDLIB_INCLUDE(x) QT_HAS_INCLUDE(x)
+#endif
+
+#if COMPILER_HAS_STDLIB_INCLUDE(<forward_list>)
+#include <forward_list>
+#endif
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+#include <unordered_set>
+#endif
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+#include <unordered_map>
+#endif
+
+struct Movable
+{
+ explicit Movable(int i = 0) Q_DECL_NOTHROW
+ : i(i)
+ {
+ ++instanceCount;
+ }
+
+ Movable(const Movable &m)
+ : i(m.i)
+ {
+ ++instanceCount;
+ }
+
+ ~Movable()
+ {
+ --instanceCount;
+ }
+
+ int i;
+ static int instanceCount;
+};
+
+int Movable::instanceCount = 0;
+bool operator==(Movable lhs, Movable rhs) Q_DECL_NOTHROW { return lhs.i == rhs.i; }
+bool operator!=(Movable lhs, Movable rhs) Q_DECL_NOTHROW { return lhs.i != rhs.i; }
+bool operator<(Movable lhs, Movable rhs) Q_DECL_NOTHROW { return lhs.i < rhs.i; }
+
+uint qHash(Movable m, uint seed = 0) Q_DECL_NOTHROW { return qHash(m.i, seed); }
+QDebug &operator<<(QDebug &d, Movable m)
+{
+ const QDebugStateSaver saver(d);
+ return d.nospace() << "Movable(" << m.i << ")";
+}
+
+QT_BEGIN_NAMESPACE
+Q_DECLARE_TYPEINFO(Movable, Q_MOVABLE_TYPE);
+QT_END_NAMESPACE
+
+struct Complex
+{
+ explicit Complex(int i = 0) Q_DECL_NOTHROW
+ : i(i)
+ {
+ ++instanceCount;
+ }
+
+ Complex(const Complex &c)
+ : i(c.i)
+ {
+ ++instanceCount;
+ }
+
+ ~Complex()
+ {
+ --instanceCount;
+ }
+
+ int i;
+ static int instanceCount;
+};
+
+int Complex::instanceCount = 0;
+bool operator==(Complex lhs, Complex rhs) Q_DECL_NOTHROW { return lhs.i == rhs.i; }
+bool operator!=(Complex lhs, Complex rhs) Q_DECL_NOTHROW { return lhs.i != rhs.i; }
+bool operator<(Complex lhs, Complex rhs) Q_DECL_NOTHROW { return lhs.i < rhs.i; }
+
+uint qHash(Complex c, uint seed = 0) Q_DECL_NOTHROW { return qHash(c.i, seed); }
+QDebug &operator<<(QDebug &d, Complex c)
+{
+ const QDebugStateSaver saver(d);
+ return d.nospace() << "Complex(" << c.i << ")";
+}
+
+
+struct DuplicateStrategyTestType
+{
+ explicit DuplicateStrategyTestType(int i = 0) Q_DECL_NOTHROW
+ : i(i),
+ j(++counter)
+ {
+ }
+
+ int i;
+ int j;
+
+ static int counter;
+};
+
+int DuplicateStrategyTestType::counter = 0;
+
+// only look at the i member, not j. j allows us to identify which instance
+// gets inserted in containers that don't allow for duplicates
+bool operator==(DuplicateStrategyTestType lhs, DuplicateStrategyTestType rhs) Q_DECL_NOTHROW
+{
+ return lhs.i == rhs.i;
+}
+
+bool operator!=(DuplicateStrategyTestType lhs, DuplicateStrategyTestType rhs) Q_DECL_NOTHROW
+{
+ return lhs.i != rhs.i;
+}
+
+bool operator<(DuplicateStrategyTestType lhs, DuplicateStrategyTestType rhs) Q_DECL_NOTHROW
+{
+ return lhs.i < rhs.i;
+}
+
+uint qHash(DuplicateStrategyTestType c, uint seed = 0) Q_DECL_NOTHROW
+{
+ return qHash(c.i, seed);
+}
+
+bool reallyEqual(DuplicateStrategyTestType lhs, DuplicateStrategyTestType rhs) Q_DECL_NOTHROW
+{
+ return lhs.i == rhs.i && lhs.j == rhs.j;
+}
+
+QDebug &operator<<(QDebug &d, DuplicateStrategyTestType c)
+{
+ const QDebugStateSaver saver(d);
+ return d.nospace() << "DuplicateStrategyTestType(" << c.i << "," << c.j << ")";
+}
+
+
+namespace std {
+template<>
+struct hash<Movable>
+{
+ std::size_t operator()(Movable m) const Q_DECL_NOTHROW
+ {
+ return hash<int>()(m.i);
+ }
+};
+
+template<>
+struct hash<Complex>
+{
+ std::size_t operator()(Complex m) const Q_DECL_NOTHROW
+ {
+ return hash<int>()(m.i);
+ }
+};
+
+template<>
+struct hash<DuplicateStrategyTestType>
+{
+ std::size_t operator()(DuplicateStrategyTestType m) const Q_DECL_NOTHROW
+ {
+ return hash<int>()(m.i);
+ }
+};
+}
+
+// work around the fact that QVarLengthArray has a non-type
+// template parameter, and that breaks non_associative_container_duplicates_strategy
+template<typename T>
+class VarLengthArray : public QVarLengthArray<T>
+{
+public:
+#ifdef Q_COMPILER_INHERITING_CONSTRUCTORS
+ using QVarLengthArray<T>::QVarLengthArray;
+#else
+ template<typename InputIterator>
+ VarLengthArray(InputIterator first, InputIterator last)
+ : QVarLengthArray<T>(first, last)
+ {
+ }
+
+ VarLengthArray(std::initializer_list<T> args)
+ : QVarLengthArray<T>(args)
+ {
+ }
+#endif
+};
class tst_ContainerApiSymmetry : public QObject
{
Q_OBJECT
+ int m_movableInstanceCount;
+ int m_complexInstanceCount;
+
+private Q_SLOTS:
+ void init();
+ void cleanup();
+
+private:
+ template <typename Container>
+ void ranged_ctor_non_associative_impl() const;
+
+ template<template<typename ... T> class Container>
+ void non_associative_container_duplicates_strategy() const;
+
+ template <typename Container>
+ void ranged_ctor_associative_impl() const;
+
+private Q_SLOTS:
+ // non associative
+ void ranged_ctor_std_vector_int() { ranged_ctor_non_associative_impl<std::vector<int>>(); }
+ void ranged_ctor_std_vector_char() { ranged_ctor_non_associative_impl<std::vector<char>>(); }
+ void ranged_ctor_std_vector_QChar() { ranged_ctor_non_associative_impl<std::vector<QChar>>(); }
+ void ranged_ctor_std_vector_Movable() { ranged_ctor_non_associative_impl<std::vector<Movable>>(); }
+ void ranged_ctor_std_vector_Complex() { ranged_ctor_non_associative_impl<std::vector<Complex>>(); }
+ void ranged_ctor_std_vector_duplicates_strategy() { non_associative_container_duplicates_strategy<std::vector>(); }
+
+ void ranged_ctor_QVector_int() { ranged_ctor_non_associative_impl<QVector<int>>(); }
+ void ranged_ctor_QVector_char() { ranged_ctor_non_associative_impl<QVector<char>>(); }
+ void ranged_ctor_QVector_QChar() { ranged_ctor_non_associative_impl<QVector<QChar>>(); }
+ void ranged_ctor_QVector_Movable() { ranged_ctor_non_associative_impl<QVector<Movable>>(); }
+ void ranged_ctor_QVector_Complex() { ranged_ctor_non_associative_impl<QVector<Complex>>(); }
+ void ranged_ctor_QVector_duplicates_strategy() { non_associative_container_duplicates_strategy<QVector>(); }
+
+ void ranged_ctor_QVarLengthArray_int() { ranged_ctor_non_associative_impl<QVarLengthArray<int>>(); }
+ void ranged_ctor_QVarLengthArray_Movable() { ranged_ctor_non_associative_impl<QVarLengthArray<Movable>>(); }
+ void ranged_ctor_QVarLengthArray_Complex() { ranged_ctor_non_associative_impl<QVarLengthArray<Complex>>(); }
+ void ranged_ctor_QVarLengthArray_duplicates_strategy() { non_associative_container_duplicates_strategy<VarLengthArray>(); } // note the VarLengthArray passed
+
+ void ranged_ctor_QList_int() { ranged_ctor_non_associative_impl<QList<int>>(); }
+ void ranged_ctor_QList_Movable() { ranged_ctor_non_associative_impl<QList<Movable>>(); }
+ void ranged_ctor_QList_Complex() { ranged_ctor_non_associative_impl<QList<Complex>>(); }
+ void ranged_ctor_QList_duplicates_strategy() { non_associative_container_duplicates_strategy<QList>(); }
+
+ void ranged_ctor_std_list_int() { ranged_ctor_non_associative_impl<std::list<int>>(); }
+ void ranged_ctor_std_list_Movable() { ranged_ctor_non_associative_impl<std::list<Movable>>(); }
+ void ranged_ctor_std_list_Complex() { ranged_ctor_non_associative_impl<std::list<Complex>>(); }
+ void ranged_ctor_std_list_duplicates_strategy() { non_associative_container_duplicates_strategy<std::list>(); }
+
+ void ranged_ctor_std_forward_list_int() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<forward_list>)
+ ranged_ctor_non_associative_impl<std::forward_list<int>>();
+#else
+ QSKIP("<forward_list> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_forward_list_Movable() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<forward_list>)
+ ranged_ctor_non_associative_impl<std::forward_list<Movable>>();
+#else
+ QSKIP("<forward_list> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_forward_list_Complex() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<forward_list>)
+ ranged_ctor_non_associative_impl<std::forward_list<Complex>>();
+#else
+ QSKIP("<forward_list> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_forward_list_duplicates_strategy() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<forward_list>)
+ non_associative_container_duplicates_strategy<std::forward_list>();
+#else
+ QSKIP("<forward_list> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_QLinkedList_int() { ranged_ctor_non_associative_impl<QLinkedList<int>>(); }
+ void ranged_ctor_QLinkedList_Movable() { ranged_ctor_non_associative_impl<QLinkedList<Movable>>(); }
+ void ranged_ctor_QLinkedList_Complex() { ranged_ctor_non_associative_impl<QLinkedList<Complex>>(); }
+ void ranged_ctor_QLinkedList_duplicates_strategy() { non_associative_container_duplicates_strategy<QLinkedList>(); }
+
+ void ranged_ctor_std_set_int() { ranged_ctor_non_associative_impl<std::set<int>>(); }
+ void ranged_ctor_std_set_Movable() { ranged_ctor_non_associative_impl<std::set<Movable>>(); }
+ void ranged_ctor_std_set_Complex() { ranged_ctor_non_associative_impl<std::set<Complex>>(); }
+ void ranged_ctor_std_set_duplicates_strategy() { non_associative_container_duplicates_strategy<std::set>(); }
+
+ void ranged_ctor_std_multiset_int() { ranged_ctor_non_associative_impl<std::multiset<int>>(); }
+ void ranged_ctor_std_multiset_Movable() { ranged_ctor_non_associative_impl<std::multiset<Movable>>(); }
+ void ranged_ctor_std_multiset_Complex() { ranged_ctor_non_associative_impl<std::multiset<Complex>>(); }
+ void ranged_ctor_std_multiset_duplicates_strategy() { non_associative_container_duplicates_strategy<std::multiset>(); }
+
+ void ranged_ctor_std_unordered_set_int() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ ranged_ctor_non_associative_impl<std::unordered_set<int>>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_unordered_set_Movable() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ ranged_ctor_non_associative_impl<std::unordered_set<Movable>>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_unordered_set_Complex() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ ranged_ctor_non_associative_impl<std::unordered_set<Complex>>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_unordered_set_duplicates_strategy() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ non_associative_container_duplicates_strategy<std::unordered_set>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+
+ void ranged_ctor_std_unordered_multiset_int() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ ranged_ctor_non_associative_impl<std::unordered_multiset<int>>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_unordered_multiset_Movable() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ ranged_ctor_non_associative_impl<std::unordered_multiset<Movable>>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_unordered_multiset_Complex() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ ranged_ctor_non_associative_impl<std::unordered_multiset<Complex>>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_std_unordered_multiset_duplicates_strategy() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+ non_associative_container_duplicates_strategy<std::unordered_multiset>();
+#else
+ QSKIP("<unordered_set> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_QSet_int() { ranged_ctor_non_associative_impl<QSet<int>>(); }
+ void ranged_ctor_QSet_Movable() { ranged_ctor_non_associative_impl<QSet<Movable>>(); }
+ void ranged_ctor_QSet_Complex() { ranged_ctor_non_associative_impl<QSet<Complex>>(); }
+ void ranged_ctor_QSet_duplicates_strategy() { non_associative_container_duplicates_strategy<QSet>(); }
+
+ // associative
+ void ranged_ctor_std_map_int() { ranged_ctor_associative_impl<std::map<int, int>>(); }
+ void ranged_ctor_std_map_Movable() { ranged_ctor_associative_impl<std::map<Movable, int>>(); }
+ void ranged_ctor_std_map_Complex() { ranged_ctor_associative_impl<std::map<Complex, int>>(); }
+
+ void ranged_ctor_std_multimap_int() { ranged_ctor_associative_impl<std::multimap<int, int>>(); }
+ void ranged_ctor_std_multimap_Movable() { ranged_ctor_associative_impl<std::multimap<Movable, int>>(); }
+ void ranged_ctor_std_multimap_Complex() { ranged_ctor_associative_impl<std::multimap<Complex, int>>(); }
+
+ void ranged_ctor_unordered_map_int() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+ ranged_ctor_associative_impl<std::unordered_map<int, int>>();
+#else
+ QSKIP("<unordered_map> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_unordered_map_Movable() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+ ranged_ctor_associative_impl<std::unordered_map<Movable, Movable>>();
+#else
+ QSKIP("<unordered_map> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_unordered_map_Complex() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+ ranged_ctor_associative_impl<std::unordered_map<Complex, Complex>>();
+#else
+ QSKIP("<unordered_map> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_QHash_int() { ranged_ctor_associative_impl<QHash<int, int>>(); }
+ void ranged_ctor_QHash_Movable() { ranged_ctor_associative_impl<QHash<Movable, int>>(); }
+ void ranged_ctor_QHash_Complex() { ranged_ctor_associative_impl<QHash<Complex, int>>(); }
+
+ void ranged_ctor_unordered_multimap_int() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+ ranged_ctor_associative_impl<std::unordered_multimap<int, int>>();
+#else
+ QSKIP("<unordered_map> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_unordered_multimap_Movable() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+ ranged_ctor_associative_impl<std::unordered_multimap<Movable, Movable>>();
+#else
+ QSKIP("<unordered_map> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_unordered_multimap_Complex() {
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_map>)
+ ranged_ctor_associative_impl<std::unordered_multimap<Complex, Complex>>();
+#else
+ QSKIP("<unordered_map> is needed for this test");
+#endif
+ }
+
+ void ranged_ctor_QMultiHash_int() { ranged_ctor_associative_impl<QMultiHash<int, int>>(); }
+ void ranged_ctor_QMultiHash_Movable() { ranged_ctor_associative_impl<QMultiHash<Movable, int>>(); }
+ void ranged_ctor_QMultiHash_Complex() { ranged_ctor_associative_impl<QMultiHash<Complex, int>>(); }
+
private:
template <typename Container>
void front_back_impl() const;
@@ -58,6 +491,296 @@ private Q_SLOTS:
void front_back_QByteArray() { front_back_impl<QByteArray>(); }
};
+void tst_ContainerApiSymmetry::init()
+{
+ m_movableInstanceCount = Movable::instanceCount;
+ m_complexInstanceCount = Complex::instanceCount;
+}
+
+void tst_ContainerApiSymmetry::cleanup()
+{
+ // very simple leak check
+ QCOMPARE(Movable::instanceCount, m_movableInstanceCount);
+ QCOMPARE(Complex::instanceCount, m_complexInstanceCount);
+}
+
+template <typename Container>
+Container createContainerReference()
+{
+ using V = typename Container::value_type;
+
+ return {V(0), V(1), V(2), V(0)};
+}
+
+template <typename Container>
+void tst_ContainerApiSymmetry::ranged_ctor_non_associative_impl() const
+{
+ using V = typename Container::value_type;
+
+ // the double V(0) is deliberate
+ const auto reference = createContainerReference<Container>();
+
+ // plain array
+ const V values1[] = { V(0), V(1), V(2), V(0) };
+
+ const Container c1(values1, values1 + sizeof(values1)/sizeof(values1[0]));
+
+ // from QList
+ QList<V> l2;
+ l2 << V(0) << V(1) << V(2) << V(0);
+
+ const Container c2a(l2.begin(), l2.end());
+ const Container c2b(l2.cbegin(), l2.cend());
+
+ // from std::list
+ std::list<V> l3;
+ l3.push_back(V(0));
+ l3.push_back(V(1));
+ l3.push_back(V(2));
+ l3.push_back(V(0));
+ const Container c3a(l3.begin(), l3.end());
+
+ // from const std::list
+ const std::list<V> l3c = l3;
+ const Container c3b(l3c.begin(), l3c.end());
+
+ // from itself
+ const Container c4(reference.begin(), reference.end());
+
+ QCOMPARE(c1, reference);
+ QCOMPARE(c2a, reference);
+ QCOMPARE(c2b, reference);
+ QCOMPARE(c3a, reference);
+ QCOMPARE(c3b, reference);
+ QCOMPARE(c4, reference);
+}
+
+
+// type traits for detecting whether a non-associative container
+// accepts duplicated values, and if it doesn't, whether construction/insertion
+// prefer the new values (overwriting) or the old values (rejecting)
+
+struct ContainerAcceptsDuplicateValues {};
+struct ContainerOverwritesDuplicateValues {};
+struct ContainerRejectsDuplicateValues {};
+
+template<typename Container>
+struct ContainerDuplicatedValuesStrategy {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::vector<T...>> : ContainerAcceptsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<QVector<T...>> : ContainerAcceptsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<QVarLengthArray<T...>> : ContainerAcceptsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<VarLengthArray<T...>> : ContainerAcceptsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<QList<T...>> : ContainerAcceptsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::list<T...>> : ContainerAcceptsDuplicateValues {};
+
+#if COMPILER_HAS_STDLIB_INCLUDE(<forward_list>)
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::forward_list<T...>> : ContainerAcceptsDuplicateValues {};
+#endif
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<QLinkedList<T...>> : ContainerAcceptsDuplicateValues {};
+
+// assuming https://cplusplus.github.io/LWG/lwg-active.html#2844 resolution
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::set<T...>> : ContainerRejectsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::multiset<T...>> : ContainerAcceptsDuplicateValues {};
+
+#if COMPILER_HAS_STDLIB_INCLUDE(<unordered_set>)
+// assuming https://cplusplus.github.io/LWG/lwg-active.html#2844 resolution
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::unordered_set<T...>> : ContainerRejectsDuplicateValues {};
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<std::unordered_multiset<T...>> : ContainerAcceptsDuplicateValues {};
+#endif
+
+template<typename ... T>
+struct ContainerDuplicatedValuesStrategy<QSet<T...>> : ContainerRejectsDuplicateValues {};
+
+template<typename Container>
+void non_associative_container_check_duplicates_impl(const std::initializer_list<DuplicateStrategyTestType> &reference, const Container &c, ContainerAcceptsDuplicateValues)
+{
+ // do a deep check for equality, not ordering
+ QVERIFY(std::distance(reference.begin(), reference.end()) == std::distance(c.begin(), c.end()));
+ QVERIFY(std::is_permutation(reference.begin(), reference.end(), c.begin(), &reallyEqual));
+}
+
+enum class IterationOnReference
+{
+ ForwardIteration,
+ ReverseIteration
+};
+
+template<typename Container>
+void non_associative_container_check_duplicates_impl_no_duplicates(const std::initializer_list<DuplicateStrategyTestType> &reference, const Container &c, IterationOnReference ior)
+{
+ std::vector<DuplicateStrategyTestType> valuesAlreadySeen;
+
+ // iterate on reference forward or backwards, depending on ior. this will give
+ // us the expected semantics when checking for duplicated values into c
+ auto it = [&reference, ior]() {
+ switch (ior) {
+ case IterationOnReference::ForwardIteration: return reference.begin();
+ case IterationOnReference::ReverseIteration: return reference.end() - 1;
+ };
+ return std::initializer_list<DuplicateStrategyTestType>::const_iterator();
+ }();
+
+ const auto &end = [&reference, ior]() {
+ switch (ior) {
+ case IterationOnReference::ForwardIteration: return reference.end();
+ case IterationOnReference::ReverseIteration: return reference.begin() - 1;
+ };
+ return std::initializer_list<DuplicateStrategyTestType>::const_iterator();
+ }();
+
+ while (it != end) {
+ const auto &value = *it;
+
+ // check that there is indeed the same value in the container (using operator==)
+ const auto &valueInContainerIterator = std::find(c.begin(), c.end(), value);
+ QVERIFY(valueInContainerIterator != c.end());
+ QVERIFY(value == *valueInContainerIterator);
+
+ // if the value is a duplicate, we don't expect to find it in the container
+ // (when doing a deep comparison). otherwise it should be there
+
+ const auto &valuesAlreadySeenIterator = std::find(valuesAlreadySeen.cbegin(), valuesAlreadySeen.cend(), value);
+ const bool valueIsDuplicated = (valuesAlreadySeenIterator != valuesAlreadySeen.cend());
+
+ const auto &reallyEqualCheck = [&value](const DuplicateStrategyTestType &v) { return reallyEqual(value, v); };
+ QCOMPARE(std::find_if(c.begin(), c.end(), reallyEqualCheck) == c.end(), valueIsDuplicated);
+
+ valuesAlreadySeen.push_back(value);
+
+ switch (ior) {
+ case IterationOnReference::ForwardIteration:
+ ++it;
+ break;
+ case IterationOnReference::ReverseIteration:
+ --it;
+ break;
+ };
+ }
+
+}
+
+template<typename Container>
+void non_associative_container_check_duplicates_impl(const std::initializer_list<DuplicateStrategyTestType> &reference, const Container &c, ContainerRejectsDuplicateValues)
+{
+ non_associative_container_check_duplicates_impl_no_duplicates(reference, c, IterationOnReference::ForwardIteration);
+}
+
+template<typename Container>
+void non_associative_container_check_duplicates_impl(const std::initializer_list<DuplicateStrategyTestType> &reference, const Container &c, ContainerOverwritesDuplicateValues)
+{
+ non_associative_container_check_duplicates_impl_no_duplicates(reference, c, IterationOnReference::ReverseIteration);
+}
+
+template<typename Container>
+void non_associative_container_check_duplicates(const std::initializer_list<DuplicateStrategyTestType> &reference, const Container &c)
+{
+ non_associative_container_check_duplicates_impl(reference, c, ContainerDuplicatedValuesStrategy<Container>());
+}
+
+template<template<class ... T> class Container>
+void tst_ContainerApiSymmetry::non_associative_container_duplicates_strategy() const
+{
+ // first and last are "duplicates" -- they compare equal for operator==,
+ // but they differ when using reallyEqual
+ const std::initializer_list<DuplicateStrategyTestType> reference{ DuplicateStrategyTestType{0},
+ DuplicateStrategyTestType{1},
+ DuplicateStrategyTestType{2},
+ DuplicateStrategyTestType{0} };
+ Container<DuplicateStrategyTestType> c1{reference};
+ non_associative_container_check_duplicates(reference, c1);
+
+ Container<DuplicateStrategyTestType> c2{reference.begin(), reference.end()};
+ non_associative_container_check_duplicates(reference, c2);
+}
+
+template <typename Container>
+void tst_ContainerApiSymmetry::ranged_ctor_associative_impl() const
+{
+ using K = typename Container::key_type;
+ using V = typename Container::mapped_type;
+
+ // The double K(0) is deliberate. The order of the elements matters:
+ // * for unique-key STL containers, the first one should be the one inserted (cf. LWG 2844)
+ // * for unique-key Qt containers, the last one should be the one inserted
+ // * for multi-key sorted containers, the order of insertion of identical keys is also the
+ // iteration order (which establishes the equality of the containers)
+ // (although nothing of this is being tested here, that deserves its own testing)
+ const Container reference{
+ { K(0), V(1000) },
+ { K(1), V(1001) },
+ { K(2), V(1002) },
+ { K(0), V(1003) }
+ };
+
+ // Note that using anything not convertible to std::pair doesn't work for
+ // std containers. Their ranged construction is defined in terms of
+ // insert(value_type), which for std associative containers is
+ // std::pair<const K, T>.
+
+ // plain array
+ const std::pair<K, V> values1[] = {
+ std::make_pair(K(0), V(1000)),
+ std::make_pair(K(1), V(1001)),
+ std::make_pair(K(2), V(1002)),
+ std::make_pair(K(0), V(1003))
+ };
+
+ const Container c1(values1, values1 + sizeof(values1)/sizeof(values1[0]));
+
+ // from QList
+ QList<std::pair<K, V>> l2;
+ l2 << std::make_pair(K(0), V(1000))
+ << std::make_pair(K(1), V(1001))
+ << std::make_pair(K(2), V(1002))
+ << std::make_pair(K(0), V(1003));
+
+ const Container c2a(l2.begin(), l2.end());
+ const Container c2b(l2.cbegin(), l2.cend());
+
+ // from std::list
+ std::list<std::pair<K, V>> l3;
+ l3.push_back(std::make_pair(K(0), V(1000)));
+ l3.push_back(std::make_pair(K(1), V(1001)));
+ l3.push_back(std::make_pair(K(2), V(1002)));
+ l3.push_back(std::make_pair(K(0), V(1003)));
+ const Container c3a(l3.begin(), l3.end());
+
+ // from const std::list
+ const std::list<std::pair<K, V>> l3c = l3;
+ const Container c3b(l3c.begin(), l3c.end());
+
+ // from itself
+ const Container c4(reference.begin(), reference.end());
+
+ QCOMPARE(c1, reference);
+ QCOMPARE(c2a, reference);
+ QCOMPARE(c2b, reference);
+ QCOMPARE(c3a, reference);
+ QCOMPARE(c3b, reference);
+ QCOMPARE(c4, reference);
+}
+
template <typename Container>
Container make(int size)
{
diff --git a/tests/auto/corelib/tools/qalgorithms/tst_qalgorithms.cpp b/tests/auto/corelib/tools/qalgorithms/tst_qalgorithms.cpp
index 72299402f0..06db0e8546 100644
--- a/tests/auto/corelib/tools/qalgorithms/tst_qalgorithms.cpp
+++ b/tests/auto/corelib/tools/qalgorithms/tst_qalgorithms.cpp
@@ -208,7 +208,7 @@ void printHeader(QStringList &headers)
for (int h = 0; h < headers.count(); ++h) {
cout << setw(20) << setiosflags(ios_base::left) << headers.at(h).toLatin1().constData();
}
- cout << endl;
+ cout << Qt::endl;
}
template <typename ContainerType>
@@ -220,7 +220,7 @@ void print(ContainerType testContainer)
cout << value << " ";
}
- cout << endl;
+ cout << Qt::endl;
}
template <typename Algorithm, typename DataType>
@@ -252,7 +252,7 @@ void testAlgorithm(Algorithm algorithm, QStringList &dataSetTypes)
lessThan << setiosflags(ios_base::left) << setw(10) << result.lessThanRefCount / result.numSorts;
cout << numSorts.str() << lessThan.str();
}
- cout << endl;
+ cout << Qt::endl;
}
}
#endif
@@ -765,21 +765,21 @@ public:
#if Q_TEST_PERFORMANCE
void tst_QAlgorithms::performance()
{
- cout << endl << "Quick sort" << endl;
+ cout << Qt::endl << "Quick sort" << Qt::endl;
testAlgorithm<QuickSortHelper<TestInt>, TestInt>(QuickSortHelper<TestInt>(), dataSetTypes);
- cout << endl << "stable sort" << endl;
+ cout << Qt::endl << "stable sort" << Qt::endl;
testAlgorithm<StableSortHelper<TestInt>, TestInt>(StableSortHelper<TestInt>(), dataSetTypes);
- cout << endl << "std::sort" << endl;
+ cout << Qt::endl << "std::sort" << Qt::endl;
testAlgorithm<StlSortHelper<TestInt>, TestInt>(StlSortHelper<TestInt>(), dataSetTypes);
- cout << endl << "std::stable_sort" << endl;
+ cout << Qt::endl << "std::stable_sort" << Qt::endl;
testAlgorithm<StlStableSortHelper<TestInt>, TestInt>(StlStableSortHelper<TestInt>(), dataSetTypes);
/*
- cout << endl << "Sorting lists of ints" << endl;
- cout << endl << "Quick sort" << endl;
+ cout << Qt::endl << "Sorting lists of ints" << Qt::endl;
+ cout << Qt::endl << "Quick sort" << Qt::endl;
testAlgorithm<QuickSortHelper<int>, int>(QuickSortHelper<int>(), dataSetTypes);
- cout << endl << "std::sort" << endl;
+ cout << Qt::endl << "std::sort" << Qt::endl;
testAlgorithm<StlSortHelper<int>, int>(StlSortHelper<int>(), dataSetTypes);
- cout << endl << "std::stable_sort" << endl;
+ cout << Qt::endl << "std::stable_sort" << Qt::endl;
testAlgorithm<StlStableSortHelper<int>, int>(StlStableSortHelper<int>(), dataSetTypes);
*/
}
diff --git a/tests/auto/corelib/tools/qarraydata/tst_qarraydata.cpp b/tests/auto/corelib/tools/qarraydata/tst_qarraydata.cpp
index a00c962510..7db7d71b1f 100644
--- a/tests/auto/corelib/tools/qarraydata/tst_qarraydata.cpp
+++ b/tests/auto/corelib/tools/qarraydata/tst_qarraydata.cpp
@@ -78,12 +78,8 @@ private slots:
void fromRawData_data();
void fromRawData();
void literals();
-#if defined(Q_COMPILER_VARIADIC_MACROS) && defined(Q_COMPILER_LAMBDA)
void variadicLiterals();
-#endif
-#ifdef Q_COMPILER_RVALUE_REFS
void rValueReferences();
-#endif
void grow();
};
@@ -95,7 +91,7 @@ void tst_QArrayData::referenceCounting()
// Reference counting initialized to 1 (owned)
QArrayData array = { { Q_BASIC_ATOMIC_INITIALIZER(1) }, 0, 0, 0, 0 };
- QCOMPARE(array.ref.atomic.load(), 1);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 1);
QVERIFY(!array.ref.isStatic());
#if !defined(QT_NO_UNSHARABLE_CONTAINERS)
@@ -103,19 +99,19 @@ void tst_QArrayData::referenceCounting()
#endif
QVERIFY(array.ref.ref());
- QCOMPARE(array.ref.atomic.load(), 2);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 2);
QVERIFY(array.ref.deref());
- QCOMPARE(array.ref.atomic.load(), 1);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 1);
QVERIFY(array.ref.ref());
- QCOMPARE(array.ref.atomic.load(), 2);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 2);
QVERIFY(array.ref.deref());
- QCOMPARE(array.ref.atomic.load(), 1);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 1);
QVERIFY(!array.ref.deref());
- QCOMPARE(array.ref.atomic.load(), 0);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 0);
// Now would be a good time to free/release allocated data
}
@@ -125,17 +121,17 @@ void tst_QArrayData::referenceCounting()
// Reference counting initialized to 0 (non-sharable)
QArrayData array = { { Q_BASIC_ATOMIC_INITIALIZER(0) }, 0, 0, 0, 0 };
- QCOMPARE(array.ref.atomic.load(), 0);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 0);
QVERIFY(!array.ref.isStatic());
QVERIFY(!array.ref.isSharable());
QVERIFY(!array.ref.ref());
// Reference counting fails, data should be copied
- QCOMPARE(array.ref.atomic.load(), 0);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 0);
QVERIFY(!array.ref.deref());
- QCOMPARE(array.ref.atomic.load(), 0);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), 0);
// Free/release data
}
@@ -145,7 +141,7 @@ void tst_QArrayData::referenceCounting()
// Reference counting initialized to -1 (static read-only data)
QArrayData array = { Q_REFCOUNT_INITIALIZE_STATIC, 0, 0, 0, 0 };
- QCOMPARE(array.ref.atomic.load(), -1);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), -1);
QVERIFY(array.ref.isStatic());
#if !defined(QT_NO_UNSHARABLE_CONTAINERS)
@@ -153,10 +149,10 @@ void tst_QArrayData::referenceCounting()
#endif
QVERIFY(array.ref.ref());
- QCOMPARE(array.ref.atomic.load(), -1);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), -1);
QVERIFY(array.ref.deref());
- QCOMPARE(array.ref.atomic.load(), -1);
+ QCOMPARE(array.ref.atomic.loadRelaxed(), -1);
}
}
@@ -172,8 +168,8 @@ void tst_QArrayData::sharedNullEmpty()
QVERIFY(empty->ref.isStatic());
QVERIFY(empty->ref.isShared());
- QCOMPARE(null->ref.atomic.load(), -1);
- QCOMPARE(empty->ref.atomic.load(), -1);
+ QCOMPARE(null->ref.atomic.loadRelaxed(), -1);
+ QCOMPARE(empty->ref.atomic.loadRelaxed(), -1);
#if !defined(QT_NO_UNSHARABLE_CONTAINERS)
QVERIFY(null->ref.isSharable());
@@ -183,14 +179,14 @@ void tst_QArrayData::sharedNullEmpty()
QVERIFY(null->ref.ref());
QVERIFY(empty->ref.ref());
- QCOMPARE(null->ref.atomic.load(), -1);
- QCOMPARE(empty->ref.atomic.load(), -1);
+ QCOMPARE(null->ref.atomic.loadRelaxed(), -1);
+ QCOMPARE(empty->ref.atomic.loadRelaxed(), -1);
QVERIFY(null->ref.deref());
QVERIFY(empty->ref.deref());
- QCOMPARE(null->ref.atomic.load(), -1);
- QCOMPARE(empty->ref.atomic.load(), -1);
+ QCOMPARE(null->ref.atomic.loadRelaxed(), -1);
+ QCOMPARE(empty->ref.atomic.loadRelaxed(), -1);
QVERIFY(null != empty);
@@ -1618,9 +1614,7 @@ void tst_QArrayData::literals()
QCOMPARE(v.size(), size_t(11));
// v.capacity() is unspecified, for now
-#if defined(Q_COMPILER_VARIADIC_MACROS) && defined(Q_COMPILER_LAMBDA)
QVERIFY(v.isStatic());
-#endif
#if !defined(QT_NO_UNSHARABLE_CONTAINERS)
QVERIFY(v.isSharable());
@@ -1633,7 +1627,6 @@ void tst_QArrayData::literals()
}
}
-#if defined(Q_COMPILER_VARIADIC_MACROS) && defined(Q_COMPILER_LAMBDA)
// Variadic Q_ARRAY_LITERAL need to be available in the current configuration.
void tst_QArrayData::variadicLiterals()
{
@@ -1682,9 +1675,7 @@ void tst_QArrayData::variadicLiterals()
QCOMPARE(const_(v)[i], i);
}
}
-#endif
-#ifdef Q_COMPILER_RVALUE_REFS
// std::remove_reference is in C++11, but requires library support
template <class T> struct RemoveReference { typedef T Type; };
template <class T> struct RemoveReference<T &> { typedef T Type; };
@@ -1767,7 +1758,6 @@ void tst_QArrayData::rValueReferences()
QCOMPARE(v3.size(), size_t(1));
QCOMPARE(v3.front(), 42);
}
-#endif
void tst_QArrayData::grow()
{
diff --git a/tests/auto/corelib/tools/qbytearray/tst_qbytearray.cpp b/tests/auto/corelib/tools/qbytearray/tst_qbytearray.cpp
index 1ed41793dc..90dfcaef25 100644
--- a/tests/auto/corelib/tools/qbytearray/tst_qbytearray.cpp
+++ b/tests/auto/corelib/tools/qbytearray/tst_qbytearray.cpp
@@ -138,9 +138,7 @@ private slots:
void reserveExtended();
void movablity_data();
void movablity();
-#if defined(Q_COMPILER_LAMBDA)
void literals();
-#endif
void toUpperLower_data();
void toUpperLower();
void isUpper();
@@ -1361,6 +1359,9 @@ void tst_QByteArray::toDouble_data()
QTest::newRow("trailing spaces") << QByteArray("1.2345 \n\r\t") << 1.2345 << true;
QTest::newRow("leading junk") << QByteArray("x1.2345") << 0.0 << false;
QTest::newRow("trailing junk") << QByteArray("1.2345x") << 0.0 << false;
+
+ QTest::newRow("raw, null plus junk") << QByteArray::fromRawData("1.2\0 junk", 9) << 0.0 << false;
+ QTest::newRow("raw, null-terminator not included") << QByteArray::fromRawData("2.3", 3) << 2.3 << true;
}
void tst_QByteArray::toDouble()
@@ -1934,7 +1935,7 @@ void tst_QByteArray::repeatedSignature() const
{
/* repated() should be a const member. */
const QByteArray string;
- string.repeated(3);
+ (void)string.repeated(3);
}
void tst_QByteArray::repeated() const
@@ -2126,7 +2127,7 @@ void tst_QByteArray::movablity()
{
QFETCH(QByteArray, array);
- QVERIFY(!QTypeInfo<QByteArray>::isStatic);
+ Q_STATIC_ASSERT(!QTypeInfo<QByteArray>::isStatic);
const int size = array.size();
const bool isEmpty = array.isEmpty();
@@ -2138,7 +2139,7 @@ void tst_QByteArray::movablity()
// we need only memory space not the instance
memSpace.~QByteArray();
// move array -> memSpace
- memcpy(&memSpace, &array, sizeof(QByteArray));
+ memcpy((void *)&memSpace, (const void *)&array, sizeof(QByteArray));
// reconstruct empty QByteArray
new (&array) QByteArray;
@@ -2148,8 +2149,8 @@ void tst_QByteArray::movablity()
QCOMPARE(memSpace.capacity(), capacity);
// try to not crash
- memSpace.toLower();
- memSpace.toUpper();
+ (void)memSpace.toLower();
+ (void)memSpace.toUpper();
memSpace.prepend('a');
memSpace.append("b", 1);
memSpace.squeeze();
@@ -2165,7 +2166,7 @@ void tst_QByteArray::movablity()
// move back memSpace -> array
array.~QByteArray();
- memcpy(&array, &memSpace, sizeof(QByteArray));
+ memcpy((void *)&array, (const void *)&memSpace, sizeof(QByteArray));
// reconstruct empty QByteArray
new (&memSpace) QByteArray;
@@ -2189,7 +2190,6 @@ void tst_QByteArray::movablity()
QVERIFY(true);
}
-#if defined(Q_COMPILER_LAMBDA)
// Only tested on c++0x compliant compiler or gcc
void tst_QByteArray::literals()
{
@@ -2210,7 +2210,6 @@ void tst_QByteArray::literals()
QVERIFY(str2.constData() == s);
QVERIFY(str2.data() != s);
}
-#endif
void tst_QByteArray::toUpperLower_data()
{
@@ -2242,28 +2241,28 @@ void tst_QByteArray::toUpperLower()
QCOMPARE(input.toLower(), lower);
QByteArray copy = input;
- QCOMPARE(qMove(copy).toUpper(), upper);
+ QCOMPARE(std::move(copy).toUpper(), upper);
copy = input;
copy.detach();
- QCOMPARE(qMove(copy).toUpper(), upper);
+ QCOMPARE(std::move(copy).toUpper(), upper);
copy = input;
- QCOMPARE(qMove(copy).toLower(), lower);
+ QCOMPARE(std::move(copy).toLower(), lower);
copy = input;
copy.detach();
- QCOMPARE(qMove(copy).toLower(), lower);
+ QCOMPARE(std::move(copy).toLower(), lower);
copy = lower;
- QCOMPARE(qMove(copy).toLower(), lower);
+ QCOMPARE(std::move(copy).toLower(), lower);
copy = lower;
copy.detach();
- QCOMPARE(qMove(copy).toLower(), lower);
+ QCOMPARE(std::move(copy).toLower(), lower);
copy = upper;
- QCOMPARE(qMove(copy).toUpper(), upper);
+ QCOMPARE(std::move(copy).toUpper(), upper);
copy = upper;
copy.detach();
- QCOMPARE(qMove(copy).toUpper(), upper);
+ QCOMPARE(std::move(copy).toUpper(), upper);
}
void tst_QByteArray::isUpper()
diff --git a/tests/auto/corelib/tools/qbytearraylist/tst_qbytearraylist.cpp b/tests/auto/corelib/tools/qbytearraylist/tst_qbytearraylist.cpp
index 2d2c536453..09ce41337e 100644
--- a/tests/auto/corelib/tools/qbytearraylist/tst_qbytearraylist.cpp
+++ b/tests/auto/corelib/tools/qbytearraylist/tst_qbytearraylist.cpp
@@ -194,22 +194,22 @@ void tst_QByteArrayList::operator_plus() const
{
QByteArrayList bal1 = lhs;
const QByteArrayList bal2 = rhs;
- QCOMPARE(qMove(bal1) + bal2, expectedResult);
+ QCOMPARE(std::move(bal1) + bal2, expectedResult);
}
{
QList<QByteArray> lba1 = lhs;
const QByteArrayList bal2 = rhs;
- QCOMPARE(qMove(lba1) + bal2, expectedResult);
+ QCOMPARE(std::move(lba1) + bal2, expectedResult);
}
{
QByteArrayList bal1 = lhs;
const QList<QByteArray> lba2 = rhs;
- QCOMPARE(qMove(bal1) + lba2, expectedResult);
+ QCOMPARE(std::move(bal1) + lba2, expectedResult);
}
{
QList<QByteArray> lba1 = lhs;
const QList<QByteArray> lba2 = rhs;
- QCOMPARE(qMove(lba1) + lba2, QList<QByteArray>(expectedResult)); // check we don't mess with old code
+ QCOMPARE(std::move(lba1) + lba2, QList<QByteArray>(expectedResult)); // check we don't mess with old code
}
// operator += for const lvalues
@@ -232,7 +232,7 @@ void tst_QByteArrayList::operator_plus() const
QByteArrayList t1 = lhs;
QByteArrayList t2 = rhs;
- QCOMPARE(qMove(t1) + t2, expectedResult);
+ QCOMPARE(std::move(t1) + t2, expectedResult);
}
void tst_QByteArrayList::operator_plus_data() const
@@ -287,7 +287,6 @@ void tst_QByteArrayList::indexOf() const
void tst_QByteArrayList::initializerList() const
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
// constructor
QByteArrayList v1 = {QByteArray("hello"),"world",QByteArray("plop")};
QCOMPARE(v1, (QByteArrayList() << "hello" << "world" << "plop"));
@@ -296,9 +295,6 @@ void tst_QByteArrayList::initializerList() const
QByteArrayList v2;
v2 = {QByteArray("hello"),"world",QByteArray("plop")};
QCOMPARE(v2, v1);
-#else
- QSKIP("This test requires C++11 initializer_list support in the compiler.");
-#endif
}
QTEST_APPLESS_MAIN(tst_QByteArrayList)
diff --git a/tests/auto/corelib/tools/qcollator/tst_qcollator.cpp b/tests/auto/corelib/tools/qcollator/tst_qcollator.cpp
index 72f88a235d..2ae9c6e159 100644
--- a/tests/auto/corelib/tools/qcollator/tst_qcollator.cpp
+++ b/tests/auto/corelib/tools/qcollator/tst_qcollator.cpp
@@ -47,7 +47,6 @@ private Q_SLOTS:
void state();
};
-#ifdef Q_COMPILER_RVALUE_REFS
static bool dpointer_is_null(QCollator &c)
{
char mem[sizeof c];
@@ -58,11 +57,9 @@ static bool dpointer_is_null(QCollator &c)
return false;
return true;
}
-#endif
void tst_QCollator::moveSemantics()
{
-#ifdef Q_COMPILER_RVALUE_REFS
const QLocale de_AT(QLocale::German, QLocale::Austria);
QCollator c1(de_AT);
@@ -78,9 +75,6 @@ void tst_QCollator::moveSemantics()
c1 = std::move(c2);
QCOMPARE(c1.locale(), de_AT);
QVERIFY(dpointer_is_null(c2));
-#else
- QSKIP("The compiler is not in C++11 mode or does not support move semantics.");
-#endif
}
diff --git a/tests/auto/corelib/tools/qcommandlineparser/tst_qcommandlineparser.cpp b/tests/auto/corelib/tools/qcommandlineparser/tst_qcommandlineparser.cpp
index 7980f1f8f4..1e87c76d2f 100644
--- a/tests/auto/corelib/tools/qcommandlineparser/tst_qcommandlineparser.cpp
+++ b/tests/auto/corelib/tools/qcommandlineparser/tst_qcommandlineparser.cpp
@@ -44,6 +44,7 @@ private slots:
// In-process tests
void testInvalidOptions();
+ void testDuplicateOption();
void testPositionalArguments();
void testBooleanOption_data();
void testBooleanOption();
@@ -75,6 +76,8 @@ private slots:
void testHelpOption();
void testQuoteEscaping();
void testUnknownOption();
+ void testHelpAll_data();
+ void testHelpAll();
};
static char *empty_argv[] = { 0 };
@@ -104,6 +107,15 @@ void tst_QCommandLineParser::testInvalidOptions()
QVERIFY(!parser.addOption(QCommandLineOption(QStringLiteral("-v"), QStringLiteral("Displays version information."))));
}
+void tst_QCommandLineParser::testDuplicateOption()
+{
+ QCoreApplication app(empty_argc, empty_argv);
+ QCommandLineParser parser;
+ QVERIFY(parser.addOption(QCommandLineOption(QStringLiteral("h"), QStringLiteral("Hostname."), QStringLiteral("hostname"))));
+ QTest::ignoreMessage(QtWarningMsg, "QCommandLineParser: already having an option named \"h\"");
+ parser.addHelpOption();
+}
+
void tst_QCommandLineParser::testPositionalArguments()
{
QCoreApplication app(empty_argc, empty_argv);
@@ -489,7 +501,7 @@ void tst_QCommandLineParser::testSingleDashWordOptionModes()
void tst_QCommandLineParser::testCpp11StyleInitialization()
{
-#if defined(Q_COMPILER_INITIALIZER_LISTS) && defined(Q_COMPILER_UNIFORM_INIT)
+#if defined(Q_COMPILER_UNIFORM_INIT)
QCoreApplication app(empty_argc, empty_argv);
QCommandLineParser parser;
@@ -532,7 +544,8 @@ void tst_QCommandLineParser::testVersionOption()
static const char expectedOptionsHelp[] =
"Options:\n"
- " -h, --help Displays this help.\n"
+ " -h, --help Displays help on commandline options.\n"
+ " --help-all Displays help including Qt specific options.\n"
" -v, --version Displays version information.\n"
" --load <url> Load file from URL.\n"
" -o, --output <file> Set output file.\n"
@@ -566,8 +579,8 @@ void tst_QCommandLineParser::testHelpOption_data()
" parsingMode The parsing mode to test.\n"
" command The command to execute.\n");
#ifdef Q_OS_WIN
- expectedOutput.replace(" -h, --help Displays this help.\n",
- " -?, -h, --help Displays this help.\n");
+ expectedOutput.replace(" -h, --help Displays help on commandline options.\n",
+ " -?, -h, --help Displays help on commandline options.\n");
expectedOutput.replace("testhelper/", "testhelper\\");
#endif
@@ -615,8 +628,8 @@ void tst_QCommandLineParser::testHelpOption()
"Arguments:\n"
" resize Resize the object to a new size.\n";
#ifdef Q_OS_WIN
- expectedResizeHelp.replace(" -h, --help Displays this help.\n",
- " -?, -h, --help Displays this help.\n");
+ expectedResizeHelp.replace(" -h, --help Displays help on commandline options.\n",
+ " -?, -h, --help Displays help on commandline options.\n");
expectedResizeHelp.replace("testhelper/", "testhelper\\");
#endif
QCOMPARE(output, QString(expectedResizeHelp));
@@ -670,6 +683,60 @@ void tst_QCommandLineParser::testUnknownOption()
#endif // QT_CONFIG(process)
}
+void tst_QCommandLineParser::testHelpAll_data()
+{
+ QTest::addColumn<QCommandLineParser::SingleDashWordOptionMode>("parsingMode");
+ QTest::addColumn<QString>("expectedHelpOutput");
+
+ QString expectedOutput = QString::fromLatin1(
+ "Usage: testhelper/qcommandlineparser_test_helper [options] parsingMode command\n"
+ "Test helper\n"
+ "\n")
+ + QString::fromLatin1(expectedOptionsHelp) +
+ QString::fromLatin1(
+ " --qmljsdebugger <value> Activates the QML/JS debugger with a specified\n"
+ " port. The value must be of format\n"
+ " port:1234[,block]. \"block\" makes the application\n"
+ " wait for a connection.\n"
+ "\n"
+ "Arguments:\n"
+ " parsingMode The parsing mode to test.\n"
+ " command The command to execute.\n");
+#ifdef Q_OS_WIN
+ expectedOutput.replace(" -h, --help Displays help on commandline options.\n",
+ " -?, -h, --help Displays help on commandline options.\n");
+ expectedOutput.replace("testhelper/", "testhelper\\");
+#endif
+
+ QTest::newRow("collapsed") << QCommandLineParser::ParseAsCompactedShortOptions << expectedOutput;
+ QTest::newRow("long") << QCommandLineParser::ParseAsLongOptions << expectedOutput;
+}
+
+void tst_QCommandLineParser::testHelpAll()
+{
+#if !QT_CONFIG(process)
+ QSKIP("This test requires QProcess support");
+#else
+#if defined(Q_OS_ANDROID) && !defined(Q_OS_ANDROID_EMBEDDED)
+ QSKIP("Deploying executable applications to file system on Android not supported.");
+#endif
+
+ QFETCH(QCommandLineParser::SingleDashWordOptionMode, parsingMode);
+ QFETCH(QString, expectedHelpOutput);
+ QCoreApplication app(empty_argc, empty_argv);
+ QProcess process;
+ process.start("testhelper/qcommandlineparser_test_helper", QStringList() << QString::number(parsingMode) << "--help-all");
+ QVERIFY(process.waitForFinished(5000));
+ QCOMPARE(process.exitStatus(), QProcess::NormalExit);
+ QString output = process.readAll();
+#ifdef Q_OS_WIN
+ output.replace(QStringLiteral("\r\n"), QStringLiteral("\n"));
+#endif
+ QCOMPARE(output.split('\n'), expectedHelpOutput.split('\n')); // easier to debug than the next line, on failure
+ QCOMPARE(output, expectedHelpOutput);
+#endif // QT_CONFIG(process)
+}
+
QTEST_APPLESS_MAIN(tst_QCommandLineParser)
#include "tst_qcommandlineparser.moc"
diff --git a/tests/auto/corelib/tools/qcontiguouscache/tst_qcontiguouscache.cpp b/tests/auto/corelib/tools/qcontiguouscache/tst_qcontiguouscache.cpp
index 31a5f93822..f305d63d46 100644
--- a/tests/auto/corelib/tools/qcontiguouscache/tst_qcontiguouscache.cpp
+++ b/tests/auto/corelib/tools/qcontiguouscache/tst_qcontiguouscache.cpp
@@ -68,7 +68,7 @@ void tst_QContiguousCache::assignment()
// copy:
cc1 = cc2;
// move:
- cc1 = qMove(cc2);
+ cc1 = std::move(cc2);
}
void tst_QContiguousCache::empty()
@@ -244,7 +244,7 @@ public:
return *this;
}
- int refCount() const { return d->ref.load(); }
+ int refCount() const { return d->ref.loadRelaxed(); }
private:
RefCountingClassData *d;
};
diff --git a/tests/auto/corelib/tools/qdate/.gitignore b/tests/auto/corelib/tools/qdate/.gitignore
deleted file mode 100644
index 70945d4a86..0000000000
--- a/tests/auto/corelib/tools/qdate/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-tst_qdate
diff --git a/tests/auto/corelib/tools/qdate/qdate.pro b/tests/auto/corelib/tools/qdate/qdate.pro
deleted file mode 100644
index dd7c6cb888..0000000000
--- a/tests/auto/corelib/tools/qdate/qdate.pro
+++ /dev/null
@@ -1,4 +0,0 @@
-CONFIG += testcase
-TARGET = tst_qdate
-QT = core testlib
-SOURCES = tst_qdate.cpp
diff --git a/tests/auto/corelib/tools/qdate/tst_qdate.cpp b/tests/auto/corelib/tools/qdate/tst_qdate.cpp
deleted file mode 100644
index ce1e5730dd..0000000000
--- a/tests/auto/corelib/tools/qdate/tst_qdate.cpp
+++ /dev/null
@@ -1,1505 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Copyright (C) 2016 Intel Corporation.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtTest/QtTest>
-#include <qdatetime.h>
-#include <qlocale.h>
-
-class tst_QDate : public QObject
-{
- Q_OBJECT
-private slots:
- void isNull_data();
- void isNull();
- void isValid_data();
- void isValid();
- void julianDay_data();
- void julianDay();
- void dayOfWeek_data();
- void dayOfWeek();
- void dayOfYear_data();
- void dayOfYear();
- void daysInMonth_data();
- void daysInMonth();
- void daysInYear_data();
- void daysInYear();
- void getDate();
- void weekNumber_invalid_data();
- void weekNumber_invalid();
- void weekNumber_data();
- void weekNumber();
- void julianDaysLimits();
- void addDays_data();
- void addDays();
- void addMonths_data();
- void addMonths();
- void addYears_data();
- void addYears();
- void daysTo();
- void operator_eq_eq_data();
- void operator_eq_eq();
- void operator_lt();
- void operator_gt();
- void operator_lt_eq();
- void operator_gt_eq();
- void operator_insert_extract_data();
- void operator_insert_extract();
- void fromStringDateFormat_data();
- void fromStringDateFormat();
- void fromStringFormat_data();
- void fromStringFormat();
- void toStringFormat_data();
- void toStringFormat();
- void toStringDateFormat_data();
- void toStringDateFormat();
- void isLeapYear();
- void yearsZeroToNinetyNine();
- void negativeYear() const;
- void printNegativeYear() const;
- void roundtripGermanLocale() const;
- void shortDayName() const;
- void standaloneShortDayName() const;
- void longDayName() const;
- void standaloneLongDayName() const;
- void shortMonthName() const;
- void standaloneShortMonthName() const;
- void longMonthName() const;
- void standaloneLongMonthName() const;
- void roundtrip() const;
- void qdebug() const;
-private:
- QDate defDate() const { return QDate(1900, 1, 1); }
- QDate invalidDate() const { return QDate(); }
-};
-
-Q_DECLARE_METATYPE(Qt::DateFormat)
-
-void tst_QDate::isNull_data()
-{
- QTest::addColumn<qint64>("jd");
- QTest::addColumn<bool>("null");
-
- qint64 minJd = Q_INT64_C(-784350574879);
- qint64 maxJd = Q_INT64_C( 784354017364);
-
- QTest::newRow("qint64 min") << std::numeric_limits<qint64>::min() << true;
- QTest::newRow("minJd - 1") << minJd - 1 << true;
- QTest::newRow("minJd") << minJd << false;
- QTest::newRow("minJd + 1") << minJd + 1 << false;
- QTest::newRow("maxJd - 1") << maxJd - 1 << false;
- QTest::newRow("maxJd") << maxJd << false;
- QTest::newRow("maxJd + 1") << maxJd + 1 << true;
- QTest::newRow("qint64 max") << std::numeric_limits<qint64>::max() << true;
-}
-
-void tst_QDate::isNull()
-{
- QFETCH(qint64, jd);
-
- QDate d = QDate::fromJulianDay(jd);
- QTEST(d.isNull(), "null");
-}
-
-void tst_QDate::isValid_data()
-{
- qint64 nullJd = std::numeric_limits<qint64>::min();
-
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<qint64>("jd");
- QTest::addColumn<bool>("valid");
-
- QTest::newRow("0-0-0") << 0 << 0 << 0 << nullJd << false;
- QTest::newRow("month 0") << 2000 << 0 << 1 << nullJd << false;
- QTest::newRow("day 0") << 2000 << 1 << 0 << nullJd << false;
-
- QTest::newRow("month 13") << 2000 << 13 << 1 << nullJd << false;
-
- // test leap years
- QTest::newRow("non-leap") << 2006 << 2 << 29 << nullJd << false;
- QTest::newRow("normal leap") << 2004 << 2 << 29 << qint64(2453065) << true;
- QTest::newRow("century leap 1900") << 1900 << 2 << 29 << nullJd << false;
- QTest::newRow("century leap 2100") << 2100 << 2 << 29 << nullJd << false;
- QTest::newRow("400-years leap 2000") << 2000 << 2 << 29 << qint64(2451604) << true;
- QTest::newRow("400-years leap 2400") << 2400 << 2 << 29 << qint64(2597701) << true;
- QTest::newRow("400-years leap 1600") << 1600 << 2 << 29 << qint64(2305507) << true;
- QTest::newRow("year 0") << 0 << 2 << 27 << nullJd << false;
-
- // Test end of four-digit years:
- QTest::newRow("late") << 9999 << 12 << 31 << qint64(5373484) << true;
-
- // test the number of days in months:
- QTest::newRow("jan") << 2000 << 1 << 31 << qint64(2451575) << true;
- QTest::newRow("feb") << 2000 << 2 << 29 << qint64(2451604) << true; // same data as 400-years leap
- QTest::newRow("mar") << 2000 << 3 << 31 << qint64(2451635) << true;
- QTest::newRow("apr") << 2000 << 4 << 30 << qint64(2451665) << true;
- QTest::newRow("may") << 2000 << 5 << 31 << qint64(2451696) << true;
- QTest::newRow("jun") << 2000 << 6 << 30 << qint64(2451726) << true;
- QTest::newRow("jul") << 2000 << 7 << 31 << qint64(2451757) << true;
- QTest::newRow("aug") << 2000 << 8 << 31 << qint64(2451788) << true;
- QTest::newRow("sep") << 2000 << 9 << 30 << qint64(2451818) << true;
- QTest::newRow("oct") << 2000 << 10 << 31 << qint64(2451849) << true;
- QTest::newRow("nov") << 2000 << 11 << 30 << qint64(2451879) << true;
- QTest::newRow("dec") << 2000 << 12 << 31 << qint64(2451910) << true;
-
- // and invalid dates:
- QTest::newRow("ijan") << 2000 << 1 << 32 << nullJd << false;
- QTest::newRow("ifeb") << 2000 << 2 << 30 << nullJd << false;
- QTest::newRow("imar") << 2000 << 3 << 32 << nullJd << false;
- QTest::newRow("iapr") << 2000 << 4 << 31 << nullJd << false;
- QTest::newRow("imay") << 2000 << 5 << 32 << nullJd << false;
- QTest::newRow("ijun") << 2000 << 6 << 31 << nullJd << false;
- QTest::newRow("ijul") << 2000 << 7 << 32 << nullJd << false;
- QTest::newRow("iaug") << 2000 << 8 << 32 << nullJd << false;
- QTest::newRow("isep") << 2000 << 9 << 31 << nullJd << false;
- QTest::newRow("ioct") << 2000 << 10 << 32 << nullJd << false;
- QTest::newRow("inov") << 2000 << 11 << 31 << nullJd << false;
- QTest::newRow("idec") << 2000 << 12 << 32 << nullJd << false;
-
- // the beginning of the Julian Day calendar:
- QTest::newRow("jd earliest formula") << -4800 << 1 << 1 << qint64( -31738) << true;
- QTest::newRow("jd -1") << -4714 << 11 << 23 << qint64( -1) << true;
- QTest::newRow("jd 0") << -4714 << 11 << 24 << qint64( 0) << true;
- QTest::newRow("jd 1") << -4714 << 11 << 25 << qint64( 1) << true;
- QTest::newRow("jd latest formula") << 1400000 << 12 << 31 << qint64(513060925) << true;
-}
-
-void tst_QDate::isValid()
-{
- QFETCH(int, year);
- QFETCH(int, month);
- QFETCH(int, day);
- QFETCH(qint64, jd);
- QFETCH(bool, valid);
-
- QCOMPARE(QDate::isValid(year, month, day), valid);
-
- QDate d;
- d.setDate(year, month, day);
- QCOMPARE(d.isValid(), valid);
- QCOMPARE(d.toJulianDay(), jd);
-
- if (valid) {
- QCOMPARE(d.year(), year);
- QCOMPARE(d.month(), month);
- QCOMPARE(d.day(), day);
- } else {
- QCOMPARE(d.year(), 0);
- QCOMPARE(d.month(), 0);
- QCOMPARE(d.day(), 0);
- }
-}
-
-void tst_QDate::julianDay_data()
-{
- isValid_data();
-}
-
-void tst_QDate::julianDay()
-{
- QFETCH(int, year);
- QFETCH(int, month);
- QFETCH(int, day);
- QFETCH(qint64, jd);
-
- {
- QDate d;
- d.setDate(year, month, day);
- QCOMPARE(d.toJulianDay(), jd);
- }
-
- if (jd != std::numeric_limits<qint64>::min()) {
- QDate d = QDate::fromJulianDay(jd);
- QCOMPARE(d.year(), year);
- QCOMPARE(d.month(), month);
- QCOMPARE(d.day(), day);
- }
-}
-
-void tst_QDate::dayOfWeek_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<int>("dayOfWeek");
-
- QTest::newRow("data0") << 0 << 0 << 0 << 0;
- QTest::newRow("data1") << 2000 << 1 << 3 << 1;
- QTest::newRow("data2") << 2000 << 1 << 4 << 2;
- QTest::newRow("data3") << 2000 << 1 << 5 << 3;
- QTest::newRow("data4") << 2000 << 1 << 6 << 4;
- QTest::newRow("data5") << 2000 << 1 << 7 << 5;
- QTest::newRow("data6") << 2000 << 1 << 8 << 6;
- QTest::newRow("data7") << 2000 << 1 << 9 << 7;
- QTest::newRow("data8") << -4800 << 1 << 1 << 1;
- QTest::newRow("data9") << -4800 << 1 << 2 << 2;
- QTest::newRow("data10") << -4800 << 1 << 3 << 3;
- QTest::newRow("data11") << -4800 << 1 << 4 << 4;
- QTest::newRow("data12") << -4800 << 1 << 5 << 5;
- QTest::newRow("data13") << -4800 << 1 << 6 << 6;
- QTest::newRow("data14") << -4800 << 1 << 7 << 7;
- QTest::newRow("data15") << -4800 << 1 << 8 << 1;
-}
-
-void tst_QDate::dayOfWeek()
-{
- QFETCH(int, year);
- QFETCH(int, month);
- QFETCH(int, day);
- QFETCH(int, dayOfWeek);
-
- QDate dt(year, month, day);
- QCOMPARE(dt.dayOfWeek(), dayOfWeek);
-}
-
-void tst_QDate::dayOfYear_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<int>("dayOfYear");
-
- QTest::newRow("data0") << 0 << 0 << 0 << 0;
- QTest::newRow("data1") << 2000 << 1 << 1 << 1;
- QTest::newRow("data2") << 2000 << 1 << 2 << 2;
- QTest::newRow("data3") << 2000 << 1 << 3 << 3;
- QTest::newRow("data4") << 2000 << 12 << 31 << 366;
- QTest::newRow("data5") << 2001 << 12 << 31 << 365;
- QTest::newRow("data6") << 1815 << 1 << 1 << 1;
- QTest::newRow("data7") << 1815 << 12 << 31 << 365;
- QTest::newRow("data8") << 1500 << 1 << 1 << 1;
- QTest::newRow("data9") << 1500 << 12 << 31 << 365;
- QTest::newRow("data10") << -1500 << 1 << 1 << 1;
- QTest::newRow("data11") << -1500 << 12 << 31 << 365;
- QTest::newRow("data12") << -4800 << 1 << 1 << 1;
- QTest::newRow("data13") << -4800 << 12 << 31 << 365;
-}
-
-void tst_QDate::dayOfYear()
-{
- QFETCH(int, year);
- QFETCH(int, month);
- QFETCH(int, day);
- QFETCH(int, dayOfYear);
-
- QDate dt(year, month, day);
- QCOMPARE(dt.dayOfYear(), dayOfYear);
-}
-
-void tst_QDate::daysInMonth_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<int>("daysInMonth");
-
- QTest::newRow("data0") << 0 << 0 << 0 << 0;
- QTest::newRow("data1") << 2000 << 1 << 1 << 31;
- QTest::newRow("data2") << 2000 << 2 << 1 << 29;
- QTest::newRow("data3") << 2000 << 3 << 1 << 31;
- QTest::newRow("data4") << 2000 << 4 << 1 << 30;
- QTest::newRow("data5") << 2000 << 5 << 1 << 31;
- QTest::newRow("data6") << 2000 << 6 << 1 << 30;
- QTest::newRow("data7") << 2000 << 7 << 1 << 31;
- QTest::newRow("data8") << 2000 << 8 << 1 << 31;
- QTest::newRow("data9") << 2000 << 9 << 1 << 30;
- QTest::newRow("data10") << 2000 << 10 << 1 << 31;
- QTest::newRow("data11") << 2000 << 11 << 1 << 30;
- QTest::newRow("data12") << 2000 << 12 << 1 << 31;
- QTest::newRow("data13") << 2001 << 2 << 1 << 28;
- QTest::newRow("data14") << 2000 << 0 << 1 << 0;
-}
-
-void tst_QDate::daysInMonth()
-{
- QFETCH(int, year);
- QFETCH(int, month);
- QFETCH(int, day);
- QFETCH(int, daysInMonth);
-
- QDate dt(year, month, day);
- QCOMPARE(dt.daysInMonth(), daysInMonth);
-}
-
-void tst_QDate::daysInYear_data()
-{
- QTest::addColumn<QDate>("date");
- QTest::addColumn<int>("expectedDaysInYear");
-
- QTest::newRow("2000, 1, 1") << QDate(2000, 1, 1) << 366;
- QTest::newRow("2001, 1, 1") << QDate(2001, 1, 1) << 365;
- QTest::newRow("4, 1, 1") << QDate(4, 1, 1) << 366;
- QTest::newRow("5, 1, 1") << QDate(5, 1, 1) << 365;
- QTest::newRow("0, 0, 0") << QDate(0, 0, 0) << 0;
-}
-
-void tst_QDate::daysInYear()
-{
- QFETCH(QDate, date);
- QFETCH(int, expectedDaysInYear);
-
- QCOMPARE(date.daysInYear(), expectedDaysInYear);
-}
-
-void tst_QDate::getDate()
-{
- int y, m, d;
- QDate dt(2000, 1, 1);
- dt.getDate(&y, &m, &d);
- QCOMPARE(y, 2000);
- QCOMPARE(m, 1);
- QCOMPARE(d, 1);
- dt.setDate(0, 0, 0);
- dt.getDate(&y, &m, &d);
- QCOMPARE(y, 0);
- QCOMPARE(m, 0);
- QCOMPARE(d, 0);
-}
-
-void tst_QDate::weekNumber_data()
-{
- QTest::addColumn<int>("expectedWeekNum");
- QTest::addColumn<int>("expectedYearNum");
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
-
- enum { Thursday = 4 };
- bool wasLastYearLong = false; // 1999 was not a long (53-week) year
- bool isLongYear;
-
- // full 400-year cycle for Jan 1, 4 and Dec 28, 31
- for (int yr = 2000; yr < 2400; ++yr, wasLastYearLong = isLongYear) {
- QByteArray yrstr = QByteArray::number(yr);
- int wday = QDate(yr, 1, 1).dayOfWeek();
-
- // the year is 53-week long if Jan 1 is Thursday or, if it's a leap year, a Wednesday
- isLongYear = (wday == Thursday) || (QDate::isLeapYear(yr) && wday == Thursday - 1);
-
- // Jan 4 is always on week 1
- QTest::newRow(yrstr + "-01-04") << 1 << yr << yr << 1 << 4;
-
- // Dec 28 is always on the last week
- QTest::newRow(yrstr + "-12-28") << (52 + isLongYear) << yr << yr << 12 << 28;
-
- // Jan 1 is on either on week 1 or on the last week of the previous year
- QTest::newRow(yrstr + "-01-01")
- << (wday <= Thursday ? 1 : 52 + wasLastYearLong)
- << (wday <= Thursday ? yr : yr - 1)
- << yr << 1 << 1;
-
- // Dec 31 is either on the last week or week 1 of the next year
- wday = QDate(yr, 12, 31).dayOfWeek();
- QTest::newRow(yrstr + "-12-31")
- << (wday >= Thursday ? 52 + isLongYear : 1)
- << (wday >= Thursday ? yr : yr + 1)
- << yr << 12 << 31;
- }
-}
-
-void tst_QDate::weekNumber()
-{
- int yearNumber;
- QFETCH( int, year );
- QFETCH( int, month );
- QFETCH( int, day );
- QFETCH( int, expectedWeekNum );
- QFETCH( int, expectedYearNum );
- QDate dt1( year, month, day );
- QCOMPARE( dt1.weekNumber( &yearNumber ), expectedWeekNum );
- QCOMPARE( yearNumber, expectedYearNum );
-}
-
-void tst_QDate::weekNumber_invalid_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
-
- //next we fill it with data
- QTest::newRow( "data0" ) << 0 << 0 << 0;
- QTest::newRow( "data1" ) << 2001 << 1 << 32;
- QTest::newRow( "data2" ) << 1999 << 2 << 29;
-}
-
-void tst_QDate::weekNumber_invalid()
-{
- QDate dt;
- int yearNumber;
- QCOMPARE( dt.weekNumber( &yearNumber ), 0 );
-}
-
-void tst_QDate::julianDaysLimits()
-{
- qint64 min = std::numeric_limits<qint64>::min();
- qint64 max = std::numeric_limits<qint64>::max();
- qint64 minJd = Q_INT64_C(-784350574879);
- qint64 maxJd = Q_INT64_C( 784354017364);
-
- QDate maxDate = QDate::fromJulianDay(maxJd);
- QDate minDate = QDate::fromJulianDay(minJd);
- QDate zeroDate = QDate::fromJulianDay(0);
-
- QDate dt = QDate::fromJulianDay(min);
- QCOMPARE(dt.isValid(), false);
- dt = QDate::fromJulianDay(minJd - 1);
- QCOMPARE(dt.isValid(), false);
- dt = QDate::fromJulianDay(minJd);
- QCOMPARE(dt.isValid(), true);
- dt = QDate::fromJulianDay(minJd + 1);
- QCOMPARE(dt.isValid(), true);
- dt = QDate::fromJulianDay(maxJd - 1);
- QCOMPARE(dt.isValid(), true);
- dt = QDate::fromJulianDay(maxJd);
- QCOMPARE(dt.isValid(), true);
- dt = QDate::fromJulianDay(maxJd + 1);
- QCOMPARE(dt.isValid(), false);
- dt = QDate::fromJulianDay(max);
- QCOMPARE(dt.isValid(), false);
-
- dt = maxDate.addDays(1);
- QCOMPARE(dt.isValid(), false);
- dt = maxDate.addDays(0);
- QCOMPARE(dt.isValid(), true);
- dt = maxDate.addDays(-1);
- QCOMPARE(dt.isValid(), true);
- dt = maxDate.addDays(max);
- QCOMPARE(dt.isValid(), false);
- dt = maxDate.addDays(min);
- QCOMPARE(dt.isValid(), false);
-
- dt = minDate.addDays(-1);
- QCOMPARE(dt.isValid(), false);
- dt = minDate.addDays(0);
- QCOMPARE(dt.isValid(), true);
- dt = minDate.addDays(1);
- QCOMPARE(dt.isValid(), true);
- dt = minDate.addDays(min);
- QCOMPARE(dt.isValid(), false);
- dt = minDate.addDays(max);
- QCOMPARE(dt.isValid(), false);
-
- dt = zeroDate.addDays(-1);
- QCOMPARE(dt.isValid(), true);
- dt = zeroDate.addDays(0);
- QCOMPARE(dt.isValid(), true);
- dt = zeroDate.addDays(1);
- QCOMPARE(dt.isValid(), true);
- dt = zeroDate.addDays(min);
- QCOMPARE(dt.isValid(), false);
- dt = zeroDate.addDays(max);
- QCOMPARE(dt.isValid(), false);
-}
-
-void tst_QDate::addDays()
-{
- QFETCH( int, year );
- QFETCH( int, month );
- QFETCH( int, day );
- QFETCH( int, amountToAdd );
- QFETCH( int, expectedYear );
- QFETCH( int, expectedMonth );
- QFETCH( int, expectedDay );
-
- QDate dt( year, month, day );
- dt = dt.addDays( amountToAdd );
-
- QCOMPARE( dt.year(), expectedYear );
- QCOMPARE( dt.month(), expectedMonth );
- QCOMPARE( dt.day(), expectedDay );
-}
-
-void tst_QDate::addDays_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<int>("amountToAdd");
- QTest::addColumn<int>("expectedYear");
- QTest::addColumn<int>("expectedMonth");
- QTest::addColumn<int>("expectedDay");
-
- QTest::newRow( "data0" ) << 2000 << 1 << 1 << 1 << 2000 << 1 << 2;
- QTest::newRow( "data1" ) << 2000 << 1 << 31 << 1 << 2000 << 2 << 1;
- QTest::newRow( "data2" ) << 2000 << 2 << 28 << 1 << 2000 << 2 << 29;
- QTest::newRow( "data3" ) << 2000 << 2 << 29 << 1 << 2000 << 3 << 1;
- QTest::newRow( "data4" ) << 2000 << 12 << 31 << 1 << 2001 << 1 << 1;
- QTest::newRow( "data5" ) << 2001 << 2 << 28 << 1 << 2001 << 3 << 1;
- QTest::newRow( "data6" ) << 2001 << 2 << 28 << 30 << 2001 << 3 << 30;
- QTest::newRow( "data7" ) << 2001 << 3 << 30 << 5 << 2001 << 4 << 4;
-
- QTest::newRow( "data8" ) << 2000 << 1 << 1 << -1 << 1999 << 12 << 31;
- QTest::newRow( "data9" ) << 2000 << 1 << 31 << -1 << 2000 << 1 << 30;
- QTest::newRow( "data10" ) << 2000 << 2 << 28 << -1 << 2000 << 2 << 27;
- QTest::newRow( "data11" ) << 2001 << 2 << 28 << -30 << 2001 << 1 << 29;
-
- QTest::newRow( "data12" ) << -4713 << 1 << 2 << -2 << -4714 << 12 << 31;
- QTest::newRow( "data13" ) << -4713 << 1 << 2 << 2 << -4713 << 1 << 4;
-
- QTest::newRow( "invalid" ) << 0 << 0 << 0 << 1 << 0 << 0 << 0;
-}
-
-void tst_QDate::addMonths()
-{
- QFETCH( int, year );
- QFETCH( int, month );
- QFETCH( int, day );
- QFETCH( int, amountToAdd );
- QFETCH( int, expectedYear );
- QFETCH( int, expectedMonth );
- QFETCH( int, expectedDay );
-
- QDate dt( year, month, day );
- dt = dt.addMonths( amountToAdd );
-
- QCOMPARE( dt.year(), expectedYear );
- QCOMPARE( dt.month(), expectedMonth );
- QCOMPARE( dt.day(), expectedDay );
-}
-
-void tst_QDate::addMonths_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<int>("amountToAdd");
- QTest::addColumn<int>("expectedYear");
- QTest::addColumn<int>("expectedMonth");
- QTest::addColumn<int>("expectedDay");
-
- QTest::newRow( "data0" ) << 2000 << 1 << 1 << 1 << 2000 << 2 << 1;
- QTest::newRow( "data1" ) << 2000 << 1 << 31 << 1 << 2000 << 2 << 29;
- QTest::newRow( "data2" ) << 2000 << 2 << 28 << 1 << 2000 << 3 << 28;
- QTest::newRow( "data3" ) << 2000 << 2 << 29 << 1 << 2000 << 3 << 29;
- QTest::newRow( "data4" ) << 2000 << 12 << 31 << 1 << 2001 << 1 << 31;
- QTest::newRow( "data5" ) << 2001 << 2 << 28 << 1 << 2001 << 3 << 28;
- QTest::newRow( "data6" ) << 2001 << 2 << 28 << 12 << 2002 << 2 << 28;
- QTest::newRow( "data7" ) << 2000 << 2 << 29 << 12 << 2001 << 2 << 28;
- QTest::newRow( "data8" ) << 2000 << 10 << 15 << 4 << 2001 << 2 << 15;
-
- QTest::newRow( "data9" ) << 2000 << 1 << 1 << -1 << 1999 << 12 << 1;
- QTest::newRow( "data10" ) << 2000 << 1 << 31 << -1 << 1999 << 12 << 31;
- QTest::newRow( "data11" ) << 2000 << 12 << 31 << -1 << 2000 << 11 << 30;
- QTest::newRow( "data12" ) << 2001 << 2 << 28 << -12 << 2000 << 2 << 28;
- QTest::newRow( "data13" ) << 2000 << 1 << 31 << -7 << 1999 << 6 << 30;
- QTest::newRow( "data14" ) << 2000 << 2 << 29 << -12 << 1999 << 2 << 28;
-
- // year sign change:
- QTest::newRow( "data15" ) << 1 << 1 << 1 << -1 << -1 << 12 << 1;
- QTest::newRow( "data16" ) << 1 << 1 << 1 << -12 << -1 << 1 << 1;
- QTest::newRow( "data17" ) << -1 << 12 << 1 << 1 << 1 << 1 << 1;
- QTest::newRow( "data18" ) << -1 << 1 << 1 << 12 << 1 << 1 << 1;
- QTest::newRow( "data19" ) << -2 << 1 << 1 << 12 << -1 << 1 << 1;
-
- QTest::newRow( "invalid" ) << 0 << 0 << 0 << 1 << 0 << 0 << 0;
-}
-
-void tst_QDate::addYears()
-{
- QFETCH( int, year );
- QFETCH( int, month );
- QFETCH( int, day );
- QFETCH( int, amountToAdd );
- QFETCH( int, expectedYear );
- QFETCH( int, expectedMonth );
- QFETCH( int, expectedDay );
-
- QDate dt( year, month, day );
- dt = dt.addYears( amountToAdd );
-
- QCOMPARE( dt.year(), expectedYear );
- QCOMPARE( dt.month(), expectedMonth );
- QCOMPARE( dt.day(), expectedDay );
-}
-
-void tst_QDate::addYears_data()
-{
- QTest::addColumn<int>("year");
- QTest::addColumn<int>("month");
- QTest::addColumn<int>("day");
- QTest::addColumn<int>("amountToAdd");
- QTest::addColumn<int>("expectedYear");
- QTest::addColumn<int>("expectedMonth");
- QTest::addColumn<int>("expectedDay");
-
- QTest::newRow( "data0" ) << 2000 << 1 << 1 << 1 << 2001 << 1 << 1;
- QTest::newRow( "data1" ) << 2000 << 1 << 31 << 1 << 2001 << 1 << 31;
- QTest::newRow( "data2" ) << 2000 << 2 << 28 << 1 << 2001 << 2 << 28;
- QTest::newRow( "data3" ) << 2000 << 2 << 29 << 1 << 2001 << 2 << 28;
- QTest::newRow( "data4" ) << 2000 << 12 << 31 << 1 << 2001 << 12 << 31;
- QTest::newRow( "data5" ) << 2001 << 2 << 28 << 3 << 2004 << 2 << 28;
- QTest::newRow( "data6" ) << 2000 << 2 << 29 << 4 << 2004 << 2 << 29;
-
- QTest::newRow( "data7" ) << 2000 << 1 << 31 << -1 << 1999 << 1 << 31;
- QTest::newRow( "data9" ) << 2000 << 2 << 29 << -1 << 1999 << 2 << 28;
- QTest::newRow( "data10" ) << 2000 << 12 << 31 << -1 << 1999 << 12 << 31;
- QTest::newRow( "data11" ) << 2001 << 2 << 28 << -3 << 1998 << 2 << 28;
- QTest::newRow( "data12" ) << 2000 << 2 << 29 << -4 << 1996 << 2 << 29;
- QTest::newRow( "data13" ) << 2000 << 2 << 29 << -5 << 1995 << 2 << 28;
-
- QTest::newRow( "data14" ) << 2000 << 1 << 1 << -1999 << 1 << 1 << 1;
- QTest::newRow( "data15" ) << 2000 << 1 << 1 << -2000 << -1 << 1 << 1;
- QTest::newRow( "data16" ) << 2000 << 1 << 1 << -2001 << -2 << 1 << 1;
- QTest::newRow( "data17" ) << -2000 << 1 << 1 << 1999 << -1 << 1 << 1;
- QTest::newRow( "data18" ) << -2000 << 1 << 1 << 2000 << 1 << 1 << 1;
- QTest::newRow( "data19" ) << -2000 << 1 << 1 << 2001 << 2 << 1 << 1;
-
- QTest::newRow( "invalid" ) << 0 << 0 << 0 << 1 << 0 << 0 << 0;
-}
-
-void tst_QDate::daysTo()
-{
- qint64 minJd = Q_INT64_C(-784350574879);
- qint64 maxJd = Q_INT64_C( 784354017364);
-
- QDate dt1(2000, 1, 1);
- QDate dt2(2000, 1, 5);
- QCOMPARE(dt1.daysTo(dt2), (qint64) 4);
- QCOMPARE(dt2.daysTo(dt1), (qint64) -4);
-
- dt1.setDate(0, 0, 0);
- QCOMPARE(dt1.daysTo(dt2), (qint64) 0);
- dt1.setDate(2000, 1, 1);
- dt2.setDate(0, 0, 0);
- QCOMPARE(dt1.daysTo(dt2), (qint64) 0);
-
-
- QDate maxDate = QDate::fromJulianDay(maxJd);
- QDate minDate = QDate::fromJulianDay(minJd);
- QDate zeroDate = QDate::fromJulianDay(0);
-
- QCOMPARE(maxDate.daysTo(minDate), minJd - maxJd);
- QCOMPARE(minDate.daysTo(maxDate), maxJd - minJd);
- QCOMPARE(maxDate.daysTo(zeroDate), -maxJd);
- QCOMPARE(zeroDate.daysTo(maxDate), maxJd);
- QCOMPARE(minDate.daysTo(zeroDate), -minJd);
- QCOMPARE(zeroDate.daysTo(minDate), minJd);
-}
-
-void tst_QDate::operator_eq_eq_data()
-{
- QTest::addColumn<QDate>("d1");
- QTest::addColumn<QDate>("d2");
- QTest::addColumn<bool>("expectEqual");
-
- QTest::newRow("data0") << QDate(2000,1,2) << QDate(2000,1,2) << true;
- QTest::newRow("data1") << QDate(2001,12,5) << QDate(2001,12,5) << true;
- QTest::newRow("data2") << QDate(2001,12,5) << QDate(2001,12,5) << true;
- QTest::newRow("data3") << QDate(2001,12,5) << QDate(2002,12,5) << false;
-
- QDate date1(1900, 1, 1);
- QDate date2 = date1.addDays(1);
- QDate date3 = date1.addDays(-1);
- QDate date4 = date1.addMonths(1);
- QDate date5 = date1.addMonths(-1);
- QDate date6 = date1.addYears(1);
- QDate date7 = date1.addYears(-1);
-
- QTest::newRow("data4") << date2 << date3 << false;
- QTest::newRow("data5") << date4 << date5 << false;
- QTest::newRow("data6") << date6 << date7 << false;
- QTest::newRow("data7") << date1 << date2 << false;
- QTest::newRow("data8") << date1 << date3 << false;
- QTest::newRow("data9") << date1 << date4 << false;
- QTest::newRow("data10") << date1 << date5 << false;
- QTest::newRow("data11") << date1 << date6 << false;
- QTest::newRow("data12") << date1 << date7 << false;
-}
-
-void tst_QDate::operator_eq_eq()
-{
- QFETCH(QDate, d1);
- QFETCH(QDate, d2);
- QFETCH(bool, expectEqual);
-
- bool equal = d1 == d2;
- QCOMPARE(equal, expectEqual);
- bool notEqual = d1 != d2;
- QCOMPARE(notEqual, !expectEqual);
-
- if (equal)
- QVERIFY(qHash(d1) == qHash(d2));
-}
-
-void tst_QDate::operator_lt()
-{
- QDate d1(2000,1,2);
- QDate d2(2000,1,2);
- QVERIFY( !(d1 < d2) );
-
- d1 = QDate(2001,12,4);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 < d2 );
-
- d1 = QDate(2001,11,5);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 < d2 );
-
- d1 = QDate(2000,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 < d2 );
-
- d1 = QDate(2002,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 < d2) );
-
- d1 = QDate(2001,12,5);
- d2 = QDate(2001,11,5);
- QVERIFY( !(d1 < d2) );
-
- d1 = QDate(2001,12,6);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 < d2) );
-}
-
-void tst_QDate::operator_gt()
-{
- QDate d1(2000,1,2);
- QDate d2(2000,1,2);
- QVERIFY( !(d1 > d2) );
-
- d1 = QDate(2001,12,4);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 > d2) );
-
- d1 = QDate(2001,11,5);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 > d2) );
-
- d1 = QDate(2000,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 > d2) );
-
- d1 = QDate(2002,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 > d2 );
-
- d1 = QDate(2001,12,5);
- d2 = QDate(2001,11,5);
- QVERIFY( d1 > d2 );
-
- d1 = QDate(2001,12,6);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 > d2 );
-}
-
-void tst_QDate::operator_lt_eq()
-{
- QDate d1(2000,1,2);
- QDate d2(2000,1,2);
- QVERIFY( d1 <= d2 );
-
- d1 = QDate(2001,12,4);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 <= d2 );
-
- d1 = QDate(2001,11,5);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 <= d2 );
-
- d1 = QDate(2000,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 <= d2 );
-
- d1 = QDate(2002,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 <= d2) );
-
- d1 = QDate(2001,12,5);
- d2 = QDate(2001,11,5);
- QVERIFY( !(d1 <= d2) );
-
- d1 = QDate(2001,12,6);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 <= d2) );
-}
-
-void tst_QDate::operator_gt_eq()
-{
- QDate d1(2000,1,2);
- QDate d2(2000,1,2);
- QVERIFY( d1 >= d2 );
-
- d1 = QDate(2001,12,4);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 >= d2) );
-
- d1 = QDate(2001,11,5);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 >= d2) );
-
- d1 = QDate(2000,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( !(d1 >= d2) );
-
- d1 = QDate(2002,12,5);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 >= d2 );
-
- d1 = QDate(2001,12,5);
- d2 = QDate(2001,11,5);
- QVERIFY( d1 >= d2 );
-
- d1 = QDate(2001,12,6);
- d2 = QDate(2001,12,5);
- QVERIFY( d1 >= d2 );
-}
-
-Q_DECLARE_METATYPE(QDataStream::Version)
-
-void tst_QDate::operator_insert_extract_data()
-{
- QTest::addColumn<QDate>("date");
- QTest::addColumn<QDataStream::Version>("dataStreamVersion");
-
- QMap<QDataStream::Version, QString> versionsToTest;
- versionsToTest.insert(QDataStream::Qt_1_0, QString::fromLatin1("Qt_1_0"));
- versionsToTest.insert(QDataStream::Qt_2_0, QString::fromLatin1("Qt_2_0"));
- versionsToTest.insert(QDataStream::Qt_2_1, QString::fromLatin1("Qt_2_1"));
- versionsToTest.insert(QDataStream::Qt_3_0, QString::fromLatin1("Qt_3_0"));
- versionsToTest.insert(QDataStream::Qt_3_1, QString::fromLatin1("Qt_3_1"));
- versionsToTest.insert(QDataStream::Qt_3_3, QString::fromLatin1("Qt_3_3"));
- versionsToTest.insert(QDataStream::Qt_4_0, QString::fromLatin1("Qt_4_0"));
- versionsToTest.insert(QDataStream::Qt_4_1, QString::fromLatin1("Qt_4_1"));
- versionsToTest.insert(QDataStream::Qt_4_2, QString::fromLatin1("Qt_4_2"));
- versionsToTest.insert(QDataStream::Qt_4_3, QString::fromLatin1("Qt_4_3"));
- versionsToTest.insert(QDataStream::Qt_4_4, QString::fromLatin1("Qt_4_4"));
- versionsToTest.insert(QDataStream::Qt_4_5, QString::fromLatin1("Qt_4_5"));
- versionsToTest.insert(QDataStream::Qt_4_6, QString::fromLatin1("Qt_4_6"));
- versionsToTest.insert(QDataStream::Qt_4_7, QString::fromLatin1("Qt_4_7"));
- versionsToTest.insert(QDataStream::Qt_4_8, QString::fromLatin1("Qt_4_8"));
- versionsToTest.insert(QDataStream::Qt_4_9, QString::fromLatin1("Qt_4_9"));
- versionsToTest.insert(QDataStream::Qt_5_0, QString::fromLatin1("Qt_5_0"));
-
- for (QMap<QDataStream::Version, QString>::ConstIterator it = versionsToTest.constBegin();
- it != versionsToTest.constEnd(); ++it) {
- const QString &version(it.value());
- QTest::newRow(("(invalid) " + version).toLocal8Bit().constData()) << invalidDate() << it.key();
- QTest::newRow(("(1, 1, 1) " + version).toLocal8Bit().constData()) << QDate(1, 1, 1) << it.key();
- QTest::newRow(("(-1, 1, 1) " + version).toLocal8Bit().constData()) << QDate(-1, 1, 1) << it.key();
- QTest::newRow(("(1995, 5, 20) " + version).toLocal8Bit().constData()) << QDate(1995, 5, 20) << it.key();
-
- // Test minimums for quint32/qint64.
- if (it.key() >= QDataStream::Qt_5_0)
- QTest::newRow(("(-4714, 11, 24) " + version).toLocal8Bit().constData()) << QDate(-4714, 11, 24) << it.key();
- else
- QTest::newRow(("(-4713, 1, 2) " + version).toLocal8Bit().constData()) << QDate(-4713, 1, 2) << it.key();
- }
-}
-
-void tst_QDate::operator_insert_extract()
-{
- QFETCH(QDate, date);
- QFETCH(QDataStream::Version, dataStreamVersion);
-
- QByteArray byteArray;
- QDataStream dataStream(&byteArray, QIODevice::ReadWrite);
- dataStream.setVersion(dataStreamVersion);
- dataStream << date;
- dataStream.device()->reset();
- QDate deserialised;
- dataStream >> deserialised;
- QCOMPARE(dataStream.status(), QDataStream::Ok);
-
- QCOMPARE(deserialised, date);
-}
-
-void tst_QDate::fromStringDateFormat_data()
-{
- QTest::addColumn<QString>("dateStr");
- QTest::addColumn<Qt::DateFormat>("dateFormat");
- QTest::addColumn<QDate>("expectedDate");
-
- QTest::newRow("text0") << QString("Sat May 20 1995") << Qt::TextDate << QDate(1995, 5, 20);
- QTest::newRow("text1") << QString("Tue Dec 17 2002") << Qt::TextDate << QDate(2002, 12, 17);
- QTest::newRow("text2") << QDate(1999, 11, 14).toString(Qt::TextDate) << Qt::TextDate << QDate(1999, 11, 14);
- QTest::newRow("text3") << QString("xxx Jan 1 0999") << Qt::TextDate << QDate(999, 1, 1);
- QTest::newRow("text3b") << QString("xxx Jan 1 999") << Qt::TextDate << QDate(999, 1, 1);
- QTest::newRow("text4") << QString("xxx Jan 1 12345") << Qt::TextDate << QDate(12345, 1, 1);
- QTest::newRow("text5") << QString("xxx Jan 1 -0001") << Qt::TextDate << QDate(-1, 1, 1);
- QTest::newRow("text6") << QString("xxx Jan 1 -4712") << Qt::TextDate << QDate(-4712, 1, 1);
- QTest::newRow("text7") << QString("xxx Nov 25 -4713") << Qt::TextDate << QDate(-4713, 11, 25);
- QTest::newRow("text, empty") << QString() << Qt::TextDate << QDate();
- QTest::newRow("text, 3 part") << QString("part1 part2 part3") << Qt::TextDate << QDate();
- QTest::newRow("text, invalid month name") << QString("Wed BabytownFrolics 8 2012") << Qt::TextDate << QDate();
- QTest::newRow("text, invalid day") << QString("Wed May Wilhelm 2012") << Qt::TextDate << QDate();
- QTest::newRow("text, invalid year") << QString("Wed May 8 Cats") << Qt::TextDate << QDate();
-
- QTest::newRow("iso0") << QString("1995-05-20") << Qt::ISODate << QDate(1995, 5, 20);
- QTest::newRow("iso1") << QString("2002-12-17") << Qt::ISODate << QDate(2002, 12, 17);
- QTest::newRow("iso2") << QDate(1999, 11, 14).toString(Qt::ISODate) << Qt::ISODate << QDate(1999, 11, 14);
- QTest::newRow("iso3") << QString("0999-01-01") << Qt::ISODate << QDate(999, 1, 1);
- QTest::newRow("iso3b") << QString("0999-01-01") << Qt::ISODate << QDate(999, 1, 1);
- QTest::newRow("iso4") << QString("2000101101") << Qt::ISODate << QDate();
- QTest::newRow("iso5") << QString("2000/01/01") << Qt::ISODate << QDate(2000, 1, 1);
- QTest::newRow("iso6") << QString("2000-01-01 blah") << Qt::ISODate << QDate(2000, 1, 1);
- QTest::newRow("iso7") << QString("2000-01-011blah") << Qt::ISODate << QDate();
- QTest::newRow("iso8") << QString("2000-01-01blah") << Qt::ISODate << QDate(2000, 1, 1);
- QTest::newRow("iso9") << QString("-001-01-01") << Qt::ISODate << QDate();
- QTest::newRow("iso10") << QString("99999-01-01") << Qt::ISODate << QDate();
-
- // Test Qt::RFC2822Date format (RFC 2822).
- QTest::newRow("RFC 2822") << QString::fromLatin1("13 Feb 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QDate(1987, 2, 13);
- QTest::newRow("RFC 2822 with day") << QString::fromLatin1("Thu, 01 Jan 1970 00:12:34 +0000")
- << Qt::RFC2822Date << QDate(1970, 1, 1);
- // No timezone
- QTest::newRow("RFC 2822 no timezone") << QString::fromLatin1("01 Jan 1970 00:12:34")
- << Qt::RFC2822Date << QDate(1970, 1, 1);
- // No time specified
- QTest::newRow("RFC 2822 date only") << QString::fromLatin1("01 Nov 2002")
- << Qt::RFC2822Date << QDate(2002, 11, 1);
- QTest::newRow("RFC 2822 with day date only") << QString::fromLatin1("Fri, 01 Nov 2002")
- << Qt::RFC2822Date << QDate(2002, 11, 1);
- // Test invalid month, day, year
- QTest::newRow("RFC 2822 invalid month name") << QString::fromLatin1("13 Fev 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 2822 invalid day") << QString::fromLatin1("36 Fev 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 2822 invalid year") << QString::fromLatin1("13 Fev 0000 13:24:51 +0100")
- << Qt::RFC2822Date << QDate();
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("RFC 2822 invalid character at end") << QString::fromLatin1("01 Jan 2012 08:00:00 +0100!")
- << Qt::RFC2822Date << QDate(2012, 1, 1);
- QTest::newRow("RFC 2822 invalid character at front") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 2822 invalid character both ends") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000!")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 2822 invalid character at front, 2 at back") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000..")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 2822 invalid character 2 at front") << QString::fromLatin1("!!01 Jan 2012 08:00:00 +0000")
- << Qt::RFC2822Date << QDate();
-
- // Test Qt::RFC2822Date format (RFC 850 and 1036).
- QTest::newRow("RFC 850 and 1036") << QString::fromLatin1("Fri Feb 13 13:24:51 1987 +0100")
- << Qt::RFC2822Date << QDate(1987, 2, 13);
- // No timezone
- QTest::newRow("RFC 850 and 1036 no timezone") << QString::fromLatin1("Thu Jan 01 00:12:34 1970")
- << Qt::RFC2822Date << QDate(1970, 1, 1);
- // No time specified
- QTest::newRow("RFC 850 and 1036 date only") << QString::fromLatin1("Fri Nov 01 2002")
- << Qt::RFC2822Date << QDate(2002, 11, 1);
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("RFC 850 and 1036 invalid character at end") << QString::fromLatin1("Sun Jan 01 08:00:00 2012 +0100!")
- << Qt::RFC2822Date << QDate(2012, 1, 1);
- QTest::newRow("RFC 850 and 1036 invalid character at front") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 850 and 1036 invalid character both ends") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000!")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 850 and 1036 invalid character at front, 2 at back") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000..")
- << Qt::RFC2822Date << QDate();
- QTest::newRow("RFC 850 and 1036 invalid character 2 at front") << QString::fromLatin1("!!Sun Jan 01 08:00:00 2012 +0000")
- << Qt::RFC2822Date << QDate();
-
- QTest::newRow("RFC empty") << QString::fromLatin1("") << Qt::RFC2822Date << QDate();
-}
-
-void tst_QDate::fromStringDateFormat()
-{
- QFETCH(QString, dateStr);
- QFETCH(Qt::DateFormat, dateFormat);
- QFETCH(QDate, expectedDate);
-
- QCOMPARE(QDate::fromString(dateStr, dateFormat), expectedDate);
-}
-
-void tst_QDate::fromStringFormat_data()
-{
- QTest::addColumn<QString>("string");
- QTest::addColumn<QString>("format");
- QTest::addColumn<QDate>("expected");
-
- // Undo this (inline the C-locale versions) for ### Qt 6
- // Get localized names:
- QString january = QDate::longMonthName(1);
- QString february = QDate::longMonthName(2);
- QString march = QDate::longMonthName(3);
- QString august = QDate::longMonthName(8);
- QString mon = QDate::shortDayName(1);
- QString monday = QDate::longDayName(1);
- QString tuesday = QDate::longDayName(2);
- QString wednesday = QDate::longDayName(3);
- QString thursday = QDate::longDayName(4);
- QString friday = QDate::longDayName(5);
- QString saturday = QDate::longDayName(6);
- QString sunday = QDate::longDayName(7);
-
- QTest::newRow("data0") << QString("") << QString("") << defDate();
- QTest::newRow("data1") << QString(" ") << QString("") << invalidDate();
- QTest::newRow("data2") << QString(" ") << QString(" ") << defDate();
- QTest::newRow("data3") << QString("-%$%#") << QString("$*(#@") << invalidDate();
- QTest::newRow("data4") << QString("d") << QString("'d'") << defDate();
- QTest::newRow("data5") << QString("101010") << QString("dMyy") << QDate(1910, 10, 10);
- QTest::newRow("data6") << QString("101010b") << QString("dMyy") << invalidDate();
- QTest::newRow("data7") << january << QString("MMMM") << defDate();
- QTest::newRow("data8") << QString("ball") << QString("balle") << invalidDate();
- QTest::newRow("data9") << QString("balleh") << QString("balleh") << defDate();
- QTest::newRow("data10") << QString("10.01.1") << QString("M.dd.d") << QDate(defDate().year(), 10, 1);
- QTest::newRow("data11") << QString("-1.01.1") << QString("M.dd.d") << invalidDate();
- QTest::newRow("data12") << QString("11010") << QString("dMMyy") << invalidDate();
- QTest::newRow("data13") << QString("-2") << QString("d") << invalidDate();
- QTest::newRow("data14") << QString("132") << QString("Md") << invalidDate();
- QTest::newRow("data15") << february << QString("MMMM") << QDate(defDate().year(), 2, 1);
-
- QString date = mon + QLatin1Char(' ') + august + " 8 2005";
- QTest::newRow("data16") << date << QString("ddd MMMM d yyyy") << QDate(2005, 8, 8);
- QTest::newRow("data17") << QString("2000:00") << QString("yyyy:yy") << QDate(2000, 1, 1);
- QTest::newRow("data18") << QString("1999:99") << QString("yyyy:yy") << QDate(1999, 1, 1);
- QTest::newRow("data19") << QString("2099:99") << QString("yyyy:yy") << QDate(2099, 1, 1);
- QTest::newRow("data20") << QString("2001:01") << QString("yyyy:yy") << QDate(2001, 1, 1);
- QTest::newRow("data21") << QString("99") << QString("yy") << QDate(1999, 1, 1);
- QTest::newRow("data22") << QString("01") << QString("yy") << QDate(1901, 1, 1);
-
- QTest::newRow("data23") << monday << QString("dddd") << QDate(1900, 1, 1);
- QTest::newRow("data24") << tuesday << QString("dddd") << QDate(1900, 1, 2);
- QTest::newRow("data25") << wednesday << QString("dddd") << QDate(1900, 1, 3);
- QTest::newRow("data26") << thursday << QString("dddd") << QDate(1900, 1, 4);
- QTest::newRow("data27") << friday << QString("dddd") << QDate(1900, 1, 5);
- QTest::newRow("data28") << saturday << QString("dddd") << QDate(1900, 1, 6);
- QTest::newRow("data29") << sunday << QString("dddd") << QDate(1900, 1, 7);
-
- QTest::newRow("data30") << monday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 2);
- QTest::newRow("data31") << tuesday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 3);
- QTest::newRow("data32") << wednesday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 4);
- QTest::newRow("data33") << thursday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 5);
- QTest::newRow("data34") << friday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 6);
- QTest::newRow("data35") << saturday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 7);
- QTest::newRow("data36") << sunday + " 2006" << QString("dddd yyyy") << QDate(2006, 1, 1);
-
- QTest::newRow("data37") << tuesday + " 2007 " + march << QString("dddd yyyy MMMM") << QDate(2007, 3, 6);
-
- QTest::newRow("data38") << QString("21052006") << QString("ddMMyyyy") << QDate(2006,5,21);
- QTest::newRow("data39") << QString("210506") << QString("ddMMyy") << QDate(1906,5,21);
- QTest::newRow("data40") << QString("21/5/2006") << QString("d/M/yyyy") << QDate(2006,5,21);
- QTest::newRow("data41") << QString("21/5/06") << QString("d/M/yy") << QDate(1906,5,21);
- QTest::newRow("data42") << QString("20060521") << QString("yyyyMMdd") << QDate(2006,5,21);
- QTest::newRow("data43") << QString("060521") << QString("yyMMdd") << QDate(1906,5,21);
- QTest::newRow("lateMarch") << QString("9999-03-06") << QString("yyyy-MM-dd") << QDate(9999, 3, 6);
- QTest::newRow("late") << QString("9999-12-31") << QString("yyyy-MM-dd") << QDate(9999, 12, 31);
-}
-
-
-void tst_QDate::fromStringFormat()
-{
- QFETCH(QString, string);
- QFETCH(QString, format);
- QFETCH(QDate, expected);
-
- QDate dt = QDate::fromString(string, format);
- QCOMPARE(dt, expected);
-}
-
-void tst_QDate::toStringFormat_data()
-{
- QTest::addColumn<QDate>("t");
- QTest::addColumn<QString>("format");
- QTest::addColumn<QString>("str");
-
- QTest::newRow( "data0" ) << QDate(1995,5,20) << QString("d-M-yy") << QString("20-5-95");
- QTest::newRow( "data1" ) << QDate(2002,12,17) << QString("dd-MM-yyyy") << QString("17-12-2002");
- QTest::newRow( "data2" ) << QDate(1995,5,20) << QString("M-yy") << QString("5-95");
- QTest::newRow( "data3" ) << QDate(2002,12,17) << QString("dd") << QString("17");
- QTest::newRow( "data4" ) << QDate() << QString("dd-mm-yyyy") << QString();
-}
-
-void tst_QDate::toStringFormat()
-{
- QFETCH( QDate, t );
- QFETCH( QString, format );
- QFETCH( QString, str );
-
- QCOMPARE( t.toString( format ), str );
-}
-
-void tst_QDate::toStringDateFormat_data()
-{
- QTest::addColumn<QDate>("date");
- QTest::addColumn<Qt::DateFormat>("format");
- QTest::addColumn<QString>("expectedStr");
-
- QTest::newRow("data0") << QDate(1,1,1) << Qt::ISODate << QString("0001-01-01");
- QTest::newRow("data1") << QDate(11,1,1) << Qt::ISODate << QString("0011-01-01");
- QTest::newRow("data2") << QDate(111,1,1) << Qt::ISODate << QString("0111-01-01");
- QTest::newRow("data3") << QDate(1974,12,1) << Qt::ISODate << QString("1974-12-01");
- QTest::newRow("year < 0") << QDate(-1,1,1) << Qt::ISODate << QString();
- QTest::newRow("year > 9999") << QDate(-1,1,1) << Qt::ISODate << QString();
- QTest::newRow("RFC2822Date") << QDate(1974,12,1) << Qt::RFC2822Date << QString("01 Dec 1974");
- QTest::newRow("ISODateWithMs") << QDate(1974,12,1) << Qt::ISODateWithMs << QString("1974-12-01");
-}
-
-void tst_QDate::toStringDateFormat()
-{
- QFETCH(QDate, date);
- QFETCH(Qt::DateFormat, format);
- QFETCH(QString, expectedStr);
-
- QCOMPARE(date.toString(Qt::SystemLocaleShortDate), QLocale::system().toString(date, QLocale::ShortFormat));
- QCOMPARE(date.toString(Qt::DefaultLocaleShortDate), QLocale().toString(date, QLocale::ShortFormat));
- QCOMPARE(date.toString(Qt::SystemLocaleLongDate), QLocale::system().toString(date, QLocale::LongFormat));
- QCOMPARE(date.toString(Qt::DefaultLocaleLongDate), QLocale().toString(date, QLocale::LongFormat));
- QLocale::setDefault(QLocale::German);
- QCOMPARE(date.toString(Qt::SystemLocaleShortDate), QLocale::system().toString(date, QLocale::ShortFormat));
- QCOMPARE(date.toString(Qt::DefaultLocaleShortDate), QLocale().toString(date, QLocale::ShortFormat));
- QCOMPARE(date.toString(Qt::SystemLocaleLongDate), QLocale::system().toString(date, QLocale::LongFormat));
- QCOMPARE(date.toString(Qt::DefaultLocaleLongDate), QLocale().toString(date, QLocale::LongFormat));
-
- QCOMPARE(date.toString(format), expectedStr);
-}
-
-void tst_QDate::isLeapYear()
-{
- QVERIFY(QDate::isLeapYear(-4801));
- QVERIFY(!QDate::isLeapYear(-4800));
- QVERIFY(QDate::isLeapYear(-4445));
- QVERIFY(!QDate::isLeapYear(-4444));
- QVERIFY(!QDate::isLeapYear(-6));
- QVERIFY(QDate::isLeapYear(-5));
- QVERIFY(!QDate::isLeapYear(-4));
- QVERIFY(!QDate::isLeapYear(-3));
- QVERIFY(!QDate::isLeapYear(-2));
- QVERIFY(QDate::isLeapYear(-1));
- QVERIFY(!QDate::isLeapYear(0)); // Doesn't exist
- QVERIFY(!QDate::isLeapYear(1));
- QVERIFY(!QDate::isLeapYear(2));
- QVERIFY(!QDate::isLeapYear(3));
- QVERIFY(QDate::isLeapYear(4));
- QVERIFY(!QDate::isLeapYear(7));
- QVERIFY(QDate::isLeapYear(8));
- QVERIFY(!QDate::isLeapYear(100));
- QVERIFY(QDate::isLeapYear(400));
- QVERIFY(!QDate::isLeapYear(700));
- QVERIFY(!QDate::isLeapYear(1500));
- QVERIFY(QDate::isLeapYear(1600));
- QVERIFY(!QDate::isLeapYear(1700));
- QVERIFY(!QDate::isLeapYear(1800));
- QVERIFY(!QDate::isLeapYear(1900));
- QVERIFY(QDate::isLeapYear(2000));
- QVERIFY(!QDate::isLeapYear(2100));
- QVERIFY(!QDate::isLeapYear(2200));
- QVERIFY(!QDate::isLeapYear(2300));
- QVERIFY(QDate::isLeapYear(2400));
- QVERIFY(!QDate::isLeapYear(2500));
- QVERIFY(!QDate::isLeapYear(2600));
- QVERIFY(!QDate::isLeapYear(2700));
- QVERIFY(QDate::isLeapYear(2800));
-
- for (int i = -4713; i <= 10000; ++i) {
- if (i == 0)
- continue;
- QVERIFY(!QDate(i, 2, 29).isValid() == !QDate::isLeapYear(i));
- }
-}
-
-void tst_QDate::yearsZeroToNinetyNine()
-{
- {
- QDate dt(-1, 2, 3);
- QCOMPARE(dt.year(), -1);
- QCOMPARE(dt.month(), 2);
- QCOMPARE(dt.day(), 3);
- }
-
- {
- QDate dt(1, 2, 3);
- QCOMPARE(dt.year(), 1);
- QCOMPARE(dt.month(), 2);
- QCOMPARE(dt.day(), 3);
- }
-
- {
- QDate dt(99, 2, 3);
- QCOMPARE(dt.year(), 99);
- QCOMPARE(dt.month(), 2);
- QCOMPARE(dt.day(), 3);
- }
-
- QVERIFY(!QDate::isValid(0, 2, 3));
- QVERIFY(QDate::isValid(1, 2, 3));
- QVERIFY(QDate::isValid(-1, 2, 3));
-
-#if QT_DEPRECATED_SINCE(5,0)
- {
- QDate dt;
- dt.setYMD(1, 2, 3);
- QCOMPARE(dt.year(), 1901);
- QCOMPARE(dt.month(), 2);
- QCOMPARE(dt.day(), 3);
- }
-#endif
-
- {
- QDate dt;
- dt.setDate(1, 2, 3);
- QCOMPARE(dt.year(), 1);
- QCOMPARE(dt.month(), 2);
- QCOMPARE(dt.day(), 3);
-
- dt.setDate(0, 2, 3);
- QVERIFY(!dt.isValid());
- }
-}
-
-
-void tst_QDate::negativeYear() const
-{
- QDate y(-20, 3, 4);
- QVERIFY(y.isValid());
- QCOMPARE(y.year(), -20);
-}
-
-void tst_QDate::printNegativeYear() const
-{
- {
- QDate date(-500, 3, 4);
- QVERIFY(date.isValid());
- QCOMPARE(date.toString(QLatin1String("yyyy")), QString::fromLatin1("-0500"));
- }
-
- {
- QDate date(-10, 3, 4);
- QVERIFY(date.isValid());
- QCOMPARE(date.toString(QLatin1String("yyyy")), QString::fromLatin1("-0010"));
- }
-
- {
- QDate date(-2, 3, 4);
- QVERIFY(date.isValid());
- QCOMPARE(date.toString(QLatin1String("yyyy")), QString::fromLatin1("-0002"));
- }
-}
-
-void tst_QDate::roundtripGermanLocale() const
-{
- /* This code path should not result in warnings. */
- const QDate theDate(QDate::currentDate());
- theDate.fromString(theDate.toString(Qt::TextDate), Qt::TextDate);
-
- const QDateTime theDateTime(QDateTime::currentDateTime());
- theDateTime.fromString(theDateTime.toString(Qt::TextDate), Qt::TextDate);
-}
-
-void tst_QDate::shortDayName() const
-{
- QCOMPARE(QDate::shortDayName(0), QString());
- QCOMPARE(QDate::shortDayName(8), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::shortDayName(1), QLatin1String("Mon"));
- QCOMPARE(QDate::shortDayName(7), QLatin1String("Sun"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 7; ++i) {
- QCOMPARE(QDate::shortDayName(i), locale.dayName(i, QLocale::ShortFormat));
- }
-}
-
-void tst_QDate::standaloneShortDayName() const
-{
- QCOMPARE(QDate::shortDayName(0, QDate::StandaloneFormat), QString());
- QCOMPARE(QDate::shortDayName(8, QDate::StandaloneFormat), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::shortDayName(1, QDate::StandaloneFormat), QLatin1String("Mon"));
- QCOMPARE(QDate::shortDayName(7, QDate::StandaloneFormat), QLatin1String("Sun"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 7; ++i) {
- QCOMPARE(QDate::shortDayName(i, QDate::StandaloneFormat), locale.standaloneDayName(i, QLocale::ShortFormat));
- }
-}
-
-void tst_QDate::longDayName() const
-{
- QCOMPARE(QDate::longDayName(0), QString());
- QCOMPARE(QDate::longDayName(8), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::longDayName(1), QLatin1String("Monday"));
- QCOMPARE(QDate::longDayName(7), QLatin1String("Sunday"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 7; ++i) {
- QCOMPARE(QDate::longDayName(i), locale.dayName(i, QLocale::LongFormat));
- }
-}
-
-void tst_QDate::standaloneLongDayName() const
-{
- QCOMPARE(QDate::longDayName(0, QDate::StandaloneFormat), QString());
- QCOMPARE(QDate::longDayName(8, QDate::StandaloneFormat), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::longDayName(1, QDate::StandaloneFormat), QLatin1String("Monday"));
- QCOMPARE(QDate::longDayName(7, QDate::StandaloneFormat), QLatin1String("Sunday"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 7; ++i) {
- QCOMPARE(QDate::longDayName(i, QDate::StandaloneFormat), locale.standaloneDayName(i, QLocale::LongFormat));
- }
-}
-
-void tst_QDate::shortMonthName() const
-{
- QCOMPARE(QDate::shortMonthName(0), QString());
- QCOMPARE(QDate::shortMonthName(13), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::shortMonthName(1), QLatin1String("Jan"));
- QCOMPARE(QDate::shortMonthName(8), QLatin1String("Aug"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 12; ++i) {
- QCOMPARE(QDate::shortMonthName(i), locale.monthName(i, QLocale::ShortFormat));
- }
-}
-
-void tst_QDate::standaloneShortMonthName() const
-{
- QCOMPARE(QDate::shortMonthName(0, QDate::StandaloneFormat), QString());
- QCOMPARE(QDate::shortMonthName(13, QDate::StandaloneFormat), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::shortMonthName(1, QDate::StandaloneFormat), QLatin1String("Jan"));
- QCOMPARE(QDate::shortMonthName(8, QDate::StandaloneFormat), QLatin1String("Aug"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 12; ++i) {
- QCOMPARE(QDate::shortMonthName(i, QDate::StandaloneFormat), locale.standaloneMonthName(i, QLocale::ShortFormat));
- }
-}
-
-void tst_QDate::longMonthName() const
-{
- QCOMPARE(QDate::longMonthName(0), QString());
- QCOMPARE(QDate::longMonthName(13), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::longMonthName(1), QLatin1String("January"));
- QCOMPARE(QDate::longMonthName(8), QLatin1String("August"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 12; ++i) {
- QCOMPARE(QDate::longMonthName(i), locale.monthName(i, QLocale::LongFormat));
- }
-}
-
-void tst_QDate::standaloneLongMonthName() const
-{
- QCOMPARE(QDate::longMonthName(0, QDate::StandaloneFormat), QString());
- QCOMPARE(QDate::longMonthName(13, QDate::StandaloneFormat), QString());
-
- if (QLocale::system().language() == QLocale::C) {
- QCOMPARE(QDate::longMonthName(1, QDate::StandaloneFormat), QLatin1String("January"));
- QCOMPARE(QDate::longMonthName(8, QDate::StandaloneFormat), QLatin1String("August"));
- }
-
- QLocale locale = QLocale::system();
- for(int i = 1; i <= 12; ++i) {
- QCOMPARE(QDate::longMonthName(i, QDate::StandaloneFormat), locale.standaloneMonthName(i, QLocale::LongFormat));
- }
-}
-
-void tst_QDate::roundtrip() const
-{
- // Test round trip, this exercises setDate(), isValid(), isLeapYear(),
- // year(), month(), day(), julianDayFromDate(), and getDateFromJulianDay()
- // to ensure they are internally consistent (but doesn't guarantee correct)
-
- // Test Julian round trip around JD 0 and the c++ integer division rounding
- // problem point (eg. negative numbers) in the conversion functions.
- QDate testDate;
- QDate loopDate = QDate::fromJulianDay(-50001); // 1 Jan 4850 BC
- while (loopDate.toJulianDay() <= 5150) { // 31 Dec 4700 BC
- testDate.setDate(loopDate.year(), loopDate.month(), loopDate.day());
- QCOMPARE(loopDate.toJulianDay(), testDate.toJulianDay());
- loopDate = loopDate.addDays(1);
- }
-
- // Test Julian round trip in both BC and AD
- loopDate = QDate::fromJulianDay(1684901); // 1 Jan 100 BC
- while (loopDate.toJulianDay() <= 1757949) { // 31 Dec 100 AD
- testDate.setDate(loopDate.year(), loopDate.month(), loopDate.day());
- QCOMPARE(loopDate.toJulianDay(), testDate.toJulianDay());
- loopDate = loopDate.addDays(1);
- }
-
- // Test Gregorian round trip during current useful period
- loopDate = QDate::fromJulianDay(2378497); // 1 Jan 1900 AD
- while (loopDate.toJulianDay() <= 2488433) { // 31 Dec 2100 AD
- testDate.setDate(loopDate.year(), loopDate.month(), loopDate.day());
- QCOMPARE(loopDate.toJulianDay(), testDate.toJulianDay());
- loopDate = loopDate.addDays(1);
- }
-
- // Test Gregorian round trip at top end of widget/format range
- loopDate = QDate::fromJulianDay(5336961); // 1 Jan 9900 AD
- while (loopDate.toJulianDay() <= 5373484) { // 31 Dec 9999 AD
- testDate.setDate(loopDate.year(), loopDate.month(), loopDate.day());
- QCOMPARE(loopDate.toJulianDay(), testDate.toJulianDay());
- loopDate = loopDate.addDays(1);
- }
-
- qint64 minJd = Q_INT64_C(-784350574879);
- qint64 maxJd = Q_INT64_C( 784354017364);
-
- // Test Gregorian round trip at top end of conversion range
- loopDate = QDate::fromJulianDay(maxJd);
- while (loopDate.toJulianDay() >= maxJd - 146397) {
- testDate.setDate(loopDate.year(), loopDate.month(), loopDate.day());
- QCOMPARE(loopDate.toJulianDay(), testDate.toJulianDay());
- loopDate = loopDate.addDays(-1);
- }
-
- // Test Gregorian round trip at low end of conversion range
- loopDate = QDate::fromJulianDay(minJd);
- while (loopDate.toJulianDay() <= minJd + 146397) {
- testDate.setDate(loopDate.year(), loopDate.month(), loopDate.day());
- QCOMPARE(loopDate.toJulianDay(), testDate.toJulianDay());
- loopDate = loopDate.addDays(1);
- }
-}
-
-void tst_QDate::qdebug() const
-{
- QTest::ignoreMessage(QtDebugMsg, "QDate(Invalid)");
- qDebug() << QDate();
- QTest::ignoreMessage(QtDebugMsg, "QDate(\"1983-08-07\")");
- qDebug() << QDate(1983, 8, 7);
-}
-
-QTEST_APPLESS_MAIN(tst_QDate)
-#include "tst_qdate.moc"
diff --git a/tests/auto/corelib/tools/qdatetime/.gitignore b/tests/auto/corelib/tools/qdatetime/.gitignore
deleted file mode 100644
index 7784f3a3eb..0000000000
--- a/tests/auto/corelib/tools/qdatetime/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-tst_qdatetime
diff --git a/tests/auto/corelib/tools/qdatetime/BLACKLIST b/tests/auto/corelib/tools/qdatetime/BLACKLIST
deleted file mode 100644
index 3a42ee066b..0000000000
--- a/tests/auto/corelib/tools/qdatetime/BLACKLIST
+++ /dev/null
@@ -1,2 +0,0 @@
-[timeZoneAbbreviation]
-osx
diff --git a/tests/auto/corelib/tools/qdatetime/qdatetime.pro b/tests/auto/corelib/tools/qdatetime/qdatetime.pro
deleted file mode 100644
index 742eb47075..0000000000
--- a/tests/auto/corelib/tools/qdatetime/qdatetime.pro
+++ /dev/null
@@ -1,17 +0,0 @@
-CONFIG += testcase
-TARGET = tst_qdatetime
-QT = core-private testlib
-SOURCES = tst_qdatetime.cpp
-
-# For some reason using optimization here triggers a compiler issue, which causes an exception
-# However, the code is correct
-msvc {
- !build_pass:message ( "Compiler issue, removing -O1 flag" )
- QMAKE_CFLAGS_RELEASE -= -O1
- QMAKE_CXXFLAGS_RELEASE -= -O1
-}
-
-mac {
- OBJECTIVE_SOURCES += tst_qdatetime_mac.mm
- LIBS += -framework Foundation
-}
diff --git a/tests/auto/corelib/tools/qdatetime/tst_qdatetime.cpp b/tests/auto/corelib/tools/qdatetime/tst_qdatetime.cpp
deleted file mode 100644
index ce7cacf966..0000000000
--- a/tests/auto/corelib/tools/qdatetime/tst_qdatetime.cpp
+++ /dev/null
@@ -1,3490 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Copyright (C) 2016 Intel Corporation.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtTest/QtTest>
-#include <time.h>
-#include <qdatetime.h>
-#include <private/qdatetime_p.h>
-#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
-# include <locale.h>
-#endif
-
-#ifdef Q_OS_WIN
-# include <qt_windows.h>
-#endif
-
-class tst_QDateTime : public QObject
-{
- Q_OBJECT
-
-public:
- tst_QDateTime();
-
- static QString str( int y, int month, int d, int h, int min, int s );
- static QDateTime dt( const QString& str );
-public slots:
- void initTestCase();
- void init();
-private slots:
- void ctor();
- void operator_eq();
- void isNull();
- void isValid();
- void date();
- void time();
- void timeSpec();
- void toSecsSinceEpoch_data();
- void toSecsSinceEpoch();
- void daylightSavingsTimeChange_data();
- void daylightSavingsTimeChange();
- void springForward_data();
- void springForward();
- void setDate();
- void setTime_data();
- void setTime();
- void setTimeSpec_data();
- void setTimeSpec();
- void setSecsSinceEpoch();
- void setMSecsSinceEpoch_data();
- void setMSecsSinceEpoch();
- void fromMSecsSinceEpoch_data();
- void fromMSecsSinceEpoch();
- void toString_isoDate_data();
- void toString_isoDate();
- void toString_isoDate_extra();
-#if QT_CONFIG(datestring)
- void toString_textDate_data();
- void toString_textDate();
- void toString_textDate_extra();
-#endif
- void toString_rfcDate_data();
- void toString_rfcDate();
- void toString_enumformat();
- void toString_strformat();
- void addDays();
- void addMonths();
- void addMonths_data();
- void addYears();
- void addYears_data();
- void addSecs_data();
- void addSecs();
- void addMSecs_data();
- void addMSecs();
- void toTimeSpec_data();
- void toTimeSpec();
- void toLocalTime_data();
- void toLocalTime();
- void toUTC_data();
- void toUTC();
- void daysTo();
- void secsTo_data();
- void secsTo();
- void msecsTo_data();
- void msecsTo();
- void operator_eqeq_data();
- void operator_eqeq();
- void operator_insert_extract_data();
- void operator_insert_extract();
- void currentDateTime();
- void currentDateTimeUtc();
- void currentDateTimeUtc2();
- void fromStringDateFormat_data();
- void fromStringDateFormat();
- void fromStringStringFormat_data();
- void fromStringStringFormat();
- void fromStringStringFormatLocale_data();
- void fromStringStringFormatLocale();
-#ifdef Q_OS_WIN
- void fromString_LOCALE_ILDATE();
-#endif
- void fromStringToStringLocale_data();
- void fromStringToStringLocale();
-
- void offsetFromUtc();
- void setOffsetFromUtc();
- void toOffsetFromUtc();
-
- void zoneAtTime_data();
- void zoneAtTime();
- void timeZoneAbbreviation();
-
- void getDate();
-
- void fewDigitsInYear() const;
- void printNegativeYear() const;
- void roundtripGermanLocale() const;
- void utcOffsetLessThan() const;
-
- void isDaylightTime() const;
- void daylightTransitions() const;
- void timeZones() const;
- void systemTimeZoneChange() const;
-
- void invalid() const;
-
- void macTypes();
-
-private:
- enum { LocalTimeIsUtc = 0, LocalTimeAheadOfUtc = 1, LocalTimeBehindUtc = -1} localTimeType;
- bool zoneIsCET;
- QDate defDate() const { return QDate(1900, 1, 1); }
- QTime defTime() const { return QTime(0, 0, 0); }
- QDateTime defDateTime() const { return QDateTime(defDate(), defTime()); }
- QDateTime invalidDateTime() const { return QDateTime(invalidDate(), invalidTime()); }
- QDate invalidDate() const { return QDate(); }
- QTime invalidTime() const { return QTime(-1, -1, -1); }
-
- class TimeZoneRollback
- {
- const QByteArray prior;
- public:
- // Save the previous timezone so we can restore it afterwards, otherwise
- // later tests may break:
- explicit TimeZoneRollback(const QByteArray &zone) : prior(qgetenv("TZ"))
- { reset(zone); }
- void reset(const QByteArray &zone)
- {
- qputenv("TZ", zone.constData());
- qTzSet();
- }
- ~TimeZoneRollback()
- {
- if (prior.isNull())
- qunsetenv("TZ");
- else
- qputenv("TZ", prior.constData());
- qTzSet();
- }
- };
-};
-
-Q_DECLARE_METATYPE(Qt::TimeSpec)
-Q_DECLARE_METATYPE(Qt::DateFormat)
-
-tst_QDateTime::tst_QDateTime()
-{
-#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
- // Some tests depend on C locale - BF&I it with belt *and* braces:
- qputenv("LC_ALL", "C");
- setlocale(LC_ALL, "C");
- // Need to do this as early as possible, before anything accesses the
- // QSystemLocale singleton; once it exists, there's no changing it.
-#endif // remove for ### Qt 6
-
- /*
- Due to some jurisdictions changing their zones and rules, it's possible
- for a non-CET zone to accidentally match CET at a few tested moments but
- be different a few years later or earlier. This would lead to tests
- failing if run in the partially-aliasing zone (e.g. Algeria, Lybia). So
- test thoroughly; ideally at every mid-winter or mid-summer in whose
- half-year any test below assumes zoneIsCET means what it says. (Tests at
- or near a DST transition implicate both of the half-years that meet
- there.) Years outside the 1970--2038 range, however, are likely not
- properly handled by the TZ-database; and QDateTime explicitly handles them
- differently, so don't probe them here.
- */
- const uint day = 24 * 3600; // in seconds
- zoneIsCET = (QDateTime(QDate(2038, 1, 19), QTime(4, 14, 7)).toSecsSinceEpoch() == 0x7fffffff
- // Entries a year apart robustly differ by multiples of day.
- && QDateTime(QDate(2015, 7, 1), QTime()).toSecsSinceEpoch() == 1435701600
- && QDateTime(QDate(2015, 1, 1), QTime()).toSecsSinceEpoch() == 1420066800
- && QDateTime(QDate(2013, 7, 1), QTime()).toSecsSinceEpoch() == 1372629600
- && QDateTime(QDate(2013, 1, 1), QTime()).toSecsSinceEpoch() == 1356994800
- && QDateTime(QDate(2012, 7, 1), QTime()).toSecsSinceEpoch() == 1341093600
- && QDateTime(QDate(2012, 1, 1), QTime()).toSecsSinceEpoch() == 1325372400
- && QDateTime(QDate(2008, 7, 1), QTime()).toSecsSinceEpoch() == 1214863200
- && QDateTime(QDate(2004, 1, 1), QTime()).toSecsSinceEpoch() == 1072911600
- && QDateTime(QDate(2000, 1, 1), QTime()).toSecsSinceEpoch() == 946681200
- && QDateTime(QDate(1990, 7, 1), QTime()).toSecsSinceEpoch() == 646783200
- && QDateTime(QDate(1990, 1, 1), QTime()).toSecsSinceEpoch() == 631148400
- && QDateTime(QDate(1979, 1, 1), QTime()).toSecsSinceEpoch() == 283993200
- // .toSecsSinceEpoch() returns -1 for everything before this:
- && QDateTime(QDate(1970, 1, 1), QTime(1, 0, 0)).toSecsSinceEpoch() == 0);
- // Use .toMSecsSinceEpoch() if you really need to test anything earlier.
-
- /*
- Again, rule changes can cause a TZ to look like UTC at some sample dates
- but deviate at some date relevant to a test using localTimeType. These
- tests mostly use years outside the 1970--2038 range for which TZ data is
- credible, so we can't helpfully be exhaustive. So scan a sample of years'
- starts and middles.
- */
- const int sampled = 3;
- // UTC starts of months in 2004, 2038 and 1970:
- qint64 jans[sampled] = { 12418 * day, 24837 * day, 0 };
- qint64 juls[sampled] = { 12600 * day, 25018 * day, 181 * day };
- localTimeType = LocalTimeIsUtc;
- for (int i = sampled; i-- > 0; ) {
- QDateTime jan = QDateTime::fromSecsSinceEpoch(jans[i]);
- QDateTime jul = QDateTime::fromSecsSinceEpoch(juls[i]);
- if (jan.date().year() < 1970 || jul.date().month() < 7) {
- localTimeType = LocalTimeBehindUtc;
- break;
- } else if (jan.time().hour() > 0 || jul.time().hour() > 0
- || jan.date().day() > 1 || jul.date().day() > 1) {
- localTimeType = LocalTimeAheadOfUtc;
- break;
- }
- }
- /*
- Even so, TZ=Africa/Algiers will fail fromMSecsSinceEpoch(-1) because it
- switched from WET without DST (i.e. UTC) in the late 1960s to WET with DST
- for all of 1970 - so they had a DST transition *on the epoch*. They've
- since switched to CET with no DST, making life simple; but our tests for
- mistakes around the epoch can't tell the difference between what Algeria
- really did and the symptoms we can believe a bug might produce: there's
- not much we can do about that, that wouldn't hide real bugs.
- */
-}
-
-void tst_QDateTime::initTestCase()
-{
- // Never construct a message like this in an i18n context...
- const char *typemsg1 = "exactly";
- const char *typemsg2 = "and therefore not";
- switch (localTimeType) {
- case LocalTimeIsUtc:
- break;
- case LocalTimeBehindUtc:
- typemsg1 = "behind";
- break;
- case LocalTimeAheadOfUtc:
- typemsg1 = "ahead of";
- typemsg2 = zoneIsCET ? "and is" : "but isn't";
- break;
- }
-
- qDebug() << "Current local time detected to be"
- << typemsg1
- << "UTC"
- << typemsg2
- << "the Central European timezone";
-}
-
-void tst_QDateTime::init()
-{
-#if defined(Q_OS_WIN32)
- SetThreadLocale(MAKELCID(MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US), SORT_DEFAULT));
-#endif
-}
-
-QString tst_QDateTime::str( int y, int month, int d, int h, int min, int s )
-{
- return QDateTime( QDate(y, month, d), QTime(h, min, s) ).toString( Qt::ISODate );
-}
-
-QDateTime tst_QDateTime::dt( const QString& str )
-{
- if ( str == "INVALID" ) {
- return QDateTime();
- } else {
- return QDateTime::fromString( str, Qt::ISODate );
- }
-}
-
-void tst_QDateTime::ctor()
-{
- QDateTime dt1(QDate(2004, 1, 2), QTime(1, 2, 3));
- QCOMPARE(dt1.timeSpec(), Qt::LocalTime);
- QDateTime dt2(QDate(2004, 1, 2), QTime(1, 2, 3), Qt::LocalTime);
- QCOMPARE(dt2.timeSpec(), Qt::LocalTime);
- QDateTime dt3(QDate(2004, 1, 2), QTime(1, 2, 3), Qt::UTC);
- QCOMPARE(dt3.timeSpec(), Qt::UTC);
-
- QVERIFY(dt1 == dt2);
- if (zoneIsCET) {
- QVERIFY(dt1 != dt3);
- QVERIFY(dt1 < dt3);
- QVERIFY(dt1.addSecs(3600).toUTC() == dt3);
- }
-
- // Test OffsetFromUTC constructors
- QDate offsetDate(2013, 1, 1);
- QTime offsetTime(1, 2, 3);
-
- QDateTime offset1(offsetDate, offsetTime, Qt::OffsetFromUTC);
- QCOMPARE(offset1.timeSpec(), Qt::UTC);
- QCOMPARE(offset1.offsetFromUtc(), 0);
- QCOMPARE(offset1.date(), offsetDate);
- QCOMPARE(offset1.time(), offsetTime);
-
- QDateTime offset2(offsetDate, offsetTime, Qt::OffsetFromUTC, 0);
- QCOMPARE(offset2.timeSpec(), Qt::UTC);
- QCOMPARE(offset2.offsetFromUtc(), 0);
- QCOMPARE(offset2.date(), offsetDate);
- QCOMPARE(offset2.time(), offsetTime);
-
- QDateTime offset3(offsetDate, offsetTime, Qt::OffsetFromUTC, 60 * 60);
- QCOMPARE(offset3.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(offset3.offsetFromUtc(), 60 * 60);
- QCOMPARE(offset3.date(), offsetDate);
- QCOMPARE(offset3.time(), offsetTime);
-
- QDateTime offset4(offsetDate, QTime(), Qt::OffsetFromUTC, 60 * 60);
- QCOMPARE(offset4.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(offset4.offsetFromUtc(), 60 * 60);
- QCOMPARE(offset4.date(), offsetDate);
- QCOMPARE(offset4.time(), QTime(0, 0, 0));
-}
-
-void tst_QDateTime::operator_eq()
-{
- QDateTime dt1(QDate(2004, 3, 24), QTime(23, 45, 57), Qt::UTC);
- QDateTime dt2(QDate(2005, 3, 11), QTime(), Qt::UTC);
- dt2 = dt1;
- QVERIFY(dt1 == dt2);
-}
-
-void tst_QDateTime::isNull()
-{
- QDateTime dt1;
- QVERIFY(dt1.isNull());
- dt1.setDate(QDate());
- QVERIFY(dt1.isNull());
- dt1.setTime(QTime());
- QVERIFY(dt1.isNull());
- dt1.setTimeSpec(Qt::UTC);
- QVERIFY(dt1.isNull()); // maybe it should return false?
-
- dt1.setDate(QDate(2004, 1, 2));
- QVERIFY(!dt1.isNull());
- dt1.setTime(QTime(12, 34, 56));
- QVERIFY(!dt1.isNull());
- dt1.setTime(QTime());
- QVERIFY(!dt1.isNull());
-}
-
-void tst_QDateTime::isValid()
-{
- QDateTime dt1;
- QVERIFY(!dt1.isValid());
- dt1.setDate(QDate());
- QVERIFY(!dt1.isValid());
- dt1.setTime(QTime());
- QVERIFY(!dt1.isValid());
- dt1.setTimeSpec(Qt::UTC);
- QVERIFY(!dt1.isValid());
-
- dt1.setDate(QDate(2004, 1, 2));
- QVERIFY(dt1.isValid());
- dt1.setDate(QDate());
- QVERIFY(!dt1.isValid());
- dt1.setTime(QTime(12, 34, 56));
- QVERIFY(!dt1.isValid());
- dt1.setTime(QTime());
- QVERIFY(!dt1.isValid());
-}
-
-void tst_QDateTime::date()
-{
- QDateTime dt1(QDate(2004, 3, 24), QTime(23, 45, 57), Qt::LocalTime);
- QCOMPARE(dt1.date(), QDate(2004, 3, 24));
-
- QDateTime dt2(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::LocalTime);
- QCOMPARE(dt2.date(), QDate(2004, 3, 25));
-
- QDateTime dt3(QDate(2004, 3, 24), QTime(23, 45, 57), Qt::UTC);
- QCOMPARE(dt3.date(), QDate(2004, 3, 24));
-
- QDateTime dt4(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC);
- QCOMPARE(dt4.date(), QDate(2004, 3, 25));
-}
-
-void tst_QDateTime::time()
-{
- QDateTime dt1(QDate(2004, 3, 24), QTime(23, 45, 57), Qt::LocalTime);
- QCOMPARE(dt1.time(), QTime(23, 45, 57));
-
- QDateTime dt2(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::LocalTime);
- QCOMPARE(dt2.time(), QTime(0, 45, 57));
-
- QDateTime dt3(QDate(2004, 3, 24), QTime(23, 45, 57), Qt::UTC);
- QCOMPARE(dt3.time(), QTime(23, 45, 57));
-
- QDateTime dt4(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC);
- QCOMPARE(dt4.time(), QTime(0, 45, 57));
-}
-
-void tst_QDateTime::timeSpec()
-{
- QDateTime dt1(QDate(2004, 1, 24), QTime(23, 45, 57));
- QCOMPARE(dt1.timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.addDays(0).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.addMonths(0).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.addMonths(6).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.addYears(0).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.addSecs(0).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.addSecs(86400 * 185).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.toTimeSpec(Qt::LocalTime).timeSpec(), Qt::LocalTime);
- QCOMPARE(dt1.toTimeSpec(Qt::UTC).timeSpec(), Qt::UTC);
-
- QDateTime dt2(QDate(2004, 1, 24), QTime(23, 45, 57), Qt::LocalTime);
- QCOMPARE(dt2.timeSpec(), Qt::LocalTime);
-
- QDateTime dt3(QDate(2004, 1, 25), QTime(0, 45, 57), Qt::UTC);
- QCOMPARE(dt3.timeSpec(), Qt::UTC);
-
- QDateTime dt4 = QDateTime::currentDateTime();
- QCOMPARE(dt4.timeSpec(), Qt::LocalTime);
-}
-
-void tst_QDateTime::setDate()
-{
- QDateTime dt1(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC);
- dt1.setDate(QDate(2004, 6, 25));
- QCOMPARE(dt1.date(), QDate(2004, 6, 25));
- QCOMPARE(dt1.time(), QTime(0, 45, 57));
- QCOMPARE(dt1.timeSpec(), Qt::UTC);
-
- QDateTime dt2(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::LocalTime);
- dt2.setDate(QDate(2004, 6, 25));
- QCOMPARE(dt2.date(), QDate(2004, 6, 25));
- QCOMPARE(dt2.time(), QTime(0, 45, 57));
- QCOMPARE(dt2.timeSpec(), Qt::LocalTime);
-
- QDateTime dt3(QDate(4004, 3, 25), QTime(0, 45, 57), Qt::UTC);
- dt3.setDate(QDate(4004, 6, 25));
- QCOMPARE(dt3.date(), QDate(4004, 6, 25));
- QCOMPARE(dt3.time(), QTime(0, 45, 57));
- QCOMPARE(dt3.timeSpec(), Qt::UTC);
-
- QDateTime dt4(QDate(4004, 3, 25), QTime(0, 45, 57), Qt::LocalTime);
- dt4.setDate(QDate(4004, 6, 25));
- QCOMPARE(dt4.date(), QDate(4004, 6, 25));
- QCOMPARE(dt4.time(), QTime(0, 45, 57));
- QCOMPARE(dt4.timeSpec(), Qt::LocalTime);
-
- QDateTime dt5(QDate(1760, 3, 25), QTime(0, 45, 57), Qt::UTC);
- dt5.setDate(QDate(1760, 6, 25));
- QCOMPARE(dt5.date(), QDate(1760, 6, 25));
- QCOMPARE(dt5.time(), QTime(0, 45, 57));
- QCOMPARE(dt5.timeSpec(), Qt::UTC);
-
- QDateTime dt6(QDate(1760, 3, 25), QTime(0, 45, 57), Qt::LocalTime);
- dt6.setDate(QDate(1760, 6, 25));
- QCOMPARE(dt6.date(), QDate(1760, 6, 25));
- QCOMPARE(dt6.time(), QTime(0, 45, 57));
- QCOMPARE(dt6.timeSpec(), Qt::LocalTime);
-}
-
-void tst_QDateTime::setTime_data()
-{
- QTest::addColumn<QDateTime>("dateTime");
- QTest::addColumn<QTime>("newTime");
-
- QTest::newRow("data0") << QDateTime(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC) << QTime(23, 11, 22);
- QTest::newRow("data1") << QDateTime(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::LocalTime) << QTime(23, 11, 22);
- QTest::newRow("data2") << QDateTime(QDate(4004, 3, 25), QTime(0, 45, 57), Qt::UTC) << QTime(23, 11, 22);
- QTest::newRow("data3") << QDateTime(QDate(4004, 3, 25), QTime(0, 45, 57), Qt::LocalTime) << QTime(23, 11, 22);
- QTest::newRow("data4") << QDateTime(QDate(1760, 3, 25), QTime(0, 45, 57), Qt::UTC) << QTime(23, 11, 22);
- QTest::newRow("data5") << QDateTime(QDate(1760, 3, 25), QTime(0, 45, 57), Qt::LocalTime) << QTime(23, 11, 22);
-
- QTest::newRow("set on std/dst") << QDateTime::currentDateTime() << QTime(23, 11, 22);
-}
-
-void tst_QDateTime::setTime()
-{
- QFETCH(QDateTime, dateTime);
- QFETCH(QTime, newTime);
-
- const QDate expectedDate(dateTime.date());
- const Qt::TimeSpec expectedTimeSpec(dateTime.timeSpec());
-
- dateTime.setTime(newTime);
-
- QCOMPARE(dateTime.date(), expectedDate);
- QCOMPARE(dateTime.time(), newTime);
- QCOMPARE(dateTime.timeSpec(), expectedTimeSpec);
-}
-
-void tst_QDateTime::setTimeSpec_data()
-{
- QTest::addColumn<QDateTime>("dateTime");
- QTest::addColumn<Qt::TimeSpec>("newTimeSpec");
-
- QTest::newRow("UTC => UTC") << QDateTime(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC) << Qt::UTC;
- QTest::newRow("UTC => LocalTime") << QDateTime(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC) << Qt::LocalTime;
- QTest::newRow("UTC => OffsetFromUTC") << QDateTime(QDate(2004, 3, 25), QTime(0, 45, 57), Qt::UTC) << Qt::OffsetFromUTC;
-}
-
-void tst_QDateTime::setTimeSpec()
-{
- QFETCH(QDateTime, dateTime);
- QFETCH(Qt::TimeSpec, newTimeSpec);
-
- const QDate expectedDate(dateTime.date());
- const QTime expectedTime(dateTime.time());
-
- dateTime.setTimeSpec(newTimeSpec);
-
- QCOMPARE(dateTime.date(), expectedDate);
- QCOMPARE(dateTime.time(), expectedTime);
- if (newTimeSpec == Qt::OffsetFromUTC)
- QCOMPARE(dateTime.timeSpec(), Qt::UTC);
- else
- QCOMPARE(dateTime.timeSpec(), newTimeSpec);
-}
-
-void tst_QDateTime::setSecsSinceEpoch()
-{
- QDateTime dt1;
- dt1.setSecsSinceEpoch(0);
- QCOMPARE(dt1.toUTC(), QDateTime(QDate(1970, 1, 1), QTime(), Qt::UTC));
- QCOMPARE(dt1.timeSpec(), Qt::LocalTime);
-
- dt1.setTimeSpec(Qt::UTC);
- dt1.setSecsSinceEpoch(0);
- QCOMPARE(dt1, QDateTime(QDate(1970, 1, 1), QTime(), Qt::UTC));
- QCOMPARE(dt1.timeSpec(), Qt::UTC);
-
- dt1.setSecsSinceEpoch(123456);
- QCOMPARE(dt1, QDateTime(QDate(1970, 1, 2), QTime(10, 17, 36), Qt::UTC));
- if (zoneIsCET) {
- QDateTime dt2;
- dt2.setSecsSinceEpoch(123456);
- QCOMPARE(dt2, QDateTime(QDate(1970, 1, 2), QTime(11, 17, 36), Qt::LocalTime));
- }
-
- dt1.setSecsSinceEpoch((uint)(quint32)-123456);
- QCOMPARE(dt1, QDateTime(QDate(2106, 2, 5), QTime(20, 10, 40), Qt::UTC));
- if (zoneIsCET) {
- QDateTime dt2;
- dt2.setSecsSinceEpoch((uint)(quint32)-123456);
- QCOMPARE(dt2, QDateTime(QDate(2106, 2, 5), QTime(21, 10, 40), Qt::LocalTime));
- }
-
- dt1.setSecsSinceEpoch(1214567890);
- QCOMPARE(dt1, QDateTime(QDate(2008, 6, 27), QTime(11, 58, 10), Qt::UTC));
- if (zoneIsCET) {
- QDateTime dt2;
- dt2.setSecsSinceEpoch(1214567890);
- QCOMPARE(dt2, QDateTime(QDate(2008, 6, 27), QTime(13, 58, 10), Qt::LocalTime));
- }
-
- dt1.setSecsSinceEpoch(0x7FFFFFFF);
- QCOMPARE(dt1, QDateTime(QDate(2038, 1, 19), QTime(3, 14, 7), Qt::UTC));
- if (zoneIsCET) {
- QDateTime dt2;
- dt2.setSecsSinceEpoch(0x7FFFFFFF);
- QCOMPARE(dt2, QDateTime(QDate(2038, 1, 19), QTime(4, 14, 7), Qt::LocalTime));
- }
-
- dt1 = QDateTime(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::OffsetFromUTC, 60 * 60);
- dt1.setSecsSinceEpoch(123456);
- QCOMPARE(dt1, QDateTime(QDate(1970, 1, 2), QTime(10, 17, 36), Qt::UTC));
- QCOMPARE(dt1.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(dt1.offsetFromUtc(), 60 * 60);
-}
-
-void tst_QDateTime::setMSecsSinceEpoch_data()
-{
- QTest::addColumn<qint64>("msecs");
- QTest::addColumn<QDateTime>("utc");
- QTest::addColumn<QDateTime>("cet");
-
- QTest::newRow("zero")
- << Q_INT64_C(0)
- << QDateTime(QDate(1970, 1, 1), QTime(), Qt::UTC)
- << QDateTime(QDate(1970, 1, 1), QTime(1, 0));
- QTest::newRow("-1")
- << Q_INT64_C(-1)
- << QDateTime(QDate(1969, 12, 31), QTime(23, 59, 59, 999), Qt::UTC)
- << QDateTime(QDate(1970, 1, 1), QTime(0, 59, 59, 999));
- QTest::newRow("123456789")
- << Q_INT64_C(123456789)
- << QDateTime(QDate(1970, 1, 2), QTime(10, 17, 36, 789), Qt::UTC)
- << QDateTime(QDate(1970, 1, 2), QTime(11, 17, 36, 789), Qt::LocalTime);
- QTest::newRow("-123456789")
- << Q_INT64_C(-123456789)
- << QDateTime(QDate(1969, 12, 30), QTime(13, 42, 23, 211), Qt::UTC)
- << QDateTime(QDate(1969, 12, 30), QTime(14, 42, 23, 211), Qt::LocalTime);
- QTest::newRow("non-time_t")
- << (Q_INT64_C(1000) << 32)
- << QDateTime(QDate(2106, 2, 7), QTime(6, 28, 16), Qt::UTC)
- << QDateTime(QDate(2106, 2, 7), QTime(7, 28, 16));
- QTest::newRow("very-large")
- << (Q_INT64_C(123456) << 32)
- << QDateTime(QDate(18772, 8, 15), QTime(1, 8, 14, 976), Qt::UTC)
- << QDateTime(QDate(18772, 8, 15), QTime(3, 8, 14, 976));
- QTest::newRow("old min (Tue Nov 25 00:00:00 -4714)")
- << Q_INT64_C(-210866716800000)
- << QDateTime(QDate::fromJulianDay(1), QTime(), Qt::UTC)
- << QDateTime(QDate::fromJulianDay(1), QTime(1, 0));
- QTest::newRow("old max (Tue Jun 3 21:59:59 5874898)")
- << Q_INT64_C(185331720376799999)
- << QDateTime(QDate::fromJulianDay(0x7fffffff), QTime(21, 59, 59, 999), Qt::UTC)
- << QDateTime(QDate::fromJulianDay(0x7fffffff), QTime(23, 59, 59, 999));
- QTest::newRow("min")
- // Use -max(), which is min() + 1, to simplify filtering out overflow cases:
- << -std::numeric_limits<qint64>::max()
- << QDateTime(QDate(-292275056, 5, 16), QTime(16, 47, 4, 193), Qt::UTC)
- << QDateTime(QDate(-292275056, 5, 16), QTime(17, 47, 4, 193), Qt::LocalTime);
- QTest::newRow("max")
- << std::numeric_limits<qint64>::max()
- << QDateTime(QDate(292278994, 8, 17), QTime(7, 12, 55, 807), Qt::UTC)
- << QDateTime(QDate(292278994, 8, 17), QTime(9, 12, 55, 807), Qt::LocalTime);
-}
-
-void tst_QDateTime::setMSecsSinceEpoch()
-{
- QFETCH(qint64, msecs);
- QFETCH(QDateTime, utc);
- QFETCH(QDateTime, cet);
-
- QDateTime dt;
- dt.setTimeSpec(Qt::UTC);
- dt.setMSecsSinceEpoch(msecs);
-
- QCOMPARE(dt, utc);
- QCOMPARE(dt.date(), utc.date());
- QCOMPARE(dt.time(), utc.time());
- QCOMPARE(dt.timeSpec(), Qt::UTC);
-
- {
- QDateTime dt1 = QDateTime::fromMSecsSinceEpoch(msecs, Qt::UTC);
- QCOMPARE(dt1, utc);
- QCOMPARE(dt1.date(), utc.date());
- QCOMPARE(dt1.time(), utc.time());
- QCOMPARE(dt1.timeSpec(), Qt::UTC);
- }
- {
- QDateTime dt1(utc.date(), utc.time(), Qt::UTC);
- QCOMPARE(dt1, utc);
- QCOMPARE(dt1.date(), utc.date());
- QCOMPARE(dt1.time(), utc.time());
- QCOMPARE(dt1.timeSpec(), Qt::UTC);
- }
- {
- // used to fail to clear the ShortData bit, causing corruption
- QDateTime dt1 = dt.addDays(0);
- QCOMPARE(dt1, utc);
- QCOMPARE(dt1.date(), utc.date());
- QCOMPARE(dt1.time(), utc.time());
- QCOMPARE(dt1.timeSpec(), Qt::UTC);
- }
-
- if (zoneIsCET) {
- QCOMPARE(dt.toLocalTime(), cet);
-
- // Test converting from LocalTime to UTC back to LocalTime.
- QDateTime localDt;
- localDt.setTimeSpec(Qt::LocalTime);
- localDt.setMSecsSinceEpoch(msecs);
-
- // LocalTime will overflow for max
- if (msecs != std::numeric_limits<qint64>::max())
- QCOMPARE(localDt, utc);
- QCOMPARE(localDt.timeSpec(), Qt::LocalTime);
-
- // Compare result for LocalTime to TimeZone
- QTimeZone europe("Europe/Oslo");
- QDateTime dt2;
- dt2.setTimeZone(europe);
- dt2.setMSecsSinceEpoch(msecs);
- QCOMPARE(dt2.date(), cet.date());
-
- // don't compare the time if the date is too early or too late: prior
- // to 1916, timezones in Europe were not standardised and some OS APIs
- // have hard limits. Let's restrict it to the 32-bit Unix range
- if (dt2.date().year() >= 1970 && dt2.date().year() <= 2037)
- QCOMPARE(dt2.time(), cet.time());
- QCOMPARE(dt2.timeSpec(), Qt::TimeZone);
- QCOMPARE(dt2.timeZone(), europe);
- }
-
- QCOMPARE(dt.toMSecsSinceEpoch(), msecs);
-
- if (quint64(msecs / 1000) < 0xFFFFFFFF) {
- QCOMPARE(qint64(dt.toSecsSinceEpoch()), msecs / 1000);
- }
-
- QDateTime reference(QDate(1970, 1, 1), QTime(), Qt::UTC);
- QCOMPARE(dt, reference.addMSecs(msecs));
-}
-
-void tst_QDateTime::fromMSecsSinceEpoch_data()
-{
- setMSecsSinceEpoch_data();
-}
-
-void tst_QDateTime::fromMSecsSinceEpoch()
-{
- QFETCH(qint64, msecs);
- QFETCH(QDateTime, utc);
- QFETCH(QDateTime, cet);
-
- QDateTime dtLocal = QDateTime::fromMSecsSinceEpoch(msecs, Qt::LocalTime);
- QDateTime dtUtc = QDateTime::fromMSecsSinceEpoch(msecs, Qt::UTC);
- QDateTime dtOffset = QDateTime::fromMSecsSinceEpoch(msecs, Qt::OffsetFromUTC, 60*60);
-
- // LocalTime will overflow for "min" or "max" tests, depending on whether
- // you're East or West of Greenwich. In UTC, we won't overflow.
- if (localTimeType == LocalTimeIsUtc
- || msecs != std::numeric_limits<qint64>::max() * localTimeType)
- QCOMPARE(dtLocal, utc);
-
- QCOMPARE(dtUtc, utc);
- QCOMPARE(dtUtc.date(), utc.date());
- QCOMPARE(dtUtc.time(), utc.time());
-
- QCOMPARE(dtOffset, utc);
- QCOMPARE(dtOffset.offsetFromUtc(), 60*60);
- // // OffsetFromUTC will overflow for max
- if (msecs != std::numeric_limits<qint64>::max())
- QCOMPARE(dtOffset.time(), utc.time().addMSecs(60*60*1000));
-
- if (zoneIsCET) {
- QCOMPARE(dtLocal.toLocalTime(), cet);
- QCOMPARE(dtUtc.toLocalTime(), cet);
- QCOMPARE(dtOffset.toLocalTime(), cet);
- }
-
- // LocalTime will overflow for max
- if (msecs != std::numeric_limits<qint64>::max())
- QCOMPARE(dtLocal.toMSecsSinceEpoch(), msecs);
- QCOMPARE(dtUtc.toMSecsSinceEpoch(), msecs);
- QCOMPARE(dtOffset.toMSecsSinceEpoch(), msecs);
-
- if (quint64(msecs / 1000) < 0xFFFFFFFF) {
- QCOMPARE(qint64(dtLocal.toSecsSinceEpoch()), msecs / 1000);
- QCOMPARE(qint64(dtUtc.toSecsSinceEpoch()), msecs / 1000);
- QCOMPARE(qint64(dtOffset.toSecsSinceEpoch()), msecs / 1000);
- }
-
- QDateTime reference(QDate(1970, 1, 1), QTime(), Qt::UTC);
- // LocalTime will overflow for max
- if (msecs != std::numeric_limits<qint64>::max())
- QCOMPARE(dtLocal, reference.addMSecs(msecs));
- QCOMPARE(dtUtc, reference.addMSecs(msecs));
- QCOMPARE(dtOffset, reference.addMSecs(msecs));
-}
-
-void tst_QDateTime::toString_isoDate_data()
-{
- QTest::addColumn<QDateTime>("datetime");
- QTest::addColumn<Qt::DateFormat>("format");
- QTest::addColumn<QString>("expected");
-
- QTest::newRow("localtime")
- << QDateTime(QDate(1978, 11, 9), QTime(13, 28, 34))
- << Qt::ISODate << QString("1978-11-09T13:28:34");
- QTest::newRow("UTC")
- << QDateTime(QDate(1978, 11, 9), QTime(13, 28, 34), Qt::UTC)
- << Qt::ISODate << QString("1978-11-09T13:28:34Z");
- QDateTime dt(QDate(1978, 11, 9), QTime(13, 28, 34));
- dt.setOffsetFromUtc(19800);
- QTest::newRow("positive OffsetFromUTC")
- << dt << Qt::ISODate
- << QString("1978-11-09T13:28:34+05:30");
- dt.setOffsetFromUtc(-7200);
- QTest::newRow("negative OffsetFromUTC")
- << dt << Qt::ISODate
- << QString("1978-11-09T13:28:34-02:00");
- dt.setOffsetFromUtc(-900);
- QTest::newRow("negative non-integral OffsetFromUTC")
- << dt << Qt::ISODate
- << QString("1978-11-09T13:28:34-00:15");
- QTest::newRow("invalid")
- << QDateTime(QDate(-1, 11, 9), QTime(13, 28, 34), Qt::UTC)
- << Qt::ISODate << QString();
- QTest::newRow("without-ms")
- << QDateTime(QDate(1978, 11, 9), QTime(13, 28, 34, 20))
- << Qt::ISODate << QString("1978-11-09T13:28:34");
- QTest::newRow("with-ms")
- << QDateTime(QDate(1978, 11, 9), QTime(13, 28, 34, 20))
- << Qt::ISODateWithMs << QString("1978-11-09T13:28:34.020");
-}
-
-void tst_QDateTime::toString_isoDate()
-{
- QFETCH(QDateTime, datetime);
- QFETCH(Qt::DateFormat, format);
- QFETCH(QString, expected);
-
- QLocale oldLocale;
- QLocale::setDefault(QLocale("en_US"));
-
- QString result = datetime.toString(format);
- QCOMPARE(result, expected);
-
- QDateTime resultDatetime = QDateTime::fromString(result, format);
- // If expecting invalid result the datetime may still be valid, i.e. year < 0 or > 9999
- if (!expected.isEmpty()) {
- QEXPECT_FAIL("without-ms", "Qt::ISODate truncates milliseconds (QTBUG-56552)", Abort);
-
- QCOMPARE(resultDatetime, datetime);
- QCOMPARE(resultDatetime.date(), datetime.date());
- QCOMPARE(resultDatetime.time(), datetime.time());
- QCOMPARE(resultDatetime.timeSpec(), datetime.timeSpec());
- QCOMPARE(resultDatetime.offsetFromUtc(), datetime.offsetFromUtc());
- } else {
- QCOMPARE(resultDatetime, QDateTime());
- }
-
- QLocale::setDefault(oldLocale);
-}
-
-void tst_QDateTime::toString_isoDate_extra()
-{
- QDateTime dt = QDateTime::fromMSecsSinceEpoch(0, Qt::UTC);
- QCOMPARE(dt.toString(Qt::ISODate), QLatin1String("1970-01-01T00:00:00Z"));
-#if QT_CONFIG(timezone)
- QTimeZone PST("America/Vancouver");
- if (PST.isValid()) {
- dt = QDateTime::fromMSecsSinceEpoch(0, PST);
- QCOMPARE(dt.toString(Qt::ISODate), QLatin1String("1969-12-31T16:00:00-08:00"));
- } else {
- qDebug("Missed zone test: no America/Vancouver zone available");
- }
- QTimeZone CET("Europe/Berlin");
- if (CET.isValid()) {
- dt = QDateTime::fromMSecsSinceEpoch(0, CET);
- QCOMPARE(dt.toString(Qt::ISODate), QLatin1String("1970-01-01T01:00:00+01:00"));
- } else {
- qDebug("Missed zone test: no Europe/Berlin zone available");
- }
-#endif // timezone
-}
-
-#if QT_CONFIG(datestring)
-void tst_QDateTime::toString_textDate_data()
-{
- QTest::addColumn<QDateTime>("datetime");
- QTest::addColumn<QString>("expected");
-
- QString wednesdayJanuary = QLocale::system().dayName(3, QLocale::ShortFormat)
- + ' ' + QLocale::system().monthName(1, QLocale::ShortFormat);
-
- QTest::newRow("localtime") << QDateTime(QDate(2013, 1, 2), QTime(1, 2, 3), Qt::LocalTime)
- << wednesdayJanuary + QString(" 2 01:02:03 2013");
- QTest::newRow("utc") << QDateTime(QDate(2013, 1, 2), QTime(1, 2, 3), Qt::UTC)
- << wednesdayJanuary + QString(" 2 01:02:03 2013 GMT");
- QTest::newRow("offset+") << QDateTime(QDate(2013, 1, 2), QTime(1, 2, 3), Qt::OffsetFromUTC,
- 10 * 60 * 60)
- << wednesdayJanuary + QString(" 2 01:02:03 2013 GMT+1000");
- QTest::newRow("offset-") << QDateTime(QDate(2013, 1, 2), QTime(1, 2, 3), Qt::OffsetFromUTC,
- -10 * 60 * 60)
- << wednesdayJanuary + QString(" 2 01:02:03 2013 GMT-1000");
- QTest::newRow("invalid") << QDateTime()
- << QString("");
-}
-
-void tst_QDateTime::toString_textDate()
-{
- QFETCH(QDateTime, datetime);
- QFETCH(QString, expected);
-
- QString result = datetime.toString(Qt::TextDate);
- QCOMPARE(result, expected);
-
- QDateTime resultDatetime = QDateTime::fromString(result, Qt::TextDate);
- QCOMPARE(resultDatetime, datetime);
- QCOMPARE(resultDatetime.date(), datetime.date());
- QCOMPARE(resultDatetime.time(), datetime.time());
- QCOMPARE(resultDatetime.timeSpec(), datetime.timeSpec());
- QCOMPARE(resultDatetime.offsetFromUtc(), datetime.offsetFromUtc());
-}
-
-void tst_QDateTime::toString_textDate_extra()
-{
- QLatin1String GMT("GMT");
- QDateTime dt = QDateTime::fromMSecsSinceEpoch(0, Qt::LocalTime);
- QVERIFY(!dt.toString().endsWith(GMT));
- dt = QDateTime::fromMSecsSinceEpoch(0, Qt::UTC).toLocalTime();
- QVERIFY(!dt.toString().endsWith(GMT));
- if (QTimeZone::systemTimeZone().offsetFromUtc(dt))
- QVERIFY(dt.toString() != QLatin1String("Thu Jan 1 00:00:00 1970"));
- else
- QCOMPARE(dt.toString(), QLatin1String("Thu Jan 1 00:00:00 1970"));
-#if QT_CONFIG(timezone)
-# if defined Q_OS_UNIX && !defined Q_OS_DARWIN && !defined Q_OS_ANDROID
-# define CORRECT_ZONE_ABBREV
-# endif // QTBUG-57320, QTBUG-57298, QTBUG-68833
-
- QTimeZone PST("America/Vancouver");
- if (PST.isValid()) {
- dt = QDateTime::fromMSecsSinceEpoch(0, PST);
-# ifdef CORRECT_ZONE_ABBREV
- QCOMPARE(dt.toString(), QLatin1String("Wed Dec 31 16:00:00 1969 PST"));
-# else
- QVERIFY(dt.toString().startsWith(QLatin1String("Wed Dec 31 16:00:00 1969 ")));
-# endif
- dt = dt.toLocalTime();
- QVERIFY(!dt.toString().endsWith(GMT));
- } else {
- qDebug("Missed zone test: no America/Vancouver zone available");
- }
- QTimeZone CET("Europe/Berlin");
- if (CET.isValid()) {
- dt = QDateTime::fromMSecsSinceEpoch(0, CET);
-# ifdef CORRECT_ZONE_ABBREV
- QCOMPARE(dt.toString(), QLatin1String("Thu Jan 1 01:00:00 1970 CET"));
-# else
- QVERIFY(dt.toString().startsWith(QLatin1String("Thu Jan 1 01:00:00 1970 ")));
-# endif
- dt = dt.toLocalTime();
- QVERIFY(!dt.toString().endsWith(GMT));
- } else {
- qDebug("Missed zone test: no Europe/Berlin zone available");
- }
-#endif // timezone
- dt = QDateTime::fromMSecsSinceEpoch(0, Qt::UTC);
- QVERIFY(dt.toString().endsWith(GMT));
-}
-#endif // datestring
-
-void tst_QDateTime::toString_rfcDate_data()
-{
- QTest::addColumn<QDateTime>("dt");
- QTest::addColumn<QString>("formatted");
-
- if (zoneIsCET) {
- QTest::newRow("localtime")
- << QDateTime(QDate(1978, 11, 9), QTime(13, 28, 34))
- << QString("09 Nov 1978 13:28:34 +0100");
- }
- QTest::newRow("UTC")
- << QDateTime(QDate(1978, 11, 9), QTime(13, 28, 34), Qt::UTC)
- << QString("09 Nov 1978 13:28:34 +0000");
- QDateTime dt(QDate(1978, 11, 9), QTime(13, 28, 34));
- dt.setOffsetFromUtc(19800);
- QTest::newRow("positive OffsetFromUTC")
- << dt
- << QString("09 Nov 1978 13:28:34 +0530");
- dt.setOffsetFromUtc(-7200);
- QTest::newRow("negative OffsetFromUTC")
- << dt
- << QString("09 Nov 1978 13:28:34 -0200");
- QTest::newRow("invalid")
- << QDateTime(QDate(1978, 13, 9), QTime(13, 28, 34), Qt::UTC)
- << QString();
- QTest::newRow("999 milliseconds UTC")
- << QDateTime(QDate(2000, 1, 1), QTime(13, 28, 34, 999), Qt::UTC)
- << QString("01 Jan 2000 13:28:34 +0000");
-}
-
-void tst_QDateTime::toString_rfcDate()
-{
- QFETCH(QDateTime, dt);
- QFETCH(QString, formatted);
-
- // Set to non-English locale to confirm still uses English
- QLocale oldLocale;
- QLocale::setDefault(QLocale("de_DE"));
- QCOMPARE(dt.toString(Qt::RFC2822Date), formatted);
- QLocale::setDefault(oldLocale);
-}
-
-void tst_QDateTime::toString_enumformat()
-{
- QDateTime dt1(QDate(1995, 5, 20), QTime(12, 34, 56));
-
-
- QString str1 = dt1.toString(Qt::TextDate);
- QVERIFY(!str1.isEmpty()); // It's locale dependent everywhere
-
- QString str2 = dt1.toString(Qt::ISODate);
- QCOMPARE(str2, QString("1995-05-20T12:34:56"));
-
- QString str3 = dt1.toString(Qt::LocalDate);
- QVERIFY(!str3.isEmpty());
- //check for date/time components in any order
- //year may be 2 or 4 digits
- QVERIFY(str3.contains("95"));
- //day and month may be in numeric or word form
- QVERIFY(str3.contains("12"));
- QVERIFY(str3.contains("34"));
- //seconds may be absent
-}
-
-void tst_QDateTime::addDays()
-{
- for (int pass = 0; pass < 2; ++pass) {
- QDateTime dt(QDate(2004, 1, 1), QTime(12, 34, 56), pass == 0 ? Qt::LocalTime : Qt::UTC);
- dt = dt.addDays(185);
- QVERIFY(dt.date().year() == 2004 && dt.date().month() == 7 && dt.date().day() == 4);
- QVERIFY(dt.time().hour() == 12 && dt.time().minute() == 34 && dt.time().second() == 56
- && dt.time().msec() == 0);
- QCOMPARE(dt.timeSpec(), (pass == 0 ? Qt::LocalTime : Qt::UTC));
-
- dt = dt.addDays(-185);
- QCOMPARE(dt.date(), QDate(2004, 1, 1));
- QCOMPARE(dt.time(), QTime(12, 34, 56));
- }
-
- QDateTime dt(QDate(1752, 9, 14), QTime(12, 34, 56));
- while (dt.date().year() < 8000) {
- int year = dt.date().year();
- if (QDate::isLeapYear(year + 1))
- dt = dt.addDays(366);
- else
- dt = dt.addDays(365);
- QCOMPARE(dt.date(), QDate(year + 1, 9, 14));
- QCOMPARE(dt.time(), QTime(12, 34, 56));
- }
-
- // Test preserves TimeSpec
- QDateTime dt1(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime dt2 = dt1.addDays(2);
- QCOMPARE(dt2.date(), QDate(2013, 1, 3));
- QCOMPARE(dt2.time(), QTime(0, 0, 0));
- QCOMPARE(dt2.timeSpec(), Qt::UTC);
-
- dt1 = QDateTime(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
- dt2 = dt1.addDays(2);
- QCOMPARE(dt2.date(), QDate(2013, 1, 3));
- QCOMPARE(dt2.time(), QTime(0, 0, 0));
- QCOMPARE(dt2.timeSpec(), Qt::LocalTime);
-
- dt1 = QDateTime(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::OffsetFromUTC, 60*60);
- dt2 = dt1.addDays(2);
- QCOMPARE(dt2.date(), QDate(2013, 1, 3));
- QCOMPARE(dt2.time(), QTime(0, 0, 0));
- QCOMPARE(dt2.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(dt2.offsetFromUtc(), 60 * 60);
-
- // ### test invalid QDateTime()
-}
-
-
-void tst_QDateTime::addMonths_data()
-{
- QTest::addColumn<int>("months");
- QTest::addColumn<QDate>("resultDate");
-
- QTest::newRow("-15") << -15 << QDate(2002, 10, 31);
- QTest::newRow("-14") << -14 << QDate(2002, 11, 30);
- QTest::newRow("-13") << -13 << QDate(2002, 12, 31);
- QTest::newRow("-12") << -12 << QDate(2003, 1, 31);
-
- QTest::newRow("-11") << -11 << QDate(2003, 2, 28);
- QTest::newRow("-10") << -10 << QDate(2003, 3, 31);
- QTest::newRow("-9") << -9 << QDate(2003, 4, 30);
- QTest::newRow("-8") << -8 << QDate(2003, 5, 31);
- QTest::newRow("-7") << -7 << QDate(2003, 6, 30);
- QTest::newRow("-6") << -6 << QDate(2003, 7, 31);
- QTest::newRow("-5") << -5 << QDate(2003, 8, 31);
- QTest::newRow("-4") << -4 << QDate(2003, 9, 30);
- QTest::newRow("-3") << -3 << QDate(2003, 10, 31);
- QTest::newRow("-2") << -2 << QDate(2003, 11, 30);
- QTest::newRow("-1") << -1 << QDate(2003, 12, 31);
- QTest::newRow("0") << 0 << QDate(2004, 1, 31);
- QTest::newRow("1") << 1 << QDate(2004, 2, 29);
- QTest::newRow("2") << 2 << QDate(2004, 3, 31);
- QTest::newRow("3") << 3 << QDate(2004, 4, 30);
- QTest::newRow("4") << 4 << QDate(2004, 5, 31);
- QTest::newRow("5") << 5 << QDate(2004, 6, 30);
- QTest::newRow("6") << 6 << QDate(2004, 7, 31);
- QTest::newRow("7") << 7 << QDate(2004, 8, 31);
- QTest::newRow("8") << 8 << QDate(2004, 9, 30);
- QTest::newRow("9") << 9 << QDate(2004, 10, 31);
- QTest::newRow("10") << 10 << QDate(2004, 11, 30);
- QTest::newRow("11") << 11 << QDate(2004, 12, 31);
- QTest::newRow("12") << 12 << QDate(2005, 1, 31);
- QTest::newRow("13") << 13 << QDate(2005, 2, 28);
- QTest::newRow("14") << 14 << QDate(2005, 3, 31);
- QTest::newRow("15") << 15 << QDate(2005, 4, 30);
-}
-
-void tst_QDateTime::addMonths()
-{
- QFETCH(int, months);
- QFETCH(QDate, resultDate);
-
- QDate testDate(2004, 1, 31);
- QTime testTime(12, 34, 56);
- QDateTime start(testDate, testTime);
- QDateTime end = start.addMonths(months);
- QCOMPARE(end.date(), resultDate);
- QCOMPARE(end.time(), testTime);
- QCOMPARE(end.timeSpec(), Qt::LocalTime);
-
- start = QDateTime(testDate, testTime, Qt::UTC);
- end = start.addMonths(months);
- QCOMPARE(end.date(), resultDate);
- QCOMPARE(end.time(), testTime);
- QCOMPARE(end.timeSpec(), Qt::UTC);
-
- start = QDateTime(testDate, testTime, Qt::OffsetFromUTC, 60 * 60);
- end = start.addMonths(months);
- QCOMPARE(end.date(), resultDate);
- QCOMPARE(end.time(), testTime);
- QCOMPARE(end.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(end.offsetFromUtc(), 60 * 60);
-}
-
-void tst_QDateTime::addYears_data()
-{
- QTest::addColumn<int>("years1");
- QTest::addColumn<int>("years2");
- QTest::addColumn<QDate>("startDate");
- QTest::addColumn<QDate>("resultDate");
-
- QTest::newRow("0") << 0 << 0 << QDate(1752, 9, 14) << QDate(1752, 9, 14);
- QTest::newRow("4000 - 4000") << 4000 << -4000 << QDate(1752, 9, 14) << QDate(1752, 9, 14);
- QTest::newRow("10") << 10 << 0 << QDate(1752, 9, 14) << QDate(1762, 9, 14);
- QTest::newRow("0 leap year") << 0 << 0 << QDate(1760, 2, 29) << QDate(1760, 2, 29);
- QTest::newRow("1 leap year") << 1 << 0 << QDate(1760, 2, 29) << QDate(1761, 2, 28);
- QTest::newRow("2 leap year") << 2 << 0 << QDate(1760, 2, 29) << QDate(1762, 2, 28);
- QTest::newRow("3 leap year") << 3 << 0 << QDate(1760, 2, 29) << QDate(1763, 2, 28);
- QTest::newRow("4 leap year") << 4 << 0 << QDate(1760, 2, 29) << QDate(1764, 2, 29);
-
- QTest::newRow("toNegative1") << -2000 << 0 << QDate(1752, 9, 14) << QDate(-249, 9, 14);
- QTest::newRow("toNegative2") << -1752 << 0 << QDate(1752, 9, 14) << QDate(-1, 9, 14);
- QTest::newRow("toNegative3") << -1751 << 0 << QDate(1752, 9, 14) << QDate(1, 9, 14);
- QTest::newRow("toPositive1") << 2000 << 0 << QDate(-1752, 9, 14) << QDate(249, 9, 14);
- QTest::newRow("toPositive2") << 1752 << 0 << QDate(-1752, 9, 14) << QDate(1, 9, 14);
- QTest::newRow("toPositive3") << 1751 << 0 << QDate(-1752, 9, 14) << QDate(-1, 9, 14);
-}
-
-void tst_QDateTime::addYears()
-{
- QFETCH(int, years1);
- QFETCH(int, years2);
- QFETCH(QDate, startDate);
- QFETCH(QDate, resultDate);
-
- QTime testTime(14, 25, 36);
- QDateTime start(startDate, testTime);
- QDateTime end = start.addYears(years1).addYears(years2);
- QCOMPARE(end.date(), resultDate);
- QCOMPARE(end.time(), testTime);
- QCOMPARE(end.timeSpec(), Qt::LocalTime);
-
- start = QDateTime(startDate, testTime, Qt::UTC);
- end = start.addYears(years1).addYears(years2);
- QCOMPARE(end.date(), resultDate);
- QCOMPARE(end.time(), testTime);
- QCOMPARE(end.timeSpec(), Qt::UTC);
-
- start = QDateTime(startDate, testTime, Qt::OffsetFromUTC, 60 * 60);
- end = start.addYears(years1).addYears(years2);
- QCOMPARE(end.date(), resultDate);
- QCOMPARE(end.time(), testTime);
- QCOMPARE(end.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(end.offsetFromUtc(), 60 * 60);
-}
-
-void tst_QDateTime::addSecs_data()
-{
- QTest::addColumn<QDateTime>("dt");
- QTest::addColumn<int>("nsecs");
- QTest::addColumn<QDateTime>("result");
-
- QTime standardTime(12, 34, 56);
- QTime daylightTime(13, 34, 56);
-
- QTest::newRow("utc0") << QDateTime(QDate(2004, 1, 1), standardTime, Qt::UTC) << 86400
- << QDateTime(QDate(2004, 1, 2), standardTime, Qt::UTC);
- QTest::newRow("utc1") << QDateTime(QDate(2004, 1, 1), standardTime, Qt::UTC) << (86400 * 185)
- << QDateTime(QDate(2004, 7, 4), standardTime, Qt::UTC);
- QTest::newRow("utc2") << QDateTime(QDate(2004, 1, 1), standardTime, Qt::UTC) << (86400 * 366)
- << QDateTime(QDate(2005, 1, 1), standardTime, Qt::UTC);
- QTest::newRow("utc3") << QDateTime(QDate(1760, 1, 1), standardTime, Qt::UTC) << 86400
- << QDateTime(QDate(1760, 1, 2), standardTime, Qt::UTC);
- QTest::newRow("utc4") << QDateTime(QDate(1760, 1, 1), standardTime, Qt::UTC) << (86400 * 185)
- << QDateTime(QDate(1760, 7, 4), standardTime, Qt::UTC);
- QTest::newRow("utc5") << QDateTime(QDate(1760, 1, 1), standardTime, Qt::UTC) << (86400 * 366)
- << QDateTime(QDate(1761, 1, 1), standardTime, Qt::UTC);
- QTest::newRow("utc6") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::UTC) << 86400
- << QDateTime(QDate(4000, 1, 2), standardTime, Qt::UTC);
- QTest::newRow("utc7") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::UTC) << (86400 * 185)
- << QDateTime(QDate(4000, 7, 4), standardTime, Qt::UTC);
- QTest::newRow("utc8") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::UTC) << (86400 * 366)
- << QDateTime(QDate(4001, 1, 1), standardTime, Qt::UTC);
- QTest::newRow("utc9") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::UTC) << 0
- << QDateTime(QDate(4000, 1, 1), standardTime, Qt::UTC);
-
- if (zoneIsCET) {
- QTest::newRow("cet0") << QDateTime(QDate(2004, 1, 1), standardTime, Qt::LocalTime) << 86400
- << QDateTime(QDate(2004, 1, 2), standardTime, Qt::LocalTime);
- QTest::newRow("cet1") << QDateTime(QDate(2004, 1, 1), standardTime, Qt::LocalTime) << (86400 * 185)
- << QDateTime(QDate(2004, 7, 4), daylightTime, Qt::LocalTime);
- QTest::newRow("cet2") << QDateTime(QDate(2004, 1, 1), standardTime, Qt::LocalTime) << (86400 * 366)
- << QDateTime(QDate(2005, 1, 1), standardTime, Qt::LocalTime);
- QTest::newRow("cet3") << QDateTime(QDate(1760, 1, 1), standardTime, Qt::LocalTime) << 86400
- << QDateTime(QDate(1760, 1, 2), standardTime, Qt::LocalTime);
- QTest::newRow("cet4") << QDateTime(QDate(1760, 1, 1), standardTime, Qt::LocalTime) << (86400 * 185)
- << QDateTime(QDate(1760, 7, 4), standardTime, Qt::LocalTime);
- QTest::newRow("cet5") << QDateTime(QDate(1760, 1, 1), standardTime, Qt::LocalTime) << (86400 * 366)
- << QDateTime(QDate(1761, 1, 1), standardTime, Qt::LocalTime);
- QTest::newRow("cet6") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::LocalTime) << 86400
- << QDateTime(QDate(4000, 1, 2), standardTime, Qt::LocalTime);
- QTest::newRow("cet7") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::LocalTime) << (86400 * 185)
- << QDateTime(QDate(4000, 7, 4), daylightTime, Qt::LocalTime);
- QTest::newRow("cet8") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::LocalTime) << (86400 * 366)
- << QDateTime(QDate(4001, 1, 1), standardTime, Qt::LocalTime);
- QTest::newRow("cet9") << QDateTime(QDate(4000, 1, 1), standardTime, Qt::LocalTime) << 0
- << QDateTime(QDate(4000, 1, 1), standardTime, Qt::LocalTime);
- }
-
- // Year sign change
- QTest::newRow("toNegative") << QDateTime(QDate(1, 1, 1), QTime(0, 0, 0), Qt::UTC)
- << -1
- << QDateTime(QDate(-1, 12, 31), QTime(23, 59, 59), Qt::UTC);
- QTest::newRow("toPositive") << QDateTime(QDate(-1, 12, 31), QTime(23, 59, 59), Qt::UTC)
- << 1
- << QDateTime(QDate(1, 1, 1), QTime(0, 0, 0), Qt::UTC);
-
- QTest::newRow("invalid") << invalidDateTime() << 1 << invalidDateTime();
-
- // Check Offset details are preserved
- QTest::newRow("offset0") << QDateTime(QDate(2013, 1, 1), QTime(1, 2, 3),
- Qt::OffsetFromUTC, 60 * 60)
- << 60 * 60
- << QDateTime(QDate(2013, 1, 1), QTime(2, 2, 3),
- Qt::OffsetFromUTC, 60 * 60);
-}
-
-void tst_QDateTime::addSecs()
-{
- QFETCH(QDateTime, dt);
- QFETCH(int, nsecs);
- QFETCH(QDateTime, result);
- QDateTime test = dt.addSecs(nsecs);
- QCOMPARE(test, result);
- QCOMPARE(test.timeSpec(), dt.timeSpec());
- if (test.timeSpec() == Qt::OffsetFromUTC)
- QCOMPARE(test.offsetFromUtc(), dt.offsetFromUtc());
- QCOMPARE(result.addSecs(-nsecs), dt);
-}
-
-void tst_QDateTime::addMSecs_data()
-{
- addSecs_data();
-}
-
-void tst_QDateTime::addMSecs()
-{
- QFETCH(QDateTime, dt);
- QFETCH(int, nsecs);
- QFETCH(QDateTime, result);
-
- QDateTime test = dt.addMSecs(qint64(nsecs) * 1000);
- QCOMPARE(test, result);
- QCOMPARE(test.timeSpec(), dt.timeSpec());
- if (test.timeSpec() == Qt::OffsetFromUTC)
- QCOMPARE(test.offsetFromUtc(), dt.offsetFromUtc());
- QCOMPARE(result.addMSecs(qint64(-nsecs) * 1000), dt);
-}
-
-void tst_QDateTime::toTimeSpec_data()
-{
- QTest::addColumn<QDateTime>("fromUtc");
- QTest::addColumn<QDateTime>("fromLocal");
-
- QTime utcTime(4, 20, 30);
- QTime localStandardTime(5, 20, 30);
- QTime localDaylightTime(6, 20, 30);
-
- QTest::newRow("winter1") << QDateTime(QDate(2004, 1, 1), utcTime, Qt::UTC)
- << QDateTime(QDate(2004, 1, 1), localStandardTime, Qt::LocalTime);
- QTest::newRow("winter2") << QDateTime(QDate(2004, 2, 29), utcTime, Qt::UTC)
- << QDateTime(QDate(2004, 2, 29), localStandardTime, Qt::LocalTime);
- QTest::newRow("winter3") << QDateTime(QDate(1760, 2, 29), utcTime, Qt::UTC)
- << QDateTime(QDate(1760, 2, 29), localStandardTime, Qt::LocalTime);
- QTest::newRow("winter4") << QDateTime(QDate(6000, 2, 29), utcTime, Qt::UTC)
- << QDateTime(QDate(6000, 2, 29), localStandardTime, Qt::LocalTime);
-
- // Test mktime boundaries (1970 - 2038) and adjustDate().
- QTest::newRow("1969/12/31 23:00 UTC")
- << QDateTime(QDate(1969, 12, 31), QTime(23, 0, 0), Qt::UTC)
- << QDateTime(QDate(1970, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
- QTest::newRow("2037/12/31 23:00 UTC")
- << QDateTime(QDate(2037, 12, 31), QTime(23, 0, 0), Qt::UTC)
- << QDateTime(QDate(2038, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
-
- QTest::newRow("-271821/4/20 00:00 UTC (JavaScript min date, start of day)")
- << QDateTime(QDate(-271821, 4, 20), QTime(0, 0, 0), Qt::UTC)
- << QDateTime(QDate(-271821, 4, 20), QTime(1, 0, 0), Qt::LocalTime);
- QTest::newRow("-271821/4/20 23:00 UTC (JavaScript min date, end of day)")
- << QDateTime(QDate(-271821, 4, 20), QTime(23, 0, 0), Qt::UTC)
- << QDateTime(QDate(-271821, 4, 21), QTime(0, 0, 0), Qt::LocalTime);
-
- if (zoneIsCET) {
- QTest::newRow("summer1") << QDateTime(QDate(2004, 6, 30), utcTime, Qt::UTC)
- << QDateTime(QDate(2004, 6, 30), localDaylightTime, Qt::LocalTime);
- QTest::newRow("summer2") << QDateTime(QDate(1760, 6, 30), utcTime, Qt::UTC)
- << QDateTime(QDate(1760, 6, 30), localStandardTime, Qt::LocalTime);
- QTest::newRow("summer3") << QDateTime(QDate(4000, 6, 30), utcTime, Qt::UTC)
- << QDateTime(QDate(4000, 6, 30), localDaylightTime, Qt::LocalTime);
-
- QTest::newRow("275760/9/23 00:00 UTC (JavaScript max date, start of day)")
- << QDateTime(QDate(275760, 9, 23), QTime(0, 0, 0), Qt::UTC)
- << QDateTime(QDate(275760, 9, 23), QTime(2, 0, 0), Qt::LocalTime);
-
- QTest::newRow("275760/9/23 22:00 UTC (JavaScript max date, end of day)")
- << QDateTime(QDate(275760, 9, 23), QTime(22, 0, 0), Qt::UTC)
- << QDateTime(QDate(275760, 9, 24), QTime(0, 0, 0), Qt::LocalTime);
- }
-
- QTest::newRow("msec") << QDateTime(QDate(4000, 6, 30), utcTime.addMSecs(1), Qt::UTC)
- << QDateTime(QDate(4000, 6, 30), localDaylightTime.addMSecs(1), Qt::LocalTime);
-}
-
-void tst_QDateTime::toTimeSpec()
-{
- if (zoneIsCET) {
- QFETCH(QDateTime, fromUtc);
- QFETCH(QDateTime, fromLocal);
-
- QDateTime utcToUtc = fromUtc.toTimeSpec(Qt::UTC);
- QDateTime localToLocal = fromLocal.toTimeSpec(Qt::LocalTime);
- QDateTime utcToLocal = fromUtc.toTimeSpec(Qt::LocalTime);
- QDateTime localToUtc = fromLocal.toTimeSpec(Qt::UTC);
- QDateTime utcToOffset = fromUtc.toTimeSpec(Qt::OffsetFromUTC);
- QDateTime localToOffset = fromLocal.toTimeSpec(Qt::OffsetFromUTC);
-
- QCOMPARE(utcToUtc, fromUtc);
- QCOMPARE(utcToUtc.date(), fromUtc.date());
- QCOMPARE(utcToUtc.time(), fromUtc.time());
- QCOMPARE(utcToUtc.timeSpec(), Qt::UTC);
-
- QCOMPARE(localToLocal, fromLocal);
- QCOMPARE(localToLocal.date(), fromLocal.date());
- QCOMPARE(localToLocal.time(), fromLocal.time());
- QCOMPARE(localToLocal.timeSpec(), Qt::LocalTime);
-
- QCOMPARE(utcToLocal, fromLocal);
- QCOMPARE(utcToLocal.date(), fromLocal.date());
- QCOMPARE(utcToLocal.time(), fromLocal.time());
- QCOMPARE(utcToLocal.timeSpec(), Qt::LocalTime);
- QCOMPARE(utcToLocal.toTimeSpec(Qt::UTC), fromUtc);
-
- QCOMPARE(localToUtc, fromUtc);
- QCOMPARE(localToUtc.date(), fromUtc.date());
- QCOMPARE(localToUtc.time(), fromUtc.time());
- QCOMPARE(localToUtc.timeSpec(), Qt::UTC);
- QCOMPARE(localToUtc.toTimeSpec(Qt::LocalTime), fromLocal);
-
- QCOMPARE(utcToUtc, localToUtc);
- QCOMPARE(utcToUtc.date(), localToUtc.date());
- QCOMPARE(utcToUtc.time(), localToUtc.time());
- QCOMPARE(utcToUtc.timeSpec(), Qt::UTC);
-
- QCOMPARE(utcToLocal, localToLocal);
- QCOMPARE(utcToLocal.date(), localToLocal.date());
- QCOMPARE(utcToLocal.time(), localToLocal.time());
- QCOMPARE(utcToLocal.timeSpec(), Qt::LocalTime);
-
- // OffsetToUTC becomes UTC
- QCOMPARE(utcToOffset, fromUtc);
- QCOMPARE(utcToOffset.date(), fromUtc.date());
- QCOMPARE(utcToOffset.time(), fromUtc.time());
- QCOMPARE(utcToOffset.timeSpec(), Qt::UTC);
- QCOMPARE(utcToOffset.toTimeSpec(Qt::UTC), fromUtc);
-
- QCOMPARE(localToOffset, fromUtc);
- QCOMPARE(localToOffset.date(), fromUtc.date());
- QCOMPARE(localToOffset.time(), fromUtc.time());
- QCOMPARE(localToOffset.timeSpec(), Qt::UTC);
- QCOMPARE(localToOffset.toTimeSpec(Qt::LocalTime), fromLocal);
- } else {
- QSKIP("Not tested with timezone other than Central European (CET/CEST)");
- }
-}
-
-void tst_QDateTime::toLocalTime_data()
-{
- toTimeSpec_data();
-}
-
-void tst_QDateTime::toLocalTime()
-{
- if (zoneIsCET) {
- QFETCH(QDateTime, fromUtc);
- QFETCH(QDateTime, fromLocal);
-
- QCOMPARE(fromLocal.toLocalTime(), fromLocal);
- QCOMPARE(fromUtc.toLocalTime(), fromLocal);
- QCOMPARE(fromUtc.toLocalTime(), fromLocal.toLocalTime());
- } else {
- QSKIP("Not tested with timezone other than Central European (CET/CEST)");
- }
-}
-
-void tst_QDateTime::toUTC_data()
-{
- toTimeSpec_data();
-}
-
-void tst_QDateTime::toUTC()
-{
- if (zoneIsCET) {
- QFETCH(QDateTime, fromUtc);
- QFETCH(QDateTime, fromLocal);
-
- QCOMPARE(fromUtc.toUTC(), fromUtc);
- QCOMPARE(fromLocal.toUTC(), fromUtc);
- QCOMPARE(fromUtc.toUTC(), fromLocal.toUTC());
- } else {
- QSKIP("Not tested with timezone other than Central European (CET/CEST)");
- }
-
- QDateTime dt = QDateTime::currentDateTime();
- if(dt.time().msec() == 0){
- dt.setTime(dt.time().addMSecs(1));
- }
- QString s = dt.toString("zzz");
- QString t = dt.toUTC().toString("zzz");
- QCOMPARE(s, t);
-}
-
-void tst_QDateTime::daysTo()
-{
- QDateTime dt1(QDate(1760, 1, 2), QTime());
- QDateTime dt2(QDate(1760, 2, 2), QTime());
- QDateTime dt3(QDate(1760, 3, 2), QTime());
-
- QCOMPARE(dt1.daysTo(dt2), (qint64) 31);
- QCOMPARE(dt1.addDays(31), dt2);
-
- QCOMPARE(dt2.daysTo(dt3), (qint64) 29);
- QCOMPARE(dt2.addDays(29), dt3);
-
- QCOMPARE(dt1.daysTo(dt3), (qint64) 60);
- QCOMPARE(dt1.addDays(60), dt3);
-
- QCOMPARE(dt2.daysTo(dt1), (qint64) -31);
- QCOMPARE(dt2.addDays(-31), dt1);
-
- QCOMPARE(dt3.daysTo(dt2), (qint64) -29);
- QCOMPARE(dt3.addDays(-29), dt2);
-
- QCOMPARE(dt3.daysTo(dt1), (qint64) -60);
- QCOMPARE(dt3.addDays(-60), dt1);
-}
-
-void tst_QDateTime::secsTo_data()
-{
- addSecs_data();
-
- QTest::newRow("disregard milliseconds #1")
- << QDateTime(QDate(2012, 3, 7), QTime(0, 58, 0, 0)) << 60
- << QDateTime(QDate(2012, 3, 7), QTime(0, 59, 0, 400));
-
- QTest::newRow("disregard milliseconds #2")
- << QDateTime(QDate(2012, 3, 7), QTime(0, 59, 0, 0)) << 60
- << QDateTime(QDate(2012, 3, 7), QTime(1, 0, 0, 400));
-}
-
-void tst_QDateTime::secsTo()
-{
- QFETCH(QDateTime, dt);
- QFETCH(int, nsecs);
- QFETCH(QDateTime, result);
-
- if (dt.isValid()) {
- QCOMPARE(dt.secsTo(result), (qint64)nsecs);
- QCOMPARE(result.secsTo(dt), (qint64)-nsecs);
- QVERIFY((dt == result) == (0 == nsecs));
- QVERIFY((dt != result) == (0 != nsecs));
- QVERIFY((dt < result) == (0 < nsecs));
- QVERIFY((dt <= result) == (0 <= nsecs));
- QVERIFY((dt > result) == (0 > nsecs));
- QVERIFY((dt >= result) == (0 >= nsecs));
- } else {
- QVERIFY(dt.secsTo(result) == 0);
- QVERIFY(result.secsTo(dt) == 0);
- }
-}
-
-void tst_QDateTime::msecsTo_data()
-{
- addMSecs_data();
-}
-
-void tst_QDateTime::msecsTo()
-{
- QFETCH(QDateTime, dt);
- QFETCH(int, nsecs);
- QFETCH(QDateTime, result);
-
- if (dt.isValid()) {
- QCOMPARE(dt.msecsTo(result), qint64(nsecs) * 1000);
- QCOMPARE(result.msecsTo(dt), -qint64(nsecs) * 1000);
- QVERIFY((dt == result) == (0 == (qint64(nsecs) * 1000)));
- QVERIFY((dt != result) == (0 != (qint64(nsecs) * 1000)));
- QVERIFY((dt < result) == (0 < (qint64(nsecs) * 1000)));
- QVERIFY((dt <= result) == (0 <= (qint64(nsecs) * 1000)));
- QVERIFY((dt > result) == (0 > (qint64(nsecs) * 1000)));
- QVERIFY((dt >= result) == (0 >= (qint64(nsecs) * 1000)));
- } else {
- QVERIFY(dt.msecsTo(result) == 0);
- QVERIFY(result.msecsTo(dt) == 0);
- }
-}
-
-void tst_QDateTime::currentDateTime()
-{
- time_t buf1, buf2;
- ::time(&buf1);
- QDateTime lowerBound;
- lowerBound.setSecsSinceEpoch(buf1);
-
- QDateTime dt1 = QDateTime::currentDateTime();
- QDateTime dt2 = QDateTime::currentDateTime().toLocalTime();
- QDateTime dt3 = QDateTime::currentDateTime().toUTC();
-
- ::time(&buf2);
-
- QDateTime upperBound;
- upperBound.setSecsSinceEpoch(buf2);
- // Note we must add 2 seconds here because time() may return up to
- // 1 second difference from the more accurate method used by QDateTime::currentDateTime()
- upperBound = upperBound.addSecs(2);
-
- QString details = QString("\n"
- "lowerBound: %1\n"
- "dt1: %2\n"
- "dt2: %3\n"
- "dt3: %4\n"
- "upperBound: %5\n")
- .arg(lowerBound.toSecsSinceEpoch())
- .arg(dt1.toSecsSinceEpoch())
- .arg(dt2.toSecsSinceEpoch())
- .arg(dt3.toSecsSinceEpoch())
- .arg(upperBound.toSecsSinceEpoch());
-
- QVERIFY2(lowerBound < upperBound, qPrintable(details));
-
- QVERIFY2(lowerBound <= dt1, qPrintable(details));
- QVERIFY2(dt1 < upperBound, qPrintable(details));
- QVERIFY2(lowerBound <= dt2, qPrintable(details));
- QVERIFY2(dt2 < upperBound, qPrintable(details));
- QVERIFY2(lowerBound <= dt3, qPrintable(details));
- QVERIFY2(dt3 < upperBound, qPrintable(details));
-
- QVERIFY(dt1.timeSpec() == Qt::LocalTime);
- QVERIFY(dt2.timeSpec() == Qt::LocalTime);
- QVERIFY(dt3.timeSpec() == Qt::UTC);
-}
-
-void tst_QDateTime::currentDateTimeUtc()
-{
- time_t buf1, buf2;
- ::time(&buf1);
-
- QDateTime lowerBound;
- lowerBound.setSecsSinceEpoch(buf1);
-
- QDateTime dt1 = QDateTime::currentDateTimeUtc();
- QDateTime dt2 = QDateTime::currentDateTimeUtc().toLocalTime();
- QDateTime dt3 = QDateTime::currentDateTimeUtc().toUTC();
-
- ::time(&buf2);
-
- QDateTime upperBound;
- upperBound.setSecsSinceEpoch(buf2);
- // Note we must add 2 seconds here because time() may return up to
- // 1 second difference from the more accurate method used by QDateTime::currentDateTime()
- upperBound = upperBound.addSecs(2);
-
- QString details = QString("\n"
- "lowerBound: %1\n"
- "dt1: %2\n"
- "dt2: %3\n"
- "dt3: %4\n"
- "upperBound: %5\n")
- .arg(lowerBound.toSecsSinceEpoch())
- .arg(dt1.toSecsSinceEpoch())
- .arg(dt2.toSecsSinceEpoch())
- .arg(dt3.toSecsSinceEpoch())
- .arg(upperBound.toSecsSinceEpoch());
-
- QVERIFY2(lowerBound < upperBound, qPrintable(details));
-
- QVERIFY2(lowerBound <= dt1, qPrintable(details));
- QVERIFY2(dt1 < upperBound, qPrintable(details));
- QVERIFY2(lowerBound <= dt2, qPrintable(details));
- QVERIFY2(dt2 < upperBound, qPrintable(details));
- QVERIFY2(lowerBound <= dt3, qPrintable(details));
- QVERIFY2(dt3 < upperBound, qPrintable(details));
-
- QVERIFY(dt1.timeSpec() == Qt::UTC);
- QVERIFY(dt2.timeSpec() == Qt::LocalTime);
- QVERIFY(dt3.timeSpec() == Qt::UTC);
-}
-
-void tst_QDateTime::currentDateTimeUtc2()
-{
- QDateTime local, utc;
- qint64 msec;
-
- // check that we got all down to the same milliseconds
- int i = 20;
- bool ok = false;
- do {
- local = QDateTime::currentDateTime();
- utc = QDateTime::currentDateTimeUtc();
- msec = QDateTime::currentMSecsSinceEpoch();
- ok = local.time().msec() == utc.time().msec()
- && utc.time().msec() == (msec % 1000);
- } while (--i && !ok);
-
- if (!i)
- QSKIP("Failed to get the dates within 1 ms of each other");
-
- // seconds and milliseconds should be the same:
- QCOMPARE(utc.time().second(), local.time().second());
- QCOMPARE(utc.time().msec(), local.time().msec());
- QCOMPARE(msec % 1000, qint64(local.time().msec()));
- QCOMPARE(msec / 1000 % 60, qint64(local.time().second()));
-
- // the two dates should be equal, actually
- QCOMPARE(local.toUTC(), utc);
- QCOMPARE(utc.toLocalTime(), local);
-
- // and finally, the SecsSinceEpoch should equal our number
- QCOMPARE(qint64(utc.toSecsSinceEpoch()), msec / 1000);
- QCOMPARE(qint64(local.toSecsSinceEpoch()), msec / 1000);
- QCOMPARE(utc.toMSecsSinceEpoch(), msec);
- QCOMPARE(local.toMSecsSinceEpoch(), msec);
-}
-
-void tst_QDateTime::toSecsSinceEpoch_data()
-{
- QTest::addColumn<QString>("dateTimeStr");
- QTest::addColumn<bool>("res");
-
- QTest::newRow( "data1" ) << str( 1800, 1, 1, 12, 0, 0 ) << false;
- QTest::newRow( "data2" ) << str( 1969, 1, 1, 12, 0, 0 ) << false;
- QTest::newRow( "data3" ) << str( 2002, 1, 1, 12, 0, 0 ) << true;
- QTest::newRow( "data4" ) << str( 2002, 6, 1, 12, 0, 0 ) << true;
- QTest::newRow( "data5" ) << QString("INVALID") << false;
- QTest::newRow( "data6" ) << str( 2038, 1, 1, 12, 0, 0 ) << true;
- QTest::newRow( "data7" ) << str( 2063, 4, 5, 12, 0, 0 ) << true; // the day of First Contact
- QTest::newRow( "data8" ) << str( 2107, 1, 1, 12, 0, 0 )
- << bool( sizeof(uint) > 32 && sizeof(time_t) > 32 );
-}
-
-void tst_QDateTime::toSecsSinceEpoch()
-{
- QFETCH( QString, dateTimeStr );
- QDateTime datetime = dt( dateTimeStr );
-
- qint64 asSecsSinceEpoch = datetime.toSecsSinceEpoch();
- uint asTime_t = datetime.toTime_t();
- QFETCH( bool, res );
- if (res) {
- QVERIFY( asTime_t != (uint)-1 );
- } else {
- QVERIFY( asTime_t == (uint)-1 );
- }
- QCOMPARE(asSecsSinceEpoch, datetime.toMSecsSinceEpoch() / 1000);
-
- if ( asTime_t != (uint) -1 ) {
- QDateTime datetime2 = QDateTime::fromTime_t( asTime_t );
- QCOMPARE(datetime, datetime2);
- }
- QDateTime datetime2 = QDateTime::fromSecsSinceEpoch(asSecsSinceEpoch);
- QCOMPARE(datetime, datetime2);
-}
-
-void tst_QDateTime::daylightSavingsTimeChange_data()
-{
- QTest::addColumn<QDate>("inDST");
- QTest::addColumn<QDate>("outDST");
- QTest::addColumn<int>("days"); // from in to out; -ve if reversed
- QTest::addColumn<int>("months");
-
- QTest::newRow("Autumn") << QDate(2006, 8, 1) << QDate(2006, 12, 1)
- << 122 << 4;
-
- QTest::newRow("Spring") << QDate(2006, 5, 1) << QDate(2006, 2, 1)
- << -89 << -3;
-}
-
-void tst_QDateTime::daylightSavingsTimeChange()
-{
- // This has grown from a regression test for an old bug where starting with
- // a date in DST and then moving to a date outside it (or vice-versa) caused
- // 1-hour jumps in time when addSecs() was called.
- //
- // The bug was caused by QDateTime knowing more than it lets show.
- // Internally, if it knows, QDateTime stores a flag indicating if the time is
- // DST or not. If it doesn't, it sets to "LocalUnknown". The problem happened
- // because some functions did not reset the flag when moving in or out of DST.
-
- // WARNING: This only tests anything if there's a Daylight Savings Time change
- // in the current locale between inDST and outDST.
- // This is true for Central European Time and may be elsewhere.
-
- QFETCH(QDate, inDST);
- QFETCH(QDate, outDST);
- QFETCH(int, days);
- QFETCH(int, months);
-
- // First with simple construction
- QDateTime dt = QDateTime(outDST, QTime(0, 0, 0), Qt::LocalTime);
- int outDSTsecs = dt.toSecsSinceEpoch();
-
- dt.setDate(inDST);
- dt = dt.addSecs(1);
- QCOMPARE(dt, QDateTime(inDST, QTime(0, 0, 1)));
-
- // now using addDays:
- dt = dt.addDays(days).addSecs(1);
- QCOMPARE(dt, QDateTime(outDST, QTime(0, 0, 2)));
-
- // ... and back again:
- dt = dt.addDays(-days).addSecs(1);
- QCOMPARE(dt, QDateTime(inDST, QTime(0, 0, 3)));
-
- // now using addMonths:
- dt = dt.addMonths(months).addSecs(1);
- QCOMPARE(dt, QDateTime(outDST, QTime(0, 0, 4)));
-
- // ... and back again:
- dt = dt.addMonths(-months).addSecs(1);
- QCOMPARE(dt, QDateTime(inDST, QTime(0, 0, 5)));
-
- // now using fromSecsSinceEpoch
- dt = QDateTime::fromSecsSinceEpoch(outDSTsecs);
- QCOMPARE(dt, QDateTime(outDST, QTime(0, 0, 0)));
-
- dt.setDate(inDST);
- dt = dt.addSecs(60);
- QCOMPARE(dt, QDateTime(inDST, QTime(0, 1, 0)));
-
- // using addMonths:
- dt = dt.addMonths(months).addSecs(60);
- QCOMPARE(dt, QDateTime(outDST, QTime(0, 2, 0)));
- // back again:
- dt = dt.addMonths(-months).addSecs(60);
- QCOMPARE(dt, QDateTime(inDST, QTime(0, 3, 0)));
-
- // using addDays:
- dt = dt.addDays(days).addSecs(60);
- QCOMPARE(dt, QDateTime(outDST, QTime(0, 4, 0)));
- // back again:
- dt = dt.addDays(-days).addSecs(60);
- QCOMPARE(dt, QDateTime(inDST, QTime(0, 5, 0)));
-
- // Now use the result of a UTC -> LocalTime conversion
- dt = QDateTime(outDST, QTime(0, 0, 0), Qt::LocalTime).toUTC();
- dt = QDateTime(dt.date(), dt.time(), Qt::UTC).toLocalTime();
- QCOMPARE(dt, QDateTime(outDST, QTime(0, 0, 0)));
-
- // using addDays:
- dt = dt.addDays(-days).addSecs(3600);
- QCOMPARE(dt, QDateTime(inDST, QTime(1, 0, 0)));
- // back again
- dt = dt.addDays(days).addSecs(3600);
- QCOMPARE(dt, QDateTime(outDST, QTime(2, 0, 0)));
-
- // using addMonths:
- dt = dt.addMonths(-months).addSecs(3600);
- QCOMPARE(dt, QDateTime(inDST, QTime(3, 0, 0)));
- // back again:
- dt = dt.addMonths(months).addSecs(3600);
- QCOMPARE(dt, QDateTime(outDST, QTime(4, 0, 0)));
-
- // using setDate:
- dt.setDate(inDST);
- dt = dt.addSecs(3600);
- QCOMPARE(dt, QDateTime(inDST, QTime(5, 0, 0)));
-}
-
-void tst_QDateTime::springForward_data()
-{
- QTest::addColumn<QDate>("day"); // day of DST transition
- QTest::addColumn<QTime>("time"); // in the "missing hour"
- QTest::addColumn<int>("step"); // days to step; +ve from before, -ve from after
- QTest::addColumn<int>("adjust"); // minutes ahead of UTC on day stepped from
-
- /*
- Zone tests compare a summer and winter moment's SecsSinceEpoch to known values.
- This could in principle be flawed (two DST-using zones in the same
- hemisphere with the same DST and standard times but different transition
- times) but no actual example is known where this is a problem. Please
- document any such conflicts, if discovered.
-
- See http://www.timeanddate.com/time/zones/ for data on more candidates to
- test.
- */
-
- uint winter = QDateTime(QDate(2015, 1, 1), QTime()).toSecsSinceEpoch();
- uint summer = QDateTime(QDate(2015, 7, 1), QTime()).toSecsSinceEpoch();
-
- if (winter == 1420066800 && summer == 1435701600) {
- QTest::newRow("CET from day before") << QDate(2015, 3, 29) << QTime(2, 30, 0) << 1 << 60;
- QTest::newRow("CET from day after") << QDate(2015, 3, 29) << QTime(2, 30, 0) << -1 << 120;
- } else if (winter == 1420063200 && summer == 1435698000) {
- // e.g. Finland, where our CI runs ...
- QTest::newRow("EET from day before") << QDate(2015, 3, 29) << QTime(3, 30, 0) << 1 << 120;
- QTest::newRow("EET from day after") << QDate(2015, 3, 29) << QTime(3, 30, 0) << -1 << 180;
- } else if (winter == 1420070400 && summer == 1435705200) {
- // Western European Time, WET/WEST; a.k.a. GMT/BST
- QTest::newRow("WET from day before") << QDate(2015, 3, 29) << QTime(1, 30, 0) << 1 << 0;
- QTest::newRow("WET from day after") << QDate(2015, 3, 29) << QTime(1, 30, 0) << -1 << 60;
- } else if (winter == 1420099200 && summer == 1435734000) {
- // Western USA, Canada: Pacific Time (e.g. US/Pacific)
- QTest::newRow("PT from day before") << QDate(2015, 3, 8) << QTime(2, 30, 0) << 1 << -480;
- QTest::newRow("PT from day after") << QDate(2015, 3, 8) << QTime(2, 30, 0) << -1 << -420;
- } else if (winter == 1420088400 && summer == 1435723200) {
- // Eastern USA, Canada: Eastern Time (e.g. US/Eastern)
- QTest::newRow("ET from day before") << QDate(2015, 3, 8) << QTime(2, 30, 0) << 1 << -300;
- QTest::newRow("ET from day after") << QDate(2015, 3, 8) << QTime(2, 30, 0) << -1 << -240;
- } else {
- // Includes the numbers you need to test for your zone, as above:
- QString msg(QString::fromLatin1("No spring forward test data for this TZ (%1, %2)"
- ).arg(winter).arg(summer));
- QSKIP(qPrintable(msg));
- }
-}
-
-void tst_QDateTime::springForward()
-{
- QFETCH(QDate, day);
- QFETCH(QTime, time);
- QFETCH(int, step);
- QFETCH(int, adjust);
-
- QDateTime direct = QDateTime(day.addDays(-step), time, Qt::LocalTime).addDays(step);
- if (direct.isValid()) { // mktime() may deem a time in the gap invalid
- QCOMPARE(direct.date(), day);
- QCOMPARE(direct.time().minute(), time.minute());
- QCOMPARE(direct.time().second(), time.second());
- int off = direct.time().hour() - time.hour();
- QVERIFY(off == 1 || off == -1);
- // Note: function doc claims always +1, but this should be reviewed !
- }
-
- // Repeat, but getting there via .toLocalTime():
- QDateTime detour = QDateTime(day.addDays(-step),
- time.addSecs(-60 * adjust),
- Qt::UTC).toLocalTime();
- QCOMPARE(detour.time(), time);
- detour = detour.addDays(step);
- // Insist on consistency:
- if (direct.isValid())
- QCOMPARE(detour, direct);
- else
- QVERIFY(!detour.isValid());
-}
-
-void tst_QDateTime::operator_eqeq_data()
-{
- QTest::addColumn<QDateTime>("dt1");
- QTest::addColumn<QDateTime>("dt2");
- QTest::addColumn<bool>("expectEqual");
- QTest::addColumn<bool>("checkEuro");
-
- QDateTime dateTime1(QDate(2012, 6, 20), QTime(14, 33, 2, 500));
- QDateTime dateTime1a = dateTime1.addMSecs(1);
- QDateTime dateTime2(QDate(2012, 20, 6), QTime(14, 33, 2, 500));
- QDateTime dateTime2a = dateTime2.addMSecs(-1);
- QDateTime dateTime3(QDate(1970, 1, 1), QTime(0, 0, 0, 0), Qt::UTC); // UTC epoch
- QDateTime dateTime3a = dateTime3.addDays(1);
- QDateTime dateTime3b = dateTime3.addDays(-1);
- // Ensure that different times may be equal when considering timezone.
- QDateTime dateTime3c(dateTime3.addSecs(3600));
- dateTime3c.setOffsetFromUtc(3600);
- QDateTime dateTime3d(dateTime3.addSecs(-3600));
- dateTime3d.setOffsetFromUtc(-3600);
- QDateTime dateTime3e(dateTime3.date(), dateTime3.time()); // Local time's epoch
-
- QTest::newRow("data0") << dateTime1 << dateTime1 << true << false;
- QTest::newRow("data1") << dateTime2 << dateTime2 << true << false;
- QTest::newRow("data2") << dateTime1a << dateTime1a << true << false;
- QTest::newRow("data3") << dateTime1 << dateTime2 << false << false;
- QTest::newRow("data4") << dateTime1 << dateTime1a << false << false;
- QTest::newRow("data5") << dateTime2 << dateTime2a << false << false;
- QTest::newRow("data6") << dateTime2 << dateTime3 << false << false;
- QTest::newRow("data7") << dateTime3 << dateTime3a << false << false;
- QTest::newRow("data8") << dateTime3 << dateTime3b << false << false;
- QTest::newRow("data9") << dateTime3a << dateTime3b << false << false;
- QTest::newRow("data10") << dateTime3 << dateTime3c << true << false;
- QTest::newRow("data11") << dateTime3 << dateTime3d << true << false;
- QTest::newRow("data12") << dateTime3c << dateTime3d << true << false;
- if (localTimeType == LocalTimeIsUtc)
- QTest::newRow("data13") << dateTime3 << dateTime3e << true << false;
- // ... but a zone (sometimes) ahead of or behind UTC (e.g. Europe/London)
- // might agree with UTC about the epoch, all the same.
-
- QTest::newRow("invalid == invalid") << invalidDateTime() << invalidDateTime() << true << false;
- QTest::newRow("invalid == valid #1") << invalidDateTime() << dateTime1 << false << false;
-
- if (zoneIsCET) {
- QTest::newRow("data14") << QDateTime(QDate(2004, 1, 2), QTime(2, 2, 3), Qt::LocalTime)
- << QDateTime(QDate(2004, 1, 2), QTime(1, 2, 3), Qt::UTC) << true << true;
- }
-}
-
-void tst_QDateTime::operator_eqeq()
-{
- QFETCH(QDateTime, dt1);
- QFETCH(QDateTime, dt2);
- QFETCH(bool, expectEqual);
- QFETCH(bool, checkEuro);
-
- QVERIFY(dt1 == dt1);
- QVERIFY(!(dt1 != dt1));
-
- QVERIFY(dt2 == dt2);
- QVERIFY(!(dt2 != dt2));
-
- QVERIFY(dt1 != QDateTime::currentDateTime());
- QVERIFY(dt2 != QDateTime::currentDateTime());
-
- QVERIFY(dt1.toUTC() == dt1.toUTC());
-
- bool equal = dt1 == dt2;
- QCOMPARE(equal, expectEqual);
- bool notEqual = dt1 != dt2;
- QCOMPARE(notEqual, !expectEqual);
-
- if (equal)
- QVERIFY(qHash(dt1) == qHash(dt2));
-
- if (checkEuro && zoneIsCET) {
- QVERIFY(dt1.toUTC() == dt2);
- QVERIFY(dt1 == dt2.toLocalTime());
- }
-}
-
-Q_DECLARE_METATYPE(QDataStream::Version)
-
-void tst_QDateTime::operator_insert_extract_data()
-{
- QTest::addColumn<QDateTime>("dateTime");
- QTest::addColumn<QString>("serialiseAs");
- QTest::addColumn<QString>("deserialiseAs");
- QTest::addColumn<QDataStream::Version>("dataStreamVersion");
-
- const QDateTime positiveYear(QDateTime(QDate(2012, 8, 14), QTime(8, 0, 0), Qt::LocalTime));
- const QDateTime negativeYear(QDateTime(QDate(-2012, 8, 14), QTime(8, 0, 0), Qt::LocalTime));
-
- const QString westernAustralia(QString::fromLatin1("AWST-8AWDT-9,M10.5.0,M3.5.0/03:00:00"));
- const QString hawaii(QString::fromLatin1("HAW10"));
-
- const QDataStream tmpDataStream;
- const int thisVersion = tmpDataStream.version();
- for (int version = QDataStream::Qt_1_0; version <= thisVersion; ++version) {
- const QDataStream::Version dataStreamVersion = static_cast<QDataStream::Version>(version);
- const QByteArray vN = QByteArray::number(dataStreamVersion);
- const QByteArray pY = positiveYear.toString().toLatin1();
- QTest::newRow(('v' + vN + " WA => HAWAII " + pY).constData())
- << positiveYear << westernAustralia << hawaii << dataStreamVersion;
- QTest::newRow(('v' + vN + " WA => WA " + pY).constData())
- << positiveYear << westernAustralia << westernAustralia << dataStreamVersion;
- QTest::newRow(('v' + vN + " HAWAII => WA " + negativeYear.toString().toLatin1()).constData())
- << negativeYear << hawaii << westernAustralia << dataStreamVersion;
- QTest::newRow(('v' + vN + " HAWAII => HAWAII " + pY).constData())
- << positiveYear << hawaii << hawaii << dataStreamVersion;
- }
-}
-
-void tst_QDateTime::operator_insert_extract()
-{
- QFETCH(QDateTime, dateTime);
- QFETCH(QString, serialiseAs);
- QFETCH(QString, deserialiseAs);
- QFETCH(QDataStream::Version, dataStreamVersion);
-
- // Start off in a certain timezone.
- TimeZoneRollback useZone(serialiseAs.toLocal8Bit());
- QDateTime dateTimeAsUTC(dateTime.toUTC());
-
- QByteArray byteArray;
- {
- QDataStream dataStream(&byteArray, QIODevice::WriteOnly);
- dataStream.setVersion(dataStreamVersion);
- if (dataStreamVersion == QDataStream::Qt_5_0) {
- // Qt 5 serialises as UTC and converts back to the stored timeSpec when
- // deserialising; we don't need to do it ourselves...
- dataStream << dateTime << dateTime;
- } else {
- // ... but other versions don't, so we have to here.
- dataStream << dateTimeAsUTC << dateTimeAsUTC;
- // We'll also make sure that a deserialised local datetime is the same
- // time of day (potentially different UTC time), regardless of which
- // timezone it was serialised in. E.g.: Tue Aug 14 08:00:00 2012
- // serialised in WST should be deserialised as Tue Aug 14 08:00:00 2012
- // HST.
- dataStream << dateTime;
- }
- }
-
- // Ensure that a change in timezone between serialisation and deserialisation
- // still results in identical UTC-converted datetimes.
- useZone.reset(deserialiseAs.toLocal8Bit());
- QDateTime expectedLocalTime(dateTimeAsUTC.toLocalTime());
- {
- // Deserialise whole QDateTime at once.
- QDataStream dataStream(&byteArray, QIODevice::ReadOnly);
- dataStream.setVersion(dataStreamVersion);
- QDateTime deserialised;
- dataStream >> deserialised;
-
- if (dataStreamVersion == QDataStream::Qt_5_0) {
- // Ensure local time is still correct. Again, Qt 5 handles the timeSpec
- // conversion (in this case, UTC => LocalTime) for us when deserialising.
- QCOMPARE(deserialised, expectedLocalTime);
- } else {
- if (dataStreamVersion < QDataStream::Qt_4_0) {
- // Versions lower than Qt 4 don't serialise the timeSpec, instead
- // assuming that everything is LocalTime.
- deserialised.setTimeSpec(Qt::UTC);
- }
- // Qt 4.* versions do serialise the timeSpec, so we only need to convert from UTC here.
- deserialised = deserialised.toLocalTime();
-
- QCOMPARE(deserialised, expectedLocalTime);
- }
- // Sanity check UTC times (operator== already converts its operands to UTC before comparing).
- QCOMPARE(deserialised.toUTC(), expectedLocalTime.toUTC());
-
- // Deserialise each component individually.
- QDate deserialisedDate;
- dataStream >> deserialisedDate;
- QTime deserialisedTime;
- dataStream >> deserialisedTime;
- qint8 deserialisedSpec;
- if (dataStreamVersion >= QDataStream::Qt_4_0)
- dataStream >> deserialisedSpec;
- deserialised = QDateTime(deserialisedDate, deserialisedTime, Qt::UTC);
- if (dataStreamVersion >= QDataStream::Qt_4_0)
- deserialised = deserialised.toTimeSpec(static_cast<Qt::TimeSpec>(deserialisedSpec));
- // Ensure local time is still correct.
- QCOMPARE(deserialised, expectedLocalTime);
- // Sanity check UTC times.
- QCOMPARE(deserialised.toUTC(), expectedLocalTime.toUTC());
-
- if (dataStreamVersion != QDataStream::Qt_5_0) {
- // Deserialised local datetime should be the same time of day,
- // regardless of which timezone it was serialised in.
- QDateTime localDeserialized;
- dataStream >> localDeserialized;
- QCOMPARE(localDeserialized, dateTime);
- }
- }
-}
-
-void tst_QDateTime::toString_strformat()
-{
- // Most tests are in QLocale, just test that the api works.
- QDate testDate(2013, 1, 1);
- QTime testTime(1, 2, 3);
- QDateTime testDateTime(testDate, testTime, Qt::UTC);
- QCOMPARE(testDate.toString("yyyy-MM-dd"), QString("2013-01-01"));
- QCOMPARE(testTime.toString("hh:mm:ss"), QString("01:02:03"));
- QCOMPARE(testDateTime.toString("yyyy-MM-dd hh:mm:ss t"), QString("2013-01-01 01:02:03 UTC"));
-}
-
-void tst_QDateTime::fromStringDateFormat_data()
-{
- QTest::addColumn<QString>("dateTimeStr");
- QTest::addColumn<Qt::DateFormat>("dateFormat");
- QTest::addColumn<QDateTime>("expected");
-
- // Test Qt::TextDate format.
- QTest::newRow("text date") << QString::fromLatin1("Tue Jun 17 08:00:10 2003")
- << Qt::TextDate << QDateTime(QDate(2003, 6, 17), QTime(8, 0, 10, 0), Qt::LocalTime);
- QTest::newRow("text date Year 0999") << QString::fromLatin1("Tue Jun 17 08:00:10 0999")
- << Qt::TextDate << QDateTime(QDate(999, 6, 17), QTime(8, 0, 10, 0), Qt::LocalTime);
- QTest::newRow("text date Year 999") << QString::fromLatin1("Tue Jun 17 08:00:10 999")
- << Qt::TextDate << QDateTime(QDate(999, 6, 17), QTime(8, 0, 10, 0), Qt::LocalTime);
- QTest::newRow("text date Year 12345") << QString::fromLatin1("Tue Jun 17 08:00:10 12345")
- << Qt::TextDate << QDateTime(QDate(12345, 6, 17), QTime(8, 0, 10, 0), Qt::LocalTime);
- QTest::newRow("text date Year -4712") << QString::fromLatin1("Tue Jan 1 00:01:02 -4712")
- << Qt::TextDate << QDateTime(QDate(-4712, 1, 1), QTime(0, 1, 2, 0), Qt::LocalTime);
- QTest::newRow("text data0") << QString::fromLatin1("Thu Jan 1 00:00:00 1970")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
- QTest::newRow("text data1") << QString::fromLatin1("Thu Jan 2 12:34 1970")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 2), QTime(12, 34, 0), Qt::LocalTime);
- QTest::newRow("text data2") << QString::fromLatin1("Thu Jan 1 00 1970")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text data3") << QString::fromLatin1("Thu Jan 1 00:00:00:00 1970")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text data4") << QString::fromLatin1("Thu 1. Jan 00:00:00 1970")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(0, 0), Qt::LocalTime);
- QTest::newRow("text data5") << QString::fromLatin1(" Thu Jan 1 00:00:00 1970 ")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
- QTest::newRow("text data6") << QString::fromLatin1("Thu Jan 1 00:00:00")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text data7") << QString::fromLatin1("Thu Jan 1 1970 00:00:00")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
- QTest::newRow("text data8") << QString::fromLatin1("Thu Jan 1 00:12:34 1970 GMT+foo")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text data9") << QString::fromLatin1("Thu Jan 1 00:12:34 1970 GMT")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("text data10") << QString::fromLatin1("Thu Jan 1 00:12:34 1970 GMT-0300")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(3, 12, 34), Qt::UTC);
- QTest::newRow("text data11") << QString::fromLatin1("Thu Jan 1 00:12:34 1970 GMT+0300")
- << Qt::TextDate << QDateTime(QDate(1969, 12, 31), QTime(21, 12, 34), Qt::UTC);
- QTest::newRow("text data12") << QString::fromLatin1("Thu Jan 1 00:12:34 1970 gmt")
- << Qt::TextDate << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("text data13") << QString::fromLatin1("Thu Jan 1 1970 00:12:34 GMT+0100")
- << Qt::TextDate << QDateTime(QDate(1969, 12, 31), QTime(23, 12, 34), Qt::UTC);
- QTest::newRow("text empty") << QString::fromLatin1("")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text too many parts") << QString::fromLatin1("Thu Jan 1 00:12:34 1970 gmt +0100")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid month name") << QString::fromLatin1("Thu Jaz 1 1970 00:12:34")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid date") << QString::fromLatin1("Thu Jan 32 1970 00:12:34")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid day #1") << QString::fromLatin1("Thu Jan XX 1970 00:12:34")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid day #2") << QString::fromLatin1("Thu X. Jan 00:00:00 1970")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid day #3") << QString::fromLatin1("Thu 1 Jan 00:00:00 1970")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid year #1") << QString::fromLatin1("Thu 1. Jan 00:00:00 19X0")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid year #2") << QString::fromLatin1("Thu 1. Jan 19X0 00:00:00")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid hour") << QString::fromLatin1("Thu 1. Jan 1970 0X:00:00")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid minute") << QString::fromLatin1("Thu 1. Jan 1970 00:0X:00")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid second") << QString::fromLatin1("Thu 1. Jan 1970 00:00:0X")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid gmt specifier #1") << QString::fromLatin1("Thu 1. Jan 1970 00:00:00 DMT")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid gmt specifier #2") << QString::fromLatin1("Thu 1. Jan 1970 00:00:00 GMTx0200")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid gmt hour") << QString::fromLatin1("Thu 1. Jan 1970 00:00:00 GMT+0X00")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text invalid gmt minute") << QString::fromLatin1("Thu 1. Jan 1970 00:00:00 GMT+000X")
- << Qt::TextDate << invalidDateTime();
- QTest::newRow("text second fraction") << QString::fromLatin1("Mon 6. May 2013 01:02:03.456")
- << Qt::TextDate << QDateTime(QDate(2013, 5, 6), QTime(1, 2, 3, 456));
-
- // Test Qt::ISODate format.
- QTest::newRow("ISO +01:00") << QString::fromLatin1("1987-02-13T13:24:51+01:00")
- << Qt::ISODate << QDateTime(QDate(1987, 2, 13), QTime(12, 24, 51), Qt::UTC);
- QTest::newRow("ISO +00:01") << QString::fromLatin1("1987-02-13T13:24:51+00:01")
- << Qt::ISODate << QDateTime(QDate(1987, 2, 13), QTime(13, 23, 51), Qt::UTC);
- QTest::newRow("ISO -01:00") << QString::fromLatin1("1987-02-13T13:24:51-01:00")
- << Qt::ISODate << QDateTime(QDate(1987, 2, 13), QTime(14, 24, 51), Qt::UTC);
- QTest::newRow("ISO -00:01") << QString::fromLatin1("1987-02-13T13:24:51-00:01")
- << Qt::ISODate << QDateTime(QDate(1987, 2, 13), QTime(13, 25, 51), Qt::UTC);
- QTest::newRow("ISO +0000") << QString::fromLatin1("1970-01-01T00:12:34+0000")
- << Qt::ISODate << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("ISO +00:00") << QString::fromLatin1("1970-01-01T00:12:34+00:00")
- << Qt::ISODate << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("ISO -03") << QString::fromLatin1("2014-12-15T12:37:09-03")
- << Qt::ISODate << QDateTime(QDate(2014, 12, 15), QTime(15, 37, 9), Qt::UTC);
- QTest::newRow("ISO zzz-03") << QString::fromLatin1("2014-12-15T12:37:09.745-03")
- << Qt::ISODate << QDateTime(QDate(2014, 12, 15), QTime(15, 37, 9, 745), Qt::UTC);
- QTest::newRow("ISO -3") << QString::fromLatin1("2014-12-15T12:37:09-3")
- << Qt::ISODate << QDateTime(QDate(2014, 12, 15), QTime(15, 37, 9), Qt::UTC);
- QTest::newRow("ISO zzz-3") << QString::fromLatin1("2014-12-15T12:37:09.745-3")
- << Qt::ISODate << QDateTime(QDate(2014, 12, 15), QTime(15, 37, 9, 745), Qt::UTC);
- // No time specified - defaults to Qt::LocalTime.
- QTest::newRow("ISO data3") << QString::fromLatin1("2002-10-01")
- << Qt::ISODate << QDateTime(QDate(2002, 10, 1), QTime(0, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO") << QString::fromLatin1("2005-06-28T07:57:30.0010000000Z")
- << Qt::ISODate << QDateTime(QDate(2005, 6, 28), QTime(7, 57, 30, 1), Qt::UTC);
- QTest::newRow("ISO with comma 1") << QString::fromLatin1("2005-06-28T07:57:30,0040000000Z")
- << Qt::ISODate << QDateTime(QDate(2005, 6, 28), QTime(7, 57, 30, 4), Qt::UTC);
- QTest::newRow("ISO with comma 2") << QString::fromLatin1("2005-06-28T07:57:30,0015Z")
- << Qt::ISODate << QDateTime(QDate(2005, 6, 28), QTime(7, 57, 30, 2), Qt::UTC);
- QTest::newRow("ISO with comma 3") << QString::fromLatin1("2005-06-28T07:57:30,0014Z")
- << Qt::ISODate << QDateTime(QDate(2005, 6, 28), QTime(7, 57, 30, 1), Qt::UTC);
- QTest::newRow("ISO with comma 4") << QString::fromLatin1("2005-06-28T07:57:30,1Z")
- << Qt::ISODate << QDateTime(QDate(2005, 6, 28), QTime(7, 57, 30, 100), Qt::UTC);
- QTest::newRow("ISO with comma 5") << QString::fromLatin1("2005-06-28T07:57:30,11")
- << Qt::ISODate << QDateTime(QDate(2005, 6, 28), QTime(7, 57, 30, 110), Qt::LocalTime);
- // 24:00:00 Should be next day according to ISO 8601 section 4.2.3.
- QTest::newRow("ISO 24:00") << QString::fromLatin1("2012-06-04T24:00:00")
- << Qt::ISODate << QDateTime(QDate(2012, 6, 5), QTime(0, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO 24:00 end of month") << QString::fromLatin1("2012-06-30T24:00:00")
- << Qt::ISODate << QDateTime(QDate(2012, 7, 1), QTime(0, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO 24:00 end of year") << QString::fromLatin1("2012-12-31T24:00:00")
- << Qt::ISODate << QDateTime(QDate(2013, 1, 1), QTime(0, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO 24:00, fract ms") << QString::fromLatin1("2012-01-01T24:00:00.000")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 2), QTime(0, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO 24:00 end of year, fract ms") << QString::fromLatin1("2012-12-31T24:00:00.000")
- << Qt::ISODate << QDateTime(QDate(2013, 1, 1), QTime(0, 0, 0, 0), Qt::LocalTime);
- // Test fractional seconds.
- QTest::newRow("ISO .0 of a second (period)") << QString::fromLatin1("2012-01-01T08:00:00.0")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO .00 of a second (period)") << QString::fromLatin1("2012-01-01T08:00:00.00")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO .000 of a second (period)") << QString::fromLatin1("2012-01-01T08:00:00.000")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO .1 of a second (comma)") << QString::fromLatin1("2012-01-01T08:00:00,1")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 100), Qt::LocalTime);
- QTest::newRow("ISO .99 of a second (comma)") << QString::fromLatin1("2012-01-01T08:00:00,99")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 990), Qt::LocalTime);
- QTest::newRow("ISO .998 of a second (comma)") << QString::fromLatin1("2012-01-01T08:00:00,998")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 998), Qt::LocalTime);
- QTest::newRow("ISO .999 of a second (comma)") << QString::fromLatin1("2012-01-01T08:00:00,999")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 999), Qt::LocalTime);
- QTest::newRow("ISO .3335 of a second (comma)") << QString::fromLatin1("2012-01-01T08:00:00,3335")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 334), Qt::LocalTime);
- QTest::newRow("ISO .333333 of a second (comma)") << QString::fromLatin1("2012-01-01T08:00:00,333333")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 333), Qt::LocalTime);
- QTest::newRow("ISO .00009 of a second (period)") << QString::fromLatin1("2012-01-01T08:00:00.00009")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO no fract specified") << QString::fromLatin1("2012-01-01T08:00:00.")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("ISO invalid character at end") << QString::fromLatin1("2012-01-01T08:00:00!")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO invalid character at front") << QString::fromLatin1("!2012-01-01T08:00:00")
- << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO invalid character both ends") << QString::fromLatin1("!2012-01-01T08:00:00!")
- << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO invalid character at front, 2 at back") << QString::fromLatin1("!2012-01-01T08:00:00..")
- << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO invalid character 2 at front") << QString::fromLatin1("!!2012-01-01T08:00:00")
- << Qt::ISODate << invalidDateTime();
- // Test fractional minutes.
- QTest::newRow("ISO .0 of a minute (period)") << QString::fromLatin1("2012-01-01T08:00.0")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO .8 of a minute (period)") << QString::fromLatin1("2012-01-01T08:00.8")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 48, 0), Qt::LocalTime);
- QTest::newRow("ISO .99999 of a minute (period)") << QString::fromLatin1("2012-01-01T08:00.99999")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 59, 999), Qt::LocalTime);
- QTest::newRow("ISO .0 of a minute (comma)") << QString::fromLatin1("2012-01-01T08:00,0")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 0, 0), Qt::LocalTime);
- QTest::newRow("ISO .8 of a minute (comma)") << QString::fromLatin1("2012-01-01T08:00,8")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 48, 0), Qt::LocalTime);
- QTest::newRow("ISO .99999 of a minute (comma)") << QString::fromLatin1("2012-01-01T08:00,99999")
- << Qt::ISODate << QDateTime(QDate(2012, 1, 1), QTime(8, 0, 59, 999), Qt::LocalTime);
- QTest::newRow("ISO empty") << QString::fromLatin1("") << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO short") << QString::fromLatin1("2017-07-01T") << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO zoned date") << QString::fromLatin1("2017-07-01Z") << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO zoned empty time") << QString::fromLatin1("2017-07-01TZ") << Qt::ISODate << invalidDateTime();
- QTest::newRow("ISO mis-punctuated") << QString::fromLatin1("2018/01/30 ") << Qt::ISODate << invalidDateTime();
-
- // Test Qt::RFC2822Date format (RFC 2822).
- QTest::newRow("RFC 2822 +0100") << QString::fromLatin1("13 Feb 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QDateTime(QDate(1987, 2, 13), QTime(12, 24, 51), Qt::UTC);
- QTest::newRow("RFC 2822 with day +0100") << QString::fromLatin1("Fri, 13 Feb 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QDateTime(QDate(1987, 2, 13), QTime(12, 24, 51), Qt::UTC);
- QTest::newRow("RFC 2822 -0100") << QString::fromLatin1("13 Feb 1987 13:24:51 -0100")
- << Qt::RFC2822Date << QDateTime(QDate(1987, 2, 13), QTime(14, 24, 51), Qt::UTC);
- QTest::newRow("RFC 2822 with day -0100") << QString::fromLatin1("Fri, 13 Feb 1987 13:24:51 -0100")
- << Qt::RFC2822Date << QDateTime(QDate(1987, 2, 13), QTime(14, 24, 51), Qt::UTC);
- QTest::newRow("RFC 2822 +0000") << QString::fromLatin1("01 Jan 1970 00:12:34 +0000")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("RFC 2822 with day +0000") << QString::fromLatin1("Thu, 01 Jan 1970 00:12:34 +0000")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("RFC 2822 +0000") << QString::fromLatin1("01 Jan 1970 00:12:34 +0000")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("RFC 2822 with day +0000") << QString::fromLatin1("Thu, 01 Jan 1970 00:12:34 +0000")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- // No timezone assume UTC
- QTest::newRow("RFC 2822 no timezone") << QString::fromLatin1("01 Jan 1970 00:12:34")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- // No time specified
- QTest::newRow("RFC 2822 date only") << QString::fromLatin1("01 Nov 2002")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 2822 with day date only") << QString::fromLatin1("Fri, 01 Nov 2002")
- << Qt::RFC2822Date << invalidDateTime();
- // Test invalid month, day, year
- QTest::newRow("RFC 2822 invalid month name") << QString::fromLatin1("13 Fev 1987 13:24:51 +0100")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 2822 invalid day") << QString::fromLatin1("36 Fev 1987 13:24:51 +0100")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 2822 invalid year") << QString::fromLatin1("13 Fev 0000 13:24:51 +0100")
- << Qt::RFC2822Date << invalidDateTime();
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("RFC 2822 invalid character at end") << QString::fromLatin1("01 Jan 2012 08:00:00 +0100!")
- << Qt::RFC2822Date << QDateTime(QDate(2012, 1, 1), QTime(7, 0, 0, 0), Qt::UTC);
- QTest::newRow("RFC 2822 invalid character at front") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 2822 invalid character both ends") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000!")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 2822 invalid character at front, 2 at back") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000..")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 2822 invalid character 2 at front") << QString::fromLatin1("!!01 Jan 2012 08:00:00 +0000")
- << Qt::RFC2822Date << invalidDateTime();
-
- // Test Qt::RFC2822Date format (RFC 850 and 1036).
- QTest::newRow("RFC 850 and 1036 +0100") << QString::fromLatin1("Fri Feb 13 13:24:51 1987 +0100")
- << Qt::RFC2822Date << QDateTime(QDate(1987, 2, 13), QTime(12, 24, 51), Qt::UTC);
- QTest::newRow("RFC 850 and 1036 -0100") << QString::fromLatin1("Fri Feb 13 13:24:51 1987 -0100")
- << Qt::RFC2822Date << QDateTime(QDate(1987, 2, 13), QTime(14, 24, 51), Qt::UTC);
- QTest::newRow("RFC 850 and 1036 +0000") << QString::fromLatin1("Thu Jan 01 00:12:34 1970 +0000")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- QTest::newRow("RFC 850 and 1036 +0000") << QString::fromLatin1("Thu Jan 01 00:12:34 1970 +0000")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- // No timezone assume UTC
- QTest::newRow("RFC 850 and 1036 no timezone") << QString::fromLatin1("Thu Jan 01 00:12:34 1970")
- << Qt::RFC2822Date << QDateTime(QDate(1970, 1, 1), QTime(0, 12, 34), Qt::UTC);
- // No time specified
- QTest::newRow("RFC 850 and 1036 date only") << QString::fromLatin1("Fri Nov 01 2002")
- << Qt::RFC2822Date << invalidDateTime();
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("RFC 850 and 1036 invalid character at end") << QString::fromLatin1("Sun Jan 01 08:00:00 2012 +0100!")
- << Qt::RFC2822Date << QDateTime(QDate(2012, 1, 1), QTime(7, 0, 0, 0), Qt::UTC);
- QTest::newRow("RFC 850 and 1036 invalid character at front") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 850 and 1036 invalid character both ends") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000!")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 850 and 1036 invalid character at front, 2 at back") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000..")
- << Qt::RFC2822Date << invalidDateTime();
- QTest::newRow("RFC 850 and 1036 invalid character 2 at front") << QString::fromLatin1("!!Sun Jan 01 08:00:00 2012 +0000")
- << Qt::RFC2822Date << invalidDateTime();
-
- QTest::newRow("RFC empty") << QString::fromLatin1("") << Qt::RFC2822Date << invalidDateTime();
-}
-
-void tst_QDateTime::fromStringDateFormat()
-{
- QFETCH(QString, dateTimeStr);
- QFETCH(Qt::DateFormat, dateFormat);
- QFETCH(QDateTime, expected);
-
- QDateTime dateTime = QDateTime::fromString(dateTimeStr, dateFormat);
- QCOMPARE(dateTime, expected);
-}
-
-void tst_QDateTime::fromStringStringFormat_data()
-{
- QTest::addColumn<QString>("string");
- QTest::addColumn<QString>("format");
- QTest::addColumn<QDateTime>("expected");
-
- QTest::newRow("data0") << QString("101010") << QString("dMyy") << QDateTime(QDate(1910, 10, 10), QTime());
- QTest::newRow("data1") << QString("1020") << QString("sss") << invalidDateTime();
- QTest::newRow("data2") << QString("1010") << QString("sss") << QDateTime(defDate(), QTime(0, 0, 10));
- QTest::newRow("data3") << QString("10hello20") << QString("ss'hello'ss") << invalidDateTime();
- QTest::newRow("data4") << QString("10") << QString("''") << invalidDateTime();
- QTest::newRow("data5") << QString("10") << QString("'") << invalidDateTime();
- QTest::newRow("data6") << QString("pm") << QString("ap") << QDateTime(defDate(), QTime(12, 0, 0));
- QTest::newRow("data7") << QString("foo") << QString("ap") << invalidDateTime();
- // Day non-conflict should not hide earlier year conflict (1963-03-01 was a
- // Friday; asking for Thursday moves this, without conflict, to the 7th):
- QTest::newRow("data8") << QString("77 03 1963 Thu") << QString("yy MM yyyy ddd") << invalidDateTime();
- QTest::newRow("data9") << QString("101010") << QString("dMyy") << QDateTime(QDate(1910, 10, 10), QTime());
- QTest::newRow("data10") << QString("101010") << QString("dMyy") << QDateTime(QDate(1910, 10, 10), QTime());
- QTest::newRow("data11") << QString("10 Oct 10") << QString("dd MMM yy") << QDateTime(QDate(1910, 10, 10), QTime());
- QTest::newRow("data12") << QString("Fri December 3 2004") << QString("ddd MMMM d yyyy") << QDateTime(QDate(2004, 12, 3), QTime());
- QTest::newRow("data13") << QString("30.02.2004") << QString("dd.MM.yyyy") << invalidDateTime();
- QTest::newRow("data14") << QString("32.01.2004") << QString("dd.MM.yyyy") << invalidDateTime();
- QTest::newRow("data15") << QString("Thu January 2004") << QString("ddd MMMM yyyy") << QDateTime(QDate(2004, 1, 1), QTime());
- QTest::newRow("data16") << QString("2005-06-28T07:57:30.001Z")
- << QString("yyyy-MM-ddThh:mm:ss.zt")
- << QDateTime(QDate(2005, 06, 28), QTime(07, 57, 30, 1), Qt::UTC);
-#if QT_CONFIG(timezone)
- QTimeZone southBrazil("America/Sao_Paulo");
- if (southBrazil.isValid()) {
- QTest::newRow("spring-forward-midnight")
- << QString("2008-10-19 23:45.678 America/Sao_Paulo") << QString("yyyy-MM-dd mm:ss.zzz t")
- << QDateTime(QDate(2008, 10, 19), QTime(1, 23, 45, 678), southBrazil);
- }
-#endif
- QTest::newRow("late") << QString("9999-12-31T23:59:59.999Z")
- << QString("yyyy-MM-ddThh:mm:ss.zZ")
- << QDateTime(QDate(9999, 12, 31), QTime(23, 59, 59, 999));
- // Separators match /([^aAdhHMmstyz]*)/
- QTest::newRow("oddly-separated") // To show broken-separator's format is valid.
- << QStringLiteral("2018 wilful long working block relief 12-19T21:09 cruel blurb encore flux")
- << QStringLiteral("yyyy wilful long working block relief MM-ddThh:mm cruel blurb encore flux")
- << QDateTime(QDate(2018, 12, 19), QTime(21, 9));
- QTest::newRow("broken-separator")
- << QStringLiteral("2018 wilful")
- << QStringLiteral("yyyy wilful long working block relief MM-ddThh:mm cruel blurb encore flux")
- << invalidDateTime();
- QTest::newRow("broken-terminator")
- << QStringLiteral("2018 wilful long working block relief 12-19T21:09 cruel")
- << QStringLiteral("yyyy wilful long working block relief MM-ddThh:mm cruel blurb encore flux")
- << invalidDateTime();
-}
-
-void tst_QDateTime::fromStringStringFormat()
-{
- QFETCH(QString, string);
- QFETCH(QString, format);
- QFETCH(QDateTime, expected);
-
- QDateTime dt = QDateTime::fromString(string, format);
-
- QCOMPARE(dt, expected);
-}
-
-void tst_QDateTime::fromStringStringFormatLocale_data()
-{
- QTest::addColumn<QString>("string");
- QTest::addColumn<QString>("format");
- QTest::addColumn<QLocale>("locale");
- QTest::addColumn<QDateTime>("expected");
-
- QLocale c = QLocale::c();
- QDateTime dt(QDate(2017, 02, 25), QTime(17, 21, 25));
-
- // The formats correspond to the locale formats, with the timezone removed.
- // We hardcode them in case an update to the locale DB changes them.
-
- QTest::newRow("C:long") << "Saturday, 25 February 2017 17:21:25" << "dddd, d MMMM yyyy HH:mm:ss" << c << dt;
- QTest::newRow("C:short") << "25 Feb 2017 17:21:25" << "d MMM yyyy HH:mm:ss" << c << dt;
- QTest::newRow("C:narrow") << "25 Feb 2017 17:21:25" << "d MMM yyyy HH:mm:ss" << c << dt;
-
- QLocale fr(QLocale::French);
- QTest::newRow("fr:long") << "Samedi 25 février 2017 17:21:25" << "dddd d MMMM yyyy HH:mm:ss" << fr << dt;
- QTest::newRow("fr:short") << "25/02/2017 17:21" << "dd/MM/yyyy HH:mm" << fr << dt.addSecs(-25);
-
- // In Turkish, the word for Friday ("Cuma") is a prefix for the word for
- // Saturday ("Cumartesi")
- QLocale tr(QLocale::Turkish);
- QTest::newRow("tr:long") << "25 Şubat 2017 Cumartesi 17:21:25" << "d MMMM yyyy dddd HH:mm:ss" << tr << dt;
- QTest::newRow("tr:long2") << "24 Şubat 2017 Cuma 17:21:25" << "d MMMM yyyy dddd HH:mm:ss" << tr << dt.addDays(-1);
- QTest::newRow("tr:mashed") << "25 Şubat2017 Cumartesi17:21:25" << "d MMMMyyyy ddddHH:mm:ss" << tr << dt;
- QTest::newRow("tr:mashed2") << "24 Şubat2017 Cuma17:21:25" << "d MMMMyyyy ddddHH:mm:ss" << tr << dt.addDays(-1);
- QTest::newRow("tr:short") << "25.02.2017 17:21" << "d.MM.yyyy HH:mm" << tr << dt.addSecs(-25);
-}
-
-void tst_QDateTime::fromStringStringFormatLocale()
-{
- QFETCH(QString, string);
- QFETCH(QString, format);
- QFETCH(QLocale, locale);
- QFETCH(QDateTime, expected);
-
- QDateTime parsed = locale.toDateTime(string, format);
- QCOMPARE(parsed, expected);
-
- parsed = locale.toDateTime(string.toLower(), format);
- QCOMPARE(parsed, expected);
-
- parsed = locale.toDateTime(string.toUpper(), format);
- QCOMPARE(parsed, expected);
-}
-
-#ifdef Q_OS_WIN
-// Windows only
-void tst_QDateTime::fromString_LOCALE_ILDATE()
-{
- QString date1 = QLatin1String("Sun 1. Dec 13:02:00 1974");
- QString date2 = QLatin1String("Sun Dec 1 13:02:00 1974");
-
- QDateTime ref(QDate(1974, 12, 1), QTime(13, 2));
- QCOMPARE(ref, QDateTime::fromString(date2, Qt::TextDate));
- QCOMPARE(ref, QDateTime::fromString(date1, Qt::TextDate));
-}
-#endif
-
-void tst_QDateTime::fromStringToStringLocale_data()
-{
- QTest::addColumn<QLocale>("locale");
- QTest::addColumn<QDateTime>("dateTime");
-
- QTest::newRow("frFR") << QLocale(QLocale::French, QLocale::France) << QDateTime(QDate(1999, 1, 18), QTime(11, 49, 00));
- QTest::newRow("spCO") << QLocale(QLocale::Spanish, QLocale::Colombia) << QDateTime(QDate(1999, 1, 18), QTime(11, 49, 00));
-}
-
-void tst_QDateTime::fromStringToStringLocale()
-{
- QFETCH(QLocale, locale);
- QFETCH(QDateTime, dateTime);
-
- QLocale def;
- QLocale::setDefault(locale);
-#define ROUNDTRIP(format) \
- QCOMPARE(QDateTime::fromString(dateTime.toString(format), format), dateTime)
-
- ROUNDTRIP(Qt::DefaultLocaleShortDate);
- ROUNDTRIP(Qt::SystemLocaleShortDate);
-
- // obsolete
- ROUNDTRIP(Qt::SystemLocaleDate);
- ROUNDTRIP(Qt::LocaleDate);
-
- ROUNDTRIP(Qt::DefaultLocaleLongDate);
- ROUNDTRIP(Qt::SystemLocaleLongDate);
-#undef ROUNDTRIP
- QLocale::setDefault(def);
-}
-
-void tst_QDateTime::offsetFromUtc()
-{
- /* Check default value. */
- QCOMPARE(QDateTime().offsetFromUtc(), 0);
-
- // Offset constructor
- QDateTime dt1(QDate(2013, 1, 1), QTime(1, 0, 0), Qt::OffsetFromUTC, 60 * 60);
- QCOMPARE(dt1.offsetFromUtc(), 60 * 60);
- QVERIFY(dt1.timeZone().isValid());
- dt1 = QDateTime(QDate(2013, 1, 1), QTime(1, 0, 0), Qt::OffsetFromUTC, -60 * 60);
- QCOMPARE(dt1.offsetFromUtc(), -60 * 60);
-
- // UTC should be 0 offset
- QDateTime dt2(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QCOMPARE(dt2.offsetFromUtc(), 0);
-
- // LocalTime should vary
- if (zoneIsCET) {
- // Time definitely in Standard Time so 1 hour ahead
- QDateTime dt3(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
- QCOMPARE(dt3.offsetFromUtc(), 1 * 60 * 60);
- // Time definitely in Daylight Time so 2 hours ahead
- QDateTime dt4(QDate(2013, 6, 1), QTime(0, 0, 0), Qt::LocalTime);
- QCOMPARE(dt4.offsetFromUtc(), 2 * 60 * 60);
- } else {
- QSKIP("You must test using Central European (CET/CEST) time zone, e.g. TZ=Europe/Oslo");
- }
-
- QDateTime dt5(QDate(2013, 1, 1), QTime(0, 0, 0), QTimeZone("Pacific/Auckland"));
- QCOMPARE(dt5.offsetFromUtc(), 46800);
-
- QDateTime dt6(QDate(2013, 6, 1), QTime(0, 0, 0), QTimeZone("Pacific/Auckland"));
- QCOMPARE(dt6.offsetFromUtc(), 43200);
-}
-
-void tst_QDateTime::setOffsetFromUtc()
-{
- /* Basic tests. */
- {
- QDateTime dt(QDateTime::currentDateTime());
- dt.setTimeSpec(Qt::LocalTime);
-
- dt.setOffsetFromUtc(0);
- QCOMPARE(dt.offsetFromUtc(), 0);
- QCOMPARE(dt.timeSpec(), Qt::UTC);
-
- dt.setOffsetFromUtc(-100);
- QCOMPARE(dt.offsetFromUtc(), -100);
- QCOMPARE(dt.timeSpec(), Qt::OffsetFromUTC);
- }
-
- /* Test detaching. */
- {
- QDateTime dt(QDateTime::currentDateTime());
- QDateTime dt2(dt);
- int offset2 = dt2.offsetFromUtc();
-
- dt.setOffsetFromUtc(501);
-
- QCOMPARE(dt.offsetFromUtc(), 501);
- QCOMPARE(dt2.offsetFromUtc(), offset2);
- }
-
- /* Check copying. */
- {
- QDateTime dt(QDateTime::currentDateTime());
- dt.setOffsetFromUtc(502);
- QCOMPARE(dt.offsetFromUtc(), 502);
-
- QDateTime dt2(dt);
- QCOMPARE(dt2.offsetFromUtc(), 502);
- }
-
- /* Check assignment. */
- {
- QDateTime dt(QDateTime::currentDateTime());
- dt.setOffsetFromUtc(502);
- QDateTime dt2;
- dt2 = dt;
-
- QCOMPARE(dt2.offsetFromUtc(), 502);
- }
-
- // Check spec persists
- QDateTime dt1(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::OffsetFromUTC, 60 * 60);
- dt1.setMSecsSinceEpoch(123456789);
- QCOMPARE(dt1.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(dt1.offsetFromUtc(), 60 * 60);
- dt1.setSecsSinceEpoch(123456789);
- QCOMPARE(dt1.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(dt1.offsetFromUtc(), 60 * 60);
-
- // Check datastream serialises the offset seconds
- QByteArray tmp;
- {
- QDataStream ds(&tmp, QIODevice::WriteOnly);
- ds << dt1;
- }
- QDateTime dt2;
- {
- QDataStream ds(&tmp, QIODevice::ReadOnly);
- ds >> dt2;
- }
- QCOMPARE(dt2, dt1);
- QCOMPARE(dt2.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(dt2.offsetFromUtc(), 60 * 60);
-}
-
-void tst_QDateTime::toOffsetFromUtc()
-{
- QDateTime dt1(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::UTC);
-
- QDateTime dt2 = dt1.toOffsetFromUtc(60 * 60);
- QCOMPARE(dt2, dt1);
- QCOMPARE(dt2.timeSpec(), Qt::OffsetFromUTC);
- QCOMPARE(dt2.date(), QDate(2013, 1, 1));
- QCOMPARE(dt2.time(), QTime(1, 0, 0));
-
- dt2 = dt1.toOffsetFromUtc(0);
- QCOMPARE(dt2, dt1);
- QCOMPARE(dt2.timeSpec(), Qt::UTC);
- QCOMPARE(dt2.date(), QDate(2013, 1, 1));
- QCOMPARE(dt2.time(), QTime(0, 0, 0));
-
- dt2 = dt1.toTimeSpec(Qt::OffsetFromUTC);
- QCOMPARE(dt2, dt1);
- QCOMPARE(dt2.timeSpec(), Qt::UTC);
- QCOMPARE(dt2.date(), QDate(2013, 1, 1));
- QCOMPARE(dt2.time(), QTime(0, 0, 0));
-}
-
-void tst_QDateTime::zoneAtTime_data()
-{
- QTest::addColumn<QByteArray>("ianaID");
- QTest::addColumn<QDate>("date");
- QTest::addColumn<int>("offset");
-#define ADDROW(name, zone, date, offset) \
- QTest::newRow(name) << QByteArray(zone) << (date) << (offset)
-
- // Check DST handling around epoch:
- {
- QDate epoch(1970, 1, 1);
- ADDROW("epoch:UTC", "UTC", epoch, 0);
- // Paris and Berlin skipped DST around 1970; but Rome used it.
- ADDROW("epoch:CET", "Europe/Rome", epoch, 3600);
- ADDROW("epoch:PST", "America/Vancouver", epoch, -8 * 3600);
- ADDROW("epoch:EST", "America/New_York", epoch, -5 * 3600);
- }
- {
- // QDateTime deliberately ignores DST before the epoch.
- QDate summer69(1969, 8, 15); // Woodstock started
- ADDROW("summer69:UTC", "UTC", summer69, 0);
- ADDROW("summer69:CET", "Europe/Rome", summer69, 3600);
- ADDROW("summer69:PST", "America/Vancouver", summer69, -8 * 3600);
- ADDROW("summer69:EST", "America/New_York", summer69, -5 * 3600);
- }
- {
- // ... but takes it into account after:
- QDate summer70(1970, 8, 26); // Isle of Wight festival
- ADDROW("summer70:UTC", "UTC", summer70, 0);
- ADDROW("summer70:CET", "Europe/Rome", summer70, 2 * 3600);
- ADDROW("summer70:PST", "America/Vancouver", summer70, -7 * 3600);
- ADDROW("summer70:EST", "America/New_York", summer70, -4 * 3600);
- }
-
-#ifdef Q_OS_ANDROID // QTBUG-68835; gets offset 0 for the affected tests.
-# define NONANDROIDROW(name, zone, date, offset)
-#else
-# define NONANDROIDROW(name, zone, date, offset) ADDROW(name, zone, date, offset)
-#endif
-
-#ifndef Q_OS_WIN
- // Bracket a few noteworthy transitions:
- ADDROW("before:ACWST", "Australia/Eucla", QDate(1974, 10, 26), 31500); // 8:45
- NONANDROIDROW("after:ACWST", "Australia/Eucla", QDate(1974, 10, 27), 35100); // 9:45
- NONANDROIDROW("before:NPT", "Asia/Kathmandu", QDate(1985, 12, 31), 19800); // 5:30
- ADDROW("after:NPT", "Asia/Kathmandu", QDate(1986, 1, 1), 20700); // 5:45
- // The two that have skipped a day (each):
- NONANDROIDROW("before:LINT", "Pacific/Kiritimati", QDate(1994, 12, 30), -36000);
- ADDROW("after:LINT", "Pacific/Kiritimati", QDate(1995, 1, 2), 14 * 3600);
- ADDROW("after:WST", "Pacific/Apia", QDate(2011, 12, 31), 14 * 3600);
-#endif // MS lacks ACWST, NPT; doesn't grok date-line crossings; and Windows 7 lacks LINT.
- ADDROW("before:WST", "Pacific/Apia", QDate(2011, 12, 29), -36000);
-#undef ADDROW
-}
-
-void tst_QDateTime::zoneAtTime()
-{
- QFETCH(QByteArray, ianaID);
- QFETCH(QDate, date);
- QFETCH(int, offset);
- const QTime noon(12, 0);
-
- QTimeZone zone(ianaID);
- QVERIFY(zone.isValid());
- QCOMPARE(QDateTime(date, noon, zone).offsetFromUtc(), offset);
- if (date.year() < 1970)
- QCOMPARE(zone.standardTimeOffset(QDateTime(date, noon, zone)), offset);
- else // zone.offsetFromUtc *does* include DST, even before epoch
- QCOMPARE(zone.offsetFromUtc(QDateTime(date, noon, zone)), offset);
-}
-
-void tst_QDateTime::timeZoneAbbreviation()
-{
- QDateTime dt1(QDate(2013, 1, 1), QTime(1, 0, 0), Qt::OffsetFromUTC, 60 * 60);
- QCOMPARE(dt1.timeZoneAbbreviation(), QString("UTC+01:00"));
- QDateTime dt2(QDate(2013, 1, 1), QTime(1, 0, 0), Qt::OffsetFromUTC, -60 * 60);
- QCOMPARE(dt2.timeZoneAbbreviation(), QString("UTC-01:00"));
-
- QDateTime dt3(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QCOMPARE(dt3.timeZoneAbbreviation(), QString("UTC"));
-
- // LocalTime should vary
- if (zoneIsCET) {
- // Time definitely in Standard Time
- QDateTime dt4(QDate(2013, 1, 1), QTime(0, 0, 0), Qt::LocalTime);
-#ifdef Q_OS_WIN
- QEXPECT_FAIL("", "Windows only reports long name (QTBUG-32759)", Continue);
-#endif
- QCOMPARE(dt4.timeZoneAbbreviation(), QStringLiteral("CET"));
- // Time definitely in Daylight Time
- QDateTime dt5(QDate(2013, 6, 1), QTime(0, 0, 0), Qt::LocalTime);
-#ifdef Q_OS_WIN
- QEXPECT_FAIL("", "Windows only reports long name (QTBUG-32759)", Continue);
-#endif
- QCOMPARE(dt5.timeZoneAbbreviation(), QStringLiteral("CEST"));
- } else {
- qDebug("(Skipped some CET-only tests)");
- }
-
-#ifdef Q_OS_ANDROID // Only reports (general) zones as offsets (QTBUG-68837)
- const QString cet(QStringLiteral("GMT+01:00"));
- const QString cest(QStringLiteral("GMT+02:00"));
-#elif defined Q_OS_DARWIN
- const QString cet(QStringLiteral("GMT+1"));
- const QString cest(QStringLiteral("GMT+2"));
-#else
- const QString cet(QStringLiteral("CET"));
- const QString cest(QStringLiteral("CEST"));
-#endif
-
- QDateTime dt5(QDate(2013, 1, 1), QTime(0, 0, 0), QTimeZone("Europe/Berlin"));
-#ifdef Q_OS_WIN
- QEXPECT_FAIL("", "Windows only reports long names (QTBUG-32759)", Continue);
-#endif
- QCOMPARE(dt5.timeZoneAbbreviation(), cet);
- QDateTime dt6(QDate(2013, 6, 1), QTime(0, 0, 0), QTimeZone("Europe/Berlin"));
-#ifdef Q_OS_WIN
- QEXPECT_FAIL("", "Windows only reports long names (QTBUG-32759)", Continue);
-#endif
- QCOMPARE(dt6.timeZoneAbbreviation(), cest);
-}
-
-void tst_QDateTime::getDate()
-{
- {
- int y = -33, m = -44, d = -55;
- QDate date;
- date.getDate(&y, &m, &d);
- QVERIFY(date.year() == y);
- QVERIFY(date.month() == m);
- QVERIFY(date.day() == d);
-
- date.getDate(0, 0, 0);
- }
-
- {
- int y = -33, m = -44, d = -55;
- QDate date(1998, 5, 24);
- date.getDate(0, &m, 0);
- date.getDate(&y, 0, 0);
- date.getDate(0, 0, &d);
-
- QVERIFY(date.year() == y);
- QVERIFY(date.month() == m);
- QVERIFY(date.day() == d);
- }
-}
-
-void tst_QDateTime::fewDigitsInYear() const
-{
- const QDateTime three(QDate(300, 10, 11), QTime());
- QCOMPARE(three.toString(QLatin1String("yyyy-MM-dd")), QString::fromLatin1("0300-10-11"));
-
- const QDateTime two(QDate(20, 10, 11), QTime());
- QCOMPARE(two.toString(QLatin1String("yyyy-MM-dd")), QString::fromLatin1("0020-10-11"));
-
- const QDateTime yyTwo(QDate(30, 10, 11), QTime());
- QCOMPARE(yyTwo.toString(QLatin1String("yy-MM-dd")), QString::fromLatin1("30-10-11"));
-
- const QDateTime yyOne(QDate(4, 10, 11), QTime());
- QCOMPARE(yyOne.toString(QLatin1String("yy-MM-dd")), QString::fromLatin1("04-10-11"));
-}
-
-void tst_QDateTime::printNegativeYear() const
-{
- {
- QDateTime date(QDate(-20, 10, 11));
- QVERIFY(date.isValid());
- QCOMPARE(date.toString(QLatin1String("yyyy")), QString::fromLatin1("-0020"));
- }
-
- {
- QDateTime date(QDate(-3, 10, 11));
- QVERIFY(date.isValid());
- QCOMPARE(date.toString(QLatin1String("yyyy")), QString::fromLatin1("-0003"));
- }
-
- {
- QDateTime date(QDate(-400, 10, 11));
- QVERIFY(date.isValid());
- QCOMPARE(date.toString(QLatin1String("yyyy")), QString::fromLatin1("-0400"));
- }
-}
-
-void tst_QDateTime::roundtripGermanLocale() const
-{
- /* This code path should not result in warnings. */
- const QDateTime theDateTime(QDateTime::currentDateTime());
- theDateTime.fromString(theDateTime.toString(Qt::TextDate), Qt::TextDate);
-}
-
-void tst_QDateTime::utcOffsetLessThan() const
-{
- QDateTime dt1(QDate(2002, 10, 10), QTime(0, 0, 0));
- QDateTime dt2(dt1);
-
- dt1.setOffsetFromUtc(-(2 * 60 * 60)); // Minus two hours.
- dt2.setOffsetFromUtc(-(3 * 60 * 60)); // Minus three hours.
-
- QVERIFY(dt1 != dt2);
- QVERIFY(!(dt1 == dt2));
- QVERIFY(dt1 < dt2);
- QVERIFY(!(dt2 < dt1));
-}
-
-void tst_QDateTime::isDaylightTime() const
-{
- QDateTime utc1(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QVERIFY(!utc1.isDaylightTime());
- QDateTime utc2(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC);
- QVERIFY(!utc2.isDaylightTime());
-
- QDateTime offset1(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::OffsetFromUTC, 1 * 60 * 60);
- QVERIFY(!offset1.isDaylightTime());
- QDateTime offset2(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::OffsetFromUTC, 1 * 60 * 60);
- QVERIFY(!offset2.isDaylightTime());
-
- if (zoneIsCET) {
- QDateTime cet1(QDate(2012, 1, 1), QTime(0, 0, 0));
- QVERIFY(!cet1.isDaylightTime());
- QDateTime cet2(QDate(2012, 6, 1), QTime(0, 0, 0));
- QVERIFY(cet2.isDaylightTime());
- } else {
- QSKIP("You must test using Central European (CET/CEST) time zone, e.g. TZ=Europe/Oslo");
- }
-}
-
-void tst_QDateTime::daylightTransitions() const
-{
- if (zoneIsCET) {
- // CET transitions occur at 01:00:00 UTC on last Sunday in March and October
- // 2011-03-27 02:00:00 CET became 03:00:00 CEST at msecs = 1301187600000
- // 2011-10-30 03:00:00 CEST became 02:00:00 CET at msecs = 1319936400000
- // 2012-03-25 02:00:00 CET became 03:00:00 CEST at msecs = 1332637200000
- // 2012-10-28 03:00:00 CEST became 02:00:00 CET at msecs = 1351386000000
- const qint64 daylight2012 = 1332637200000;
- const qint64 standard2012 = 1351386000000;
- const qint64 msecsOneHour = 3600000;
-
- // Test for correct behviour for StandardTime -> DaylightTime transition, i.e. missing hour
-
- // Test setting date, time in missing hour will be invalid
-
- QDateTime before(QDate(2012, 3, 25), QTime(1, 59, 59, 999));
- QVERIFY(before.isValid());
- QCOMPARE(before.date(), QDate(2012, 3, 25));
- QCOMPARE(before.time(), QTime(1, 59, 59, 999));
- QCOMPARE(before.toMSecsSinceEpoch(), daylight2012 - 1);
-
- QDateTime missing(QDate(2012, 3, 25), QTime(2, 0, 0));
- QVERIFY(!missing.isValid());
- QCOMPARE(missing.date(), QDate(2012, 3, 25));
- QCOMPARE(missing.time(), QTime(2, 0, 0));
-
- QDateTime after(QDate(2012, 3, 25), QTime(3, 0, 0));
- QVERIFY(after.isValid());
- QCOMPARE(after.date(), QDate(2012, 3, 25));
- QCOMPARE(after.time(), QTime(3, 0, 0));
- QCOMPARE(after.toMSecsSinceEpoch(), daylight2012);
-
- // Test round-tripping of msecs
-
- before.setMSecsSinceEpoch(daylight2012 - 1);
- QVERIFY(before.isValid());
- QCOMPARE(before.date(), QDate(2012, 3, 25));
- QCOMPARE(before.time(), QTime(1, 59, 59, 999));
- QCOMPARE(before.toMSecsSinceEpoch(), daylight2012 -1);
-
- after.setMSecsSinceEpoch(daylight2012);
- QVERIFY(after.isValid());
- QCOMPARE(after.date(), QDate(2012, 3, 25));
- QCOMPARE(after.time(), QTime(3, 0, 0));
- QCOMPARE(after.toMSecsSinceEpoch(), daylight2012);
-
- // Test changing time spec re-validates the date/time
-
- QDateTime utc(QDate(2012, 3, 25), QTime(2, 00, 0), Qt::UTC);
- QVERIFY(utc.isValid());
- QCOMPARE(utc.date(), QDate(2012, 3, 25));
- QCOMPARE(utc.time(), QTime(2, 0, 0));
- utc.setTimeSpec(Qt::LocalTime);
- QVERIFY(!utc.isValid());
- QCOMPARE(utc.date(), QDate(2012, 3, 25));
- QCOMPARE(utc.time(), QTime(2, 0, 0));
- utc.setTimeSpec(Qt::UTC);
- QVERIFY(utc.isValid());
- QCOMPARE(utc.date(), QDate(2012, 3, 25));
- QCOMPARE(utc.time(), QTime(2, 0, 0));
-
- // Test date maths, if result falls in missing hour then becomes next
- // hour (or is always invalid; mktime() may reject gap-times).
-
- QDateTime test(QDate(2011, 3, 25), QTime(2, 0, 0));
- QVERIFY(test.isValid());
- test = test.addYears(1);
- const bool handled = test.isValid();
-#define CHECK_SPRING_FORWARD(test) \
- if (test.isValid()) { \
- QCOMPARE(test.date(), QDate(2012, 3, 25)); \
- QCOMPARE(test.time(), QTime(3, 0, 0)); \
- } else { \
- QVERIFY(!handled); \
- }
- CHECK_SPRING_FORWARD(test);
-
- test = QDateTime(QDate(2012, 2, 25), QTime(2, 0, 0));
- QVERIFY(test.isValid());
- test = test.addMonths(1);
- CHECK_SPRING_FORWARD(test);
-
- test = QDateTime(QDate(2012, 3, 24), QTime(2, 0, 0));
- QVERIFY(test.isValid());
- test = test.addDays(1);
- CHECK_SPRING_FORWARD(test);
-
- test = QDateTime(QDate(2012, 3, 25), QTime(1, 0, 0));
- QVERIFY(test.isValid());
- QCOMPARE(test.toMSecsSinceEpoch(), daylight2012 - msecsOneHour);
- test = test.addMSecs(msecsOneHour);
- CHECK_SPRING_FORWARD(test);
- if (handled)
- QCOMPARE(test.toMSecsSinceEpoch(), daylight2012);
-#undef CHECK_SPRING_FORWARD
-
- // Test for correct behviour for DaylightTime -> StandardTime transition, i.e. second occurrence
-
- // Test setting date and time in first and second occurrence will be valid
-
- // 1 hour before transition is 2:00:00 FirstOccurrence
- QDateTime hourBefore(QDate(2012, 10, 28), QTime(2, 0, 0));
- QVERIFY(hourBefore.isValid());
- QCOMPARE(hourBefore.date(), QDate(2012, 10, 28));
- QCOMPARE(hourBefore.time(), QTime(2, 0, 0));
-#ifdef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(hourBefore.toMSecsSinceEpoch(), standard2012 - msecsOneHour);
-
- // 1 msec before transition is 2:59:59.999 FirstOccurrence
- QDateTime msecBefore(QDate(2012, 10, 28), QTime(2, 59, 59, 999));
- QVERIFY(msecBefore.isValid());
- QCOMPARE(msecBefore.date(), QDate(2012, 10, 28));
- QCOMPARE(msecBefore.time(), QTime(2, 59, 59, 999));
-#if defined(Q_OS_DARWIN) || defined(Q_OS_WIN) || defined(Q_OS_QNX) || defined(Q_OS_ANDROID)
- // Win and Mac uses SecondOccurrence here
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_MAC
- QCOMPARE(msecBefore.toMSecsSinceEpoch(), standard2012 - 1);
-
- // At transition is 2:00:00 SecondOccurrence
- QDateTime atTran(QDate(2012, 10, 28), QTime(2, 0, 0));
- QVERIFY(atTran.isValid());
- QCOMPARE(atTran.date(), QDate(2012, 10, 28));
- QCOMPARE(atTran.time(), QTime(2, 0, 0));
-#ifndef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(atTran.toMSecsSinceEpoch(), standard2012);
-
- // 59:59.999 after transition is 2:59:59.999 SecondOccurrence
- QDateTime afterTran(QDate(2012, 10, 28), QTime(2, 59, 59, 999));
- QVERIFY(afterTran.isValid());
- QCOMPARE(afterTran.date(), QDate(2012, 10, 28));
- QCOMPARE(afterTran.time(), QTime(2, 59, 59, 999));
-#ifdef __GLIBCXX__
- // Linux (i.e. glibc) mktime bug reuses last calculation
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_UNIX
- QCOMPARE(afterTran.toMSecsSinceEpoch(), standard2012 + msecsOneHour - 1);
-
- // 1 hour after transition is 3:00:00 FirstOccurrence
- QDateTime hourAfter(QDate(2012, 10, 28), QTime(3, 0, 0));
- QVERIFY(hourAfter.isValid());
- QCOMPARE(hourAfter.date(), QDate(2012, 10, 28));
- QCOMPARE(hourAfter.time(), QTime(3, 0, 0));
- QCOMPARE(hourAfter.toMSecsSinceEpoch(), standard2012 + msecsOneHour);
-
- // Test round-tripping of msecs
-
- // 1 hour before transition is 2:00:00 FirstOccurrence
- hourBefore.setMSecsSinceEpoch(standard2012 - msecsOneHour);
- QVERIFY(hourBefore.isValid());
- QCOMPARE(hourBefore.date(), QDate(2012, 10, 28));
- QCOMPARE(hourBefore.time(), QTime(2, 0, 0));
- QCOMPARE(hourBefore.toMSecsSinceEpoch(), standard2012 - msecsOneHour);
-
- // 1 msec before transition is 2:59:59.999 FirstOccurrence
- msecBefore.setMSecsSinceEpoch(standard2012 - 1);
- QVERIFY(msecBefore.isValid());
- QCOMPARE(msecBefore.date(), QDate(2012, 10, 28));
- QCOMPARE(msecBefore.time(), QTime(2, 59, 59, 999));
- QCOMPARE(msecBefore.toMSecsSinceEpoch(), standard2012 - 1);
-
- // At transition is 2:00:00 SecondOccurrence
- atTran.setMSecsSinceEpoch(standard2012);
- QVERIFY(atTran.isValid());
- QCOMPARE(atTran.date(), QDate(2012, 10, 28));
- QCOMPARE(atTran.time(), QTime(2, 0, 0));
- QCOMPARE(atTran.toMSecsSinceEpoch(), standard2012);
-
- // 59:59.999 after transition is 2:59:59.999 SecondOccurrence
- afterTran.setMSecsSinceEpoch(standard2012 + msecsOneHour - 1);
- QVERIFY(afterTran.isValid());
- QCOMPARE(afterTran.date(), QDate(2012, 10, 28));
- QCOMPARE(afterTran.time(), QTime(2, 59, 59, 999));
- QCOMPARE(afterTran.toMSecsSinceEpoch(), standard2012 + msecsOneHour - 1);
-
- // 1 hour after transition is 3:00:00 FirstOccurrence
- hourAfter.setMSecsSinceEpoch(standard2012 + msecsOneHour);
- QVERIFY(hourAfter.isValid());
- QCOMPARE(hourAfter.date(), QDate(2012, 10, 28));
- QCOMPARE(hourAfter.time(), QTime(3, 0, 0));
- QCOMPARE(hourAfter.toMSecsSinceEpoch(), standard2012 + msecsOneHour);
-
- // Test date maths, result is always FirstOccurrence
-
- // Add year to get to tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 28), QTime(2, 0, 0));
- test = test.addYears(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-#ifdef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 - msecsOneHour);
-
- // Add year to get to after tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 28), QTime(3, 0, 0));
- test = test.addYears(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(3, 0, 0));
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 + msecsOneHour);
-
- // Add year to tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(2, 0, 0));
- test = test.addYears(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 30));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-
- // Add year to tran SecondOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(2, 0, 0)); // TODO SecondOccurrence
- test = test.addYears(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 30));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-
- // Add year to after tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(3, 0, 0));
- test = test.addYears(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 30));
- QCOMPARE(test.time(), QTime(3, 0, 0));
-
-
- // Add month to get to tran FirstOccurrence
- test = QDateTime(QDate(2012, 9, 28), QTime(2, 0, 0));
- test = test.addMonths(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-#ifdef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 - msecsOneHour);
-
- // Add month to get to after tran FirstOccurrence
- test = QDateTime(QDate(2012, 9, 28), QTime(3, 0, 0));
- test = test.addMonths(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(3, 0, 0));
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 + msecsOneHour);
-
- // Add month to tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(2, 0, 0));
- test = test.addMonths(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2011, 11, 30));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-
- // Add month to tran SecondOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(2, 0, 0)); // TODO SecondOccurrence
- test = test.addMonths(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2011, 11, 30));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-
- // Add month to after tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(3, 0, 0));
- test = test.addMonths(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2011, 11, 30));
- QCOMPARE(test.time(), QTime(3, 0, 0));
-
-
- // Add day to get to tran FirstOccurrence
- test = QDateTime(QDate(2012, 10, 27), QTime(2, 0, 0));
- test = test.addDays(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-#ifdef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 - msecsOneHour);
-
- // Add day to get to after tran FirstOccurrence
- test = QDateTime(QDate(2012, 10, 27), QTime(3, 0, 0));
- test = test.addDays(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(3, 0, 0));
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 + msecsOneHour);
-
- // Add day to tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(2, 0, 0));
- test = test.addDays(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2011, 10, 31));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-
- // Add day to tran SecondOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(2, 0, 0)); // TODO SecondOccurrence
- test = test.addDays(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2011, 10, 31));
- QCOMPARE(test.time(), QTime(2, 0, 0));
-
- // Add day to after tran FirstOccurrence
- test = QDateTime(QDate(2011, 10, 30), QTime(3, 0, 0));
- test = test.addDays(1);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2011, 10, 31));
- QCOMPARE(test.time(), QTime(3, 0, 0));
-
-
- // Add hour to get to tran FirstOccurrence
- test = QDateTime(QDate(2012, 10, 28), QTime(1, 0, 0));
- test = test.addMSecs(msecsOneHour);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
- QCOMPARE(test.time(), QTime(2, 0, 0));
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 - msecsOneHour);
-
- // Add hour to tran FirstOccurrence to get to tran SecondOccurrence
- test = QDateTime(QDate(2012, 10, 28), QTime(2, 0, 0));
- test = test.addMSecs(msecsOneHour);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
-#ifdef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.time(), QTime(2, 0, 0));
-#ifdef Q_OS_WIN
- // Windows uses SecondOccurrence
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012);
-
- // Add hour to tran SecondOccurrence to get to after tran FirstOccurrence
- test = QDateTime(QDate(2012, 10, 28), QTime(2, 0, 0)); // TODO SecondOccurrence
- test = test.addMSecs(msecsOneHour);
- QVERIFY(test.isValid());
- QCOMPARE(test.date(), QDate(2012, 10, 28));
-#if defined(Q_OS_DARWIN) || defined(Q_OS_QNX) || defined(Q_OS_ANDROID)
- // Mac uses FirstOccurrence, Windows uses SecondOccurrence, Linux uses last calculation
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.time(), QTime(3, 0, 0));
-#if defined(Q_OS_DARWIN) || defined(Q_OS_QNX) || defined(Q_OS_ANDROID)
- // Mac uses FirstOccurrence, Windows uses SecondOccurrence, Linux uses last calculation
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
-#endif // Q_OS_WIN
- QCOMPARE(test.toMSecsSinceEpoch(), standard2012 + msecsOneHour);
-
- } else {
- QSKIP("You must test using Central European (CET/CEST) time zone, e.g. TZ=Europe/Oslo");
- }
-}
-
-void tst_QDateTime::timeZones() const
-{
- QTimeZone invalidTz = QTimeZone("Vulcan/ShiKahr");
- QCOMPARE(invalidTz.isValid(), false);
- QDateTime invalidDateTime = QDateTime(QDate(2000, 1, 1), QTime(0, 0, 0), invalidTz);
- QCOMPARE(invalidDateTime.isValid(), false);
- QCOMPARE(invalidDateTime.date(), QDate(2000, 1, 1));
- QCOMPARE(invalidDateTime.time(), QTime(0, 0, 0));
-
- QTimeZone nzTz = QTimeZone("Pacific/Auckland");
- QTimeZone nzTzOffset = QTimeZone(12 * 3600);
-
- // During Standard Time NZ is +12:00
- QDateTime utcStd(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime nzStd(QDate(2012, 6, 1), QTime(12, 0, 0), nzTz);
- QDateTime nzStdOffset(QDate(2012, 6, 1), QTime(12, 0, 0), nzTzOffset);
-
- QCOMPARE(nzStd.isValid(), true);
- QCOMPARE(nzStd.timeSpec(), Qt::TimeZone);
- QCOMPARE(nzStd.date(), QDate(2012, 6, 1));
- QCOMPARE(nzStd.time(), QTime(12, 0, 0));
- QVERIFY(nzStd.timeZone() == nzTz);
- QCOMPARE(nzStd.timeZone().id(), QByteArray("Pacific/Auckland"));
- QCOMPARE(nzStd.offsetFromUtc(), 43200);
- QCOMPARE(nzStd.isDaylightTime(), false);
- QCOMPARE(nzStd.toMSecsSinceEpoch(), utcStd.toMSecsSinceEpoch());
-
- QCOMPARE(nzStdOffset.isValid(), true);
- QCOMPARE(nzStdOffset.timeSpec(), Qt::TimeZone);
- QCOMPARE(nzStdOffset.date(), QDate(2012, 6, 1));
- QCOMPARE(nzStdOffset.time(), QTime(12, 0, 0));
- QVERIFY(nzStdOffset.timeZone() == nzTzOffset);
- QCOMPARE(nzStdOffset.timeZone().id(), QByteArray("UTC+12:00"));
- QCOMPARE(nzStdOffset.offsetFromUtc(), 43200);
- QCOMPARE(nzStdOffset.isDaylightTime(), false);
- QCOMPARE(nzStdOffset.toMSecsSinceEpoch(), utcStd.toMSecsSinceEpoch());
-
- // During Daylight Time NZ is +13:00
- QDateTime utcDst(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime nzDst(QDate(2012, 1, 1), QTime(13, 0, 0), nzTz);
-
- QCOMPARE(nzDst.isValid(), true);
- QCOMPARE(nzDst.date(), QDate(2012, 1, 1));
- QCOMPARE(nzDst.time(), QTime(13, 0, 0));
- QCOMPARE(nzDst.offsetFromUtc(), 46800);
- QCOMPARE(nzDst.isDaylightTime(), true);
- QCOMPARE(nzDst.toMSecsSinceEpoch(), utcDst.toMSecsSinceEpoch());
-
- QDateTime utc = nzStd.toUTC();
- QCOMPARE(utc.date(), utcStd.date());
- QCOMPARE(utc.time(), utcStd.time());
-
- utc = nzDst.toUTC();
- QCOMPARE(utc.date(), utcDst.date());
- QCOMPARE(utc.time(), utcDst.time());
-
- // Sydney is 2 hours behind New Zealand
- QTimeZone ausTz = QTimeZone("Australia/Sydney");
- QDateTime aus = nzStd.toTimeZone(ausTz);
- QCOMPARE(aus.date(), QDate(2012, 6, 1));
- QCOMPARE(aus.time(), QTime(10, 0, 0));
-
- QDateTime dt1(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC);
- QCOMPARE(dt1.timeSpec(), Qt::UTC);
- dt1.setTimeZone(nzTz);
- QCOMPARE(dt1.timeSpec(), Qt::TimeZone);
- QCOMPARE(dt1.date(), QDate(2012, 6, 1));
- QCOMPARE(dt1.time(), QTime(0, 0, 0));
- QCOMPARE(dt1.timeZone(), nzTz);
-
- QDateTime dt2 = QDateTime::fromSecsSinceEpoch(1338465600, nzTz);
- QCOMPARE(dt2.date(), dt1.date());
- QCOMPARE(dt2.time(), dt1.time());
- QCOMPARE(dt2.timeSpec(), dt1.timeSpec());
- QCOMPARE(dt2.timeZone(), dt1.timeZone());
-
- QDateTime dt3 = QDateTime::fromMSecsSinceEpoch(1338465600000, nzTz);
- QCOMPARE(dt3.date(), dt1.date());
- QCOMPARE(dt3.time(), dt1.time());
- QCOMPARE(dt3.timeSpec(), dt1.timeSpec());
- QCOMPARE(dt3.timeZone(), dt1.timeZone());
-
- // Check datastream serialises the time zone
- QByteArray tmp;
- {
- QDataStream ds(&tmp, QIODevice::WriteOnly);
- ds << dt1;
- }
- QDateTime dt4;
- {
- QDataStream ds(&tmp, QIODevice::ReadOnly);
- ds >> dt4;
- }
- QCOMPARE(dt4, dt1);
- QCOMPARE(dt4.timeSpec(), Qt::TimeZone);
- QCOMPARE(dt4.timeZone(), nzTz);
-
- // Check handling of transition times
- QTimeZone cet("Europe/Oslo");
-
- // Standard Time to Daylight Time 2013 on 2013-03-31 is 2:00 local time / 1:00 UTC
- qint64 stdToDstMSecs = 1364691600000;
-
- // Test MSecs to local
- // - Test 1 msec before tran = 01:59:59.999
- QDateTime beforeDst = QDateTime::fromMSecsSinceEpoch(stdToDstMSecs - 1, cet);
- QCOMPARE(beforeDst.date(), QDate(2013, 3, 31));
- QCOMPARE(beforeDst.time(), QTime(1, 59, 59, 999));
- // - Test at tran = 03:00:00
- QDateTime atDst = QDateTime::fromMSecsSinceEpoch(stdToDstMSecs, cet);
- QCOMPARE(atDst.date(), QDate(2013, 3, 31));
- QCOMPARE(atDst.time(), QTime(3, 0, 0));
-
- // Test local to MSecs
- // - Test 1 msec before tran = 01:59:59.999
- beforeDst = QDateTime(QDate(2013, 3, 31), QTime(1, 59, 59, 999), cet);
- QCOMPARE(beforeDst.toMSecsSinceEpoch(), stdToDstMSecs - 1);
- // - Test at tran = 03:00:00
- atDst = QDateTime(QDate(2013, 3, 31), QTime(3, 0, 0), cet);
- QCOMPARE(atDst.toMSecsSinceEpoch(), stdToDstMSecs);
- // - Test transition hole, setting 03:00:00 is valid
- atDst = QDateTime(QDate(2013, 3, 31), QTime(3, 0, 0), cet);
- QVERIFY(atDst.isValid());
- QCOMPARE(atDst.date(), QDate(2013, 3, 31));
- QCOMPARE(atDst.time(), QTime(3, 0, 0));
- QCOMPARE(atDst.toMSecsSinceEpoch(), stdToDstMSecs);
- // - Test transition hole, setting 02:00:00 is invalid
- atDst = QDateTime(QDate(2013, 3, 31), QTime(2, 0, 0), cet);
- QVERIFY(!atDst.isValid());
- QCOMPARE(atDst.date(), QDate(2013, 3, 31));
- QCOMPARE(atDst.time(), QTime(2, 0, 0));
- // - Test transition hole, setting 02:59:59.999 is invalid
- atDst = QDateTime(QDate(2013, 3, 31), QTime(2, 59, 59, 999), cet);
- QVERIFY(!atDst.isValid());
- QCOMPARE(atDst.date(), QDate(2013, 3, 31));
- QCOMPARE(atDst.time(), QTime(2, 59, 59, 999));
-
- // Standard Time to Daylight Time 2013 on 2013-10-27 is 3:00 local time / 1:00 UTC
- qint64 dstToStdMSecs = 1382835600000;
-
- // Test MSecs to local
- // - Test 1 hour before tran = 02:00:00 local first occurrence
- QDateTime hourBeforeStd = QDateTime::fromMSecsSinceEpoch(dstToStdMSecs - 3600000, cet);
- QCOMPARE(hourBeforeStd.date(), QDate(2013, 10, 27));
- QCOMPARE(hourBeforeStd.time(), QTime(2, 0, 0));
- // - Test 1 msec before tran = 02:59:59.999 local first occurrence
- QDateTime msecBeforeStd = QDateTime::fromMSecsSinceEpoch(dstToStdMSecs - 1, cet);
- QCOMPARE(msecBeforeStd.date(), QDate(2013, 10, 27));
- QCOMPARE(msecBeforeStd.time(), QTime(2, 59, 59, 999));
- // - Test at tran = 03:00:00 local becomes 02:00:00 local second occurrence
- QDateTime atStd = QDateTime::fromMSecsSinceEpoch(dstToStdMSecs, cet);
- QCOMPARE(atStd.date(), QDate(2013, 10, 27));
- QCOMPARE(atStd.time(), QTime(2, 0, 0));
- // - Test 59 mins after tran = 02:59:59.999 local second occurrence
- QDateTime afterStd = QDateTime::fromMSecsSinceEpoch(dstToStdMSecs + 3600000 -1, cet);
- QCOMPARE(afterStd.date(), QDate(2013, 10, 27));
- QCOMPARE(afterStd.time(), QTime(2, 59, 59, 999));
- // - Test 1 hour after tran = 03:00:00 local
- QDateTime hourAfterStd = QDateTime::fromMSecsSinceEpoch(dstToStdMSecs + 3600000, cet);
- QCOMPARE(hourAfterStd.date(), QDate(2013, 10, 27));
- QCOMPARE(hourAfterStd.time(), QTime(3, 00, 00));
-
- // Test local to MSecs
- // - Test first occurrence 02:00:00 = 1 hour before tran
- hourBeforeStd = QDateTime(QDate(2013, 10, 27), QTime(2, 0, 0), cet);
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
- QCOMPARE(hourBeforeStd.toMSecsSinceEpoch(), dstToStdMSecs - 3600000);
- // - Test first occurrence 02:59:59.999 = 1 msec before tran
- msecBeforeStd = QDateTime(QDate(2013, 10, 27), QTime(2, 59, 59, 999), cet);
- QEXPECT_FAIL("", "QDateTime doesn't properly support Daylight Transitions", Continue);
- QCOMPARE(msecBeforeStd.toMSecsSinceEpoch(), dstToStdMSecs - 1);
- // - Test second occurrence 02:00:00 = at tran
- atStd = QDateTime(QDate(2013, 10, 27), QTime(2, 0, 0), cet);
- QCOMPARE(atStd.toMSecsSinceEpoch(), dstToStdMSecs);
- // - Test second occurrence 03:00:00 = 59 mins after tran
- afterStd = QDateTime(QDate(2013, 10, 27), QTime(2, 59, 59, 999), cet);
- QCOMPARE(afterStd.toMSecsSinceEpoch(), dstToStdMSecs + 3600000 - 1);
- // - Test 03:00:00 = 1 hour after tran
- hourAfterStd = QDateTime(QDate(2013, 10, 27), QTime(3, 0, 0), cet);
- QCOMPARE(hourAfterStd.toMSecsSinceEpoch(), dstToStdMSecs + 3600000);
-
- // Test Time Zone that has transitions but no future transitions afer a given date
- QTimeZone sgt("Asia/Singapore");
- QDateTime future(QDate(2015, 1, 1), QTime(0, 0, 0), sgt);
- QVERIFY(future.isValid());
- QCOMPARE(future.offsetFromUtc(), 28800);
-}
-
-void tst_QDateTime::systemTimeZoneChange() const
-{
- // Set the timezone to Brisbane time
- TimeZoneRollback useZone(QByteArray("AEST-10:00"));
-
- QDateTime localDate = QDateTime(QDate(2012, 6, 1), QTime(2, 15, 30), Qt::LocalTime);
- QDateTime utcDate = QDateTime(QDate(2012, 6, 1), QTime(2, 15, 30), Qt::UTC);
- QDateTime tzDate = QDateTime(QDate(2012, 6, 1), QTime(2, 15, 30), QTimeZone("Australia/Brisbane"));
- qint64 localMsecs = localDate.toMSecsSinceEpoch();
- qint64 utcMsecs = utcDate.toMSecsSinceEpoch();
- qint64 tzMsecs = tzDate.toMSecsSinceEpoch();
-
- // check that Australia/Brisbane is known
- QVERIFY(tzDate.timeZone().isValid());
-
- // Change to Indian time
- useZone.reset(QByteArray("IST-05:30"));
-
- QCOMPARE(localDate, QDateTime(QDate(2012, 6, 1), QTime(2, 15, 30), Qt::LocalTime));
-#ifdef Q_OS_WINRT
- QEXPECT_FAIL("", "WinRT gets this wrong, QTBUG-71185", Continue);
-#endif
- QVERIFY(localMsecs != localDate.toMSecsSinceEpoch());
- QCOMPARE(utcDate, QDateTime(QDate(2012, 6, 1), QTime(2, 15, 30), Qt::UTC));
- QCOMPARE(utcDate.toMSecsSinceEpoch(), utcMsecs);
- QCOMPARE(tzDate, QDateTime(QDate(2012, 6, 1), QTime(2, 15, 30), QTimeZone("Australia/Brisbane")));
- QCOMPARE(tzDate.toMSecsSinceEpoch(), tzMsecs);
-}
-
-void tst_QDateTime::invalid() const
-{
- QDateTime invalidDate = QDateTime(QDate(0, 0, 0), QTime(-1, -1, -1));
- QCOMPARE(invalidDate.isValid(), false);
- QCOMPARE(invalidDate.timeSpec(), Qt::LocalTime);
-
- QDateTime utcDate = invalidDate.toUTC();
- QCOMPARE(utcDate.isValid(), false);
- QCOMPARE(utcDate.timeSpec(), Qt::UTC);
-
- QDateTime offsetDate = invalidDate.toOffsetFromUtc(3600);
- QCOMPARE(offsetDate.isValid(), false);
- QCOMPARE(offsetDate.timeSpec(), Qt::OffsetFromUTC);
-
- QDateTime tzDate = invalidDate.toTimeZone(QTimeZone("Europe/Oslo"));
- QCOMPARE(tzDate.isValid(), false);
- QCOMPARE(tzDate.timeSpec(), Qt::TimeZone);
-}
-
-void tst_QDateTime::macTypes()
-{
-#ifndef Q_OS_MAC
- QSKIP("This is a Apple-only test");
-#else
- extern void tst_QDateTime_macTypes(); // in qdatetime_mac.mm
- tst_QDateTime_macTypes();
-#endif
-}
-
-QTEST_APPLESS_MAIN(tst_QDateTime)
-#include "tst_qdatetime.moc"
diff --git a/tests/auto/corelib/tools/qdatetime/tst_qdatetime_mac.mm b/tests/auto/corelib/tools/qdatetime/tst_qdatetime_mac.mm
deleted file mode 100644
index f73c7b9d5d..0000000000
--- a/tests/auto/corelib/tools/qdatetime/tst_qdatetime_mac.mm
+++ /dev/null
@@ -1,70 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Copyright (C) 2014 Petroules Corporation.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtCore/QDateTime>
-#include <QtTest/QtTest>
-
-#include <CoreFoundation/CoreFoundation.h>
-#include <Foundation/Foundation.h>
-
-void tst_QDateTime_macTypes()
-{
- // QDateTime <-> CFDate
-
- static const int kMsPerSecond = 1000;
-
- for (int i = 0; i < kMsPerSecond; ++i) {
- QDateTime qtDateTime = QDateTime::fromMSecsSinceEpoch(i);
- const CFDateRef cfDate = qtDateTime.toCFDate();
- QCOMPARE(QDateTime::fromCFDate(cfDate), qtDateTime);
- CFRelease(cfDate);
- }
- {
- QDateTime qtDateTime = QDateTime::fromMSecsSinceEpoch(0);
- const CFDateRef cfDate = qtDateTime.toCFDate();
- QDateTime qtDateTimeCopy(qtDateTime);
- qtDateTime.setTime_t(10000); // modify
- QCOMPARE(QDateTime::fromCFDate(cfDate), qtDateTimeCopy);
- }
- // QDateTime <-> NSDate
- for (int i = 0; i < kMsPerSecond; ++i) {
- QMacAutoReleasePool pool;
- QDateTime qtDateTime = QDateTime::fromMSecsSinceEpoch(i);
- const NSDate *nsDate = qtDateTime.toNSDate();
- QCOMPARE(QDateTime::fromNSDate(nsDate), qtDateTime);
- }
- {
- QMacAutoReleasePool pool;
- QDateTime qtDateTime = QDateTime::fromMSecsSinceEpoch(0);
- const NSDate *nsDate = qtDateTime.toNSDate();
- QDateTime qtDateTimeCopy(qtDateTime);
- qtDateTime.setTime_t(10000); // modify
- QCOMPARE(QDateTime::fromNSDate(nsDate), qtDateTimeCopy);
- }
-}
diff --git a/tests/auto/corelib/tools/qeasingcurve/tst_qeasingcurve.cpp b/tests/auto/corelib/tools/qeasingcurve/tst_qeasingcurve.cpp
index 0196dd2d23..3af6132695 100644
--- a/tests/auto/corelib/tools/qeasingcurve/tst_qeasingcurve.cpp
+++ b/tests/auto/corelib/tools/qeasingcurve/tst_qeasingcurve.cpp
@@ -30,9 +30,7 @@
#include <qeasingcurve.h>
-#ifdef Q_COMPILER_RVALUE_REFS // cpp11() slot
-# include <utility> // for std::move()
-#endif
+#include <utility> // for std::move()
class tst_QEasingCurve : public QObject
{
@@ -55,6 +53,8 @@ private slots:
void testCbrtFloat();
void cpp11();
void quadraticEquation();
+ void streamInOut_data();
+ void streamInOut();
};
void tst_QEasingCurve::type()
@@ -792,7 +792,6 @@ void tst_QEasingCurve::testCbrtFloat()
void tst_QEasingCurve::cpp11()
{
-#ifdef Q_COMPILER_RVALUE_REFS
{
QEasingCurve ec( QEasingCurve::InOutBack );
QEasingCurve copy = std::move(ec); // move ctor
@@ -807,7 +806,6 @@ void tst_QEasingCurve::cpp11()
QCOMPARE( copy.type(), QEasingCurve::InOutBack );
QCOMPARE( ec.type(), type );
}
-#endif
}
void tst_QEasingCurve::quadraticEquation() {
@@ -879,5 +877,36 @@ void tst_QEasingCurve::quadraticEquation() {
}
}
+void tst_QEasingCurve::streamInOut_data()
+{
+ QTest::addColumn<int>("version");
+ QTest::addColumn<bool>("equality");
+
+ QTest::newRow("5.11") << int(QDataStream::Qt_5_11) << false;
+ QTest::newRow("5.13") << int(QDataStream::Qt_5_13) << true;
+}
+
+void tst_QEasingCurve::streamInOut()
+{
+ QFETCH(int, version);
+ QFETCH(bool, equality);
+
+ QEasingCurve orig;
+ orig.addCubicBezierSegment(QPointF(0.43, 0.0025), QPointF(0.38, 0.51), QPointF(0.57, 0.99));
+
+ QEasingCurve copy;
+
+ QByteArray data;
+ QDataStream dsw(&data,QIODevice::WriteOnly);
+ QDataStream dsr(&data,QIODevice::ReadOnly);
+
+ dsw.setVersion(version);
+ dsr.setVersion(version);
+ dsw << orig;
+ dsr >> copy;
+
+ QCOMPARE(copy == orig, equality);
+}
+
QTEST_MAIN(tst_QEasingCurve)
#include "tst_qeasingcurve.moc"
diff --git a/tests/auto/corelib/tools/qhash/tst_qhash.cpp b/tests/auto/corelib/tools/qhash/tst_qhash.cpp
index 0015efacfa..d70d488e96 100644
--- a/tests/auto/corelib/tools/qhash/tst_qhash.cpp
+++ b/tests/auto/corelib/tools/qhash/tst_qhash.cpp
@@ -1480,7 +1480,6 @@ void tst_QHash::twoArguments_qHash()
void tst_QHash::initializerList()
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QHash<int, QString> hash = {{1, "bar"}, {1, "hello"}, {2, "initializer_list"}};
QCOMPARE(hash.count(), 2);
QCOMPARE(hash[1], QString("hello"));
@@ -1507,9 +1506,6 @@ void tst_QHash::initializerList()
QMultiHash<int, float> emptyPairs2{{}, {}};
QVERIFY(!emptyPairs2.isEmpty());
-#else
- QSKIP("Compiler doesn't support initializer lists");
-#endif
}
void tst_QHash::eraseValidIteratorOnSharedHash()
diff --git a/tests/auto/corelib/tools/qhashfunctions/tst_qhashfunctions.cpp b/tests/auto/corelib/tools/qhashfunctions/tst_qhashfunctions.cpp
index 124e3cdf00..f76f3aa0c6 100644
--- a/tests/auto/corelib/tools/qhashfunctions/tst_qhashfunctions.cpp
+++ b/tests/auto/corelib/tools/qhashfunctions/tst_qhashfunctions.cpp
@@ -34,6 +34,8 @@
#include <sstream>
#include <algorithm>
+#include <unordered_set>
+
class tst_QHashFunctions : public QObject
{
Q_OBJECT
@@ -59,6 +61,8 @@ private Q_SLOTS:
void range();
void rangeCommutative();
+ void stdHash();
+
void setGlobalQHashSeed();
};
@@ -281,6 +285,38 @@ void tst_QHashFunctions::rangeCommutative()
(void)qHashRangeCommutative(hashables, hashables + numHashables, seed);
}
+void tst_QHashFunctions::stdHash()
+{
+ {
+ std::unordered_set<QString> s = {QStringLiteral("Hello"), QStringLiteral("World")};
+ QCOMPARE(s.size(), 2UL);
+ s.insert(QStringLiteral("Hello"));
+ QCOMPARE(s.size(), 2UL);
+ }
+
+ {
+ std::unordered_set<QStringView> s = {QStringLiteral("Hello"), QStringLiteral("World")};
+ QCOMPARE(s.size(), 2UL);
+ s.insert(QStringLiteral("Hello"));
+ QCOMPARE(s.size(), 2UL);
+ }
+
+ {
+ std::unordered_set<QLatin1String> s = {QLatin1String("Hello"), QLatin1String("World")};
+ QCOMPARE(s.size(), 2UL);
+ s.insert(QLatin1String("Hello"));
+ QCOMPARE(s.size(), 2UL);
+ }
+
+ {
+ std::unordered_set<QByteArray> s = {QByteArrayLiteral("Hello"), QByteArrayLiteral("World")};
+ QCOMPARE(s.size(), 2UL);
+ s.insert(QByteArray("Hello"));
+ QCOMPARE(s.size(), 2UL);
+ }
+
+}
+
void tst_QHashFunctions::setGlobalQHashSeed()
{
// Setter works as advertised
diff --git a/tests/auto/corelib/tools/qlatin1string/tst_qlatin1string.cpp b/tests/auto/corelib/tools/qlatin1string/tst_qlatin1string.cpp
index dcfb0aa042..cf46159251 100644
--- a/tests/auto/corelib/tools/qlatin1string/tst_qlatin1string.cpp
+++ b/tests/auto/corelib/tools/qlatin1string/tst_qlatin1string.cpp
@@ -45,6 +45,7 @@ class tst_QLatin1String : public QObject
private Q_SLOTS:
void at();
+ void arg() const;
void midLeftRight();
void nullString();
void emptyString();
@@ -63,6 +64,47 @@ void tst_QLatin1String::at()
QCOMPARE(l1[l1.size() - 1], QLatin1Char('d'));
}
+void tst_QLatin1String::arg() const
+{
+#define CHECK1(pattern, arg1, expected) \
+ do { \
+ auto p = QLatin1String(pattern); \
+ QCOMPARE(p.arg(QLatin1String(arg1)), expected); \
+ QCOMPARE(p.arg(QStringViewLiteral(arg1)), expected); \
+ QCOMPARE(p.arg(QStringLiteral(arg1)), expected); \
+ QCOMPARE(p.arg(QString(QLatin1String(arg1))), expected); \
+ } while (false) \
+ /*end*/
+#define CHECK2(pattern, arg1, arg2, expected) \
+ do { \
+ auto p = QLatin1String(pattern); \
+ QCOMPARE(p.arg(QLatin1String(arg1), QLatin1String(arg2)), expected); \
+ QCOMPARE(p.arg(QStringViewLiteral(arg1), QLatin1String(arg2)), expected); \
+ QCOMPARE(p.arg(QLatin1String(arg1), QStringViewLiteral(arg2)), expected); \
+ QCOMPARE(p.arg(QStringViewLiteral(arg1), QStringViewLiteral(arg2)), expected); \
+ } while (false) \
+ /*end*/
+
+ CHECK1("", "World", "");
+ CHECK1("%1", "World", "World");
+ CHECK1("!%1?", "World", "!World?");
+ CHECK1("%1%1", "World", "WorldWorld");
+ CHECK1("%1%2", "World", "World%2");
+ CHECK1("%2%1", "World", "%2World");
+
+ CHECK2("", "Hello", "World", "");
+ CHECK2("%1", "Hello", "World", "Hello");
+ CHECK2("!%1, %2?", "Hello", "World", "!Hello, World?");
+ CHECK2("%1%1", "Hello", "World", "HelloHello");
+ CHECK2("%1%2", "Hello", "World", "HelloWorld");
+ CHECK2("%2%1", "Hello", "World", "WorldHello");
+
+#undef CHECK2
+#undef CHECK1
+
+ QCOMPARE(QLatin1String(" %2 %2 %1 %3 ").arg(QLatin1Char('c'), QChar::CarriageReturn, u'C'), " \r \r c C ");
+}
+
void tst_QLatin1String::midLeftRight()
{
const QLatin1String l1("Hello World");
diff --git a/tests/auto/corelib/tools/qline/tst_qline.cpp b/tests/auto/corelib/tools/qline/tst_qline.cpp
index ae65d8f697..915a24a1f6 100644
--- a/tests/auto/corelib/tools/qline/tst_qline.cpp
+++ b/tests/auto/corelib/tools/qline/tst_qline.cpp
@@ -205,7 +205,7 @@ void tst_QLine::testIntersection()
QPointF ip;
- QLineF::IntersectType itype = a.intersect(b, &ip);
+ QLineF::IntersectionType itype = a.intersect(b, &ip);
QCOMPARE(int(itype), type);
if (type != QLineF::NoIntersection) {
diff --git a/tests/auto/corelib/tools/qlinkedlist/tst_qlinkedlist.cpp b/tests/auto/corelib/tools/qlinkedlist/tst_qlinkedlist.cpp
index f17d6695f0..deb3b68c5c 100644
--- a/tests/auto/corelib/tools/qlinkedlist/tst_qlinkedlist.cpp
+++ b/tests/auto/corelib/tools/qlinkedlist/tst_qlinkedlist.cpp
@@ -1005,7 +1005,6 @@ void tst_QLinkedList::testSTLIteratorsComplex() const
void tst_QLinkedList::initializeList() const
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QLinkedList<int> v1 { 2, 3, 4 };
QCOMPARE(v1, QLinkedList<int>() << 2 << 3 << 4);
QCOMPARE(v1, (QLinkedList<int> { 2, 3, 4}));
@@ -1014,7 +1013,6 @@ void tst_QLinkedList::initializeList() const
QLinkedList<QLinkedList<int>> v3;
v3 << v1 << (QLinkedList<int>() << 1) << QLinkedList<int>() << v1;
QCOMPARE(v3, v2);
-#endif
}
diff --git a/tests/auto/corelib/tools/qlist/tst_qlist.cpp b/tests/auto/corelib/tools/qlist/tst_qlist.cpp
index b3f8130d27..5a485e88d2 100644
--- a/tests/auto/corelib/tools/qlist/tst_qlist.cpp
+++ b/tests/auto/corelib/tools/qlist/tst_qlist.cpp
@@ -364,12 +364,14 @@ private slots:
void takeLastOptimal() const;
void takeLastMovable() const;
void takeLastComplex() const;
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
void toSetOptimal() const;
void toSetMovable() const;
void toSetComplex() const;
void toStdListOptimal() const;
void toStdListMovable() const;
void toStdListComplex() const;
+#endif
void toVectorOptimal() const;
void toVectorMovable() const;
void toVectorComplex() const;
@@ -426,8 +428,10 @@ private:
template<typename T> void takeAt() const;
template<typename T> void takeFirst() const;
template<typename T> void takeLast() const;
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
template<typename T> void toSet() const;
template<typename T> void toStdList() const;
+#endif
template<typename T> void toVector() const;
template<typename T> void value() const;
@@ -1457,11 +1461,11 @@ void tst_QList::swap() const
list << T_FOO << T_BAR << T_BAZ;
// swap
- list.swap(0, 2);
+ list.swapItemsAt(0, 2);
QCOMPARE(list, QList<T>() << T_BAZ << T_BAR << T_FOO);
// swap again
- list.swap(1, 2);
+ list.swapItemsAt(1, 2);
QCOMPARE(list, QList<T>() << T_BAZ << T_FOO << T_BAR);
QList<T> list2;
@@ -1595,6 +1599,7 @@ void tst_QList::takeLastComplex() const
QCOMPARE(liveCount, Complex::getLiveCount());
}
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
template<typename T>
void tst_QList::toSet() const
{
@@ -1669,6 +1674,7 @@ void tst_QList::toStdListComplex() const
toStdList<Complex>();
QCOMPARE(liveCount, Complex::getLiveCount());
}
+#endif
template<typename T>
void tst_QList::toVector() const
@@ -1871,7 +1877,6 @@ void tst_QList::testSTLIteratorsComplex() const
void tst_QList::initializeList() const
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QList<int> v1{2,3,4};
QCOMPARE(v1, QList<int>() << 2 << 3 << 4);
QCOMPARE(v1, (QList<int>{2,3,4}));
@@ -1880,7 +1885,6 @@ void tst_QList::initializeList() const
QList<QList<int>> v3;
v3 << v1 << (QList<int>() << 1) << QList<int>() << v1;
QCOMPARE(v3, v2);
-#endif
}
template<typename T>
diff --git a/tests/auto/corelib/tools/qlocale/tst_qlocale.cpp b/tests/auto/corelib/tools/qlocale/tst_qlocale.cpp
index be2e2a2e08..ec8f2fc047 100644
--- a/tests/auto/corelib/tools/qlocale/tst_qlocale.cpp
+++ b/tests/auto/corelib/tools/qlocale/tst_qlocale.cpp
@@ -423,6 +423,7 @@ void tst_QLocale::defaulted_ctor()
}
QLocale::setDefault(QLocale(QLocale::C));
+ const QString empty;
TEST_CTOR("C", C, AnyCountry)
TEST_CTOR("bla", C, AnyCountry)
@@ -431,7 +432,7 @@ void tst_QLocale::defaulted_ctor()
TEST_CTOR("zz...", C, AnyCountry)
TEST_CTOR("", C, AnyCountry)
TEST_CTOR("en/", C, AnyCountry)
- TEST_CTOR(QString::null, C, AnyCountry)
+ TEST_CTOR(empty, C, AnyCountry)
TEST_CTOR("en", English, UnitedStates)
TEST_CTOR("en", English, UnitedStates)
TEST_CTOR("en.", English, UnitedStates)
diff --git a/tests/auto/corelib/tools/qmap/tst_qmap.cpp b/tests/auto/corelib/tools/qmap/tst_qmap.cpp
index b39444e76f..d66fd28779 100644
--- a/tests/auto/corelib/tools/qmap/tst_qmap.cpp
+++ b/tests/auto/corelib/tools/qmap/tst_qmap.cpp
@@ -1319,7 +1319,6 @@ void tst_QMap::checkMostLeftNode()
void tst_QMap::initializerList()
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QMap<int, QString> map = {{1, "bar"}, {1, "hello"}, {2, "initializer_list"}};
QCOMPARE(map.count(), 2);
QCOMPARE(map[1], QString("hello"));
@@ -1346,9 +1345,6 @@ void tst_QMap::initializerList()
QMultiMap<float, float> emptyPairs2{{}, {}};
QVERIFY(!emptyPairs2.isEmpty());
-#else
- QSKIP("Compiler doesn't support initializer lists");
-#endif
}
void tst_QMap::testInsertWithHint()
diff --git a/tests/auto/corelib/tools/qpair/qpair.pro b/tests/auto/corelib/tools/qpair/qpair.pro
index 659be887d3..d684a24a57 100644
--- a/tests/auto/corelib/tools/qpair/qpair.pro
+++ b/tests/auto/corelib/tools/qpair/qpair.pro
@@ -2,3 +2,6 @@ CONFIG += testcase
TARGET = tst_qpair
QT = core testlib
SOURCES = tst_qpair.cpp
+
+# Force C++17 if available (needed due to Q_COMPILER_DEDUCTION_GUIDES)
+contains(QT_CONFIG, c++1z): CONFIG += c++1z
diff --git a/tests/auto/corelib/tools/qpair/tst_qpair.cpp b/tests/auto/corelib/tools/qpair/tst_qpair.cpp
index dedc353e67..3c972329bc 100644
--- a/tests/auto/corelib/tools/qpair/tst_qpair.cpp
+++ b/tests/auto/corelib/tools/qpair/tst_qpair.cpp
@@ -39,6 +39,7 @@ private Q_SLOTS:
void testConstexpr();
void testConversions();
void taskQTBUG_48780_pairContainingCArray();
+ void testDeducationRules();
};
class C { C() {} char _[4]; };
@@ -202,5 +203,30 @@ void tst_QPair::taskQTBUG_48780_pairContainingCArray()
Q_UNUSED(pair);
}
+void tst_QPair::testDeducationRules()
+{
+#if defined(__cpp_deduction_guides) && __cpp_deduction_guides >= 201606
+ QPair p1{1, 2};
+ static_assert(std::is_same<decltype(p1)::first_type, decltype(1)>::value);
+ static_assert(std::is_same<decltype(p1)::second_type, decltype(2)>::value);
+ QCOMPARE(p1.first, 1);
+ QCOMPARE(p1.second, 2);
+
+ QPair p2{QString("string"), 2};
+ static_assert(std::is_same<decltype(p2)::first_type, QString>::value);
+ static_assert(std::is_same<decltype(p2)::second_type, decltype(2)>::value);
+ QCOMPARE(p2.first, "string");
+ QCOMPARE(p2.second, 2);
+
+ QPair p3(p2);
+ static_assert(std::is_same<decltype(p3)::first_type, decltype(p2)::first_type>::value);
+ static_assert(std::is_same<decltype(p3)::second_type, decltype(p2)::second_type>::value);
+ QCOMPARE(p3.first, "string");
+ QCOMPARE(p3.second, 2);
+#else
+ QSKIP("Unsupported");
+#endif
+}
+
QTEST_APPLESS_MAIN(tst_QPair)
#include "tst_qpair.moc"
diff --git a/tests/auto/corelib/tools/qscopedpointer/tst_qscopedpointer.cpp b/tests/auto/corelib/tools/qscopedpointer/tst_qscopedpointer.cpp
index b943b04e23..ea94cc2999 100644
--- a/tests/auto/corelib/tools/qscopedpointer/tst_qscopedpointer.cpp
+++ b/tests/auto/corelib/tools/qscopedpointer/tst_qscopedpointer.cpp
@@ -327,7 +327,7 @@ struct RefCounted
~RefCounted()
{
- QVERIFY( ref.load() == 0 );
+ QVERIFY( ref.loadRelaxed() == 0 );
instanceCount.deref();
}
@@ -369,13 +369,13 @@ void scopedPointerComparisonTest(const A1 &a1, const A2 &a2, const B &b)
void tst_QScopedPointer::comparison()
{
- QCOMPARE( RefCounted::instanceCount.load(), 0 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 0 );
{
RefCounted *a = new RefCounted;
RefCounted *b = new RefCounted;
- QCOMPARE( RefCounted::instanceCount.load(), 2 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 2 );
QScopedPointer<RefCounted> pa1(a);
QScopedPointer<RefCounted> pa2(a);
@@ -387,16 +387,16 @@ void tst_QScopedPointer::comparison()
pa2.take();
- QCOMPARE( RefCounted::instanceCount.load(), 2 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 2 );
}
- QCOMPARE( RefCounted::instanceCount.load(), 0 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 0 );
{
RefCounted *a = new RefCounted[42];
RefCounted *b = new RefCounted[43];
- QCOMPARE( RefCounted::instanceCount.load(), 85 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 85 );
QScopedArrayPointer<RefCounted> pa1(a);
QScopedArrayPointer<RefCounted> pa2(a);
@@ -406,10 +406,10 @@ void tst_QScopedPointer::comparison()
pa2.take();
- QCOMPARE( RefCounted::instanceCount.load(), 85 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 85 );
}
- QCOMPARE( RefCounted::instanceCount.load(), 0 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 0 );
{
// QScopedSharedPointer is an internal helper class -- it is unsupported!
@@ -417,42 +417,42 @@ void tst_QScopedPointer::comparison()
RefCounted *a = new RefCounted;
RefCounted *b = new RefCounted;
- QCOMPARE( RefCounted::instanceCount.load(), 2 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 2 );
QSharedDataPointer<RefCounted> pa1(a);
QSharedDataPointer<RefCounted> pa2(a);
QSharedDataPointer<RefCounted> pb(b);
- QCOMPARE( a->ref.load(), 2 );
- QCOMPARE( b->ref.load(), 1 );
- QCOMPARE( RefCounted::instanceCount.load(), 2 );
+ QCOMPARE( a->ref.loadRelaxed(), 2 );
+ QCOMPARE( b->ref.loadRelaxed(), 1 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 2 );
scopedPointerComparisonTest(pa1, pa2, pb);
- QCOMPARE( RefCounted::instanceCount.load(), 2 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 2 );
}
- QCOMPARE( RefCounted::instanceCount.load(), 0 );
+ QCOMPARE( RefCounted::instanceCount.loadRelaxed(), 0 );
}
void tst_QScopedPointer::array()
{
- int instCount = RefCounted::instanceCount.load();
+ int instCount = RefCounted::instanceCount.loadRelaxed();
{
QScopedArrayPointer<RefCounted> array;
array.reset(new RefCounted[42]);
- QCOMPARE(instCount + 42, RefCounted::instanceCount.load());
+ QCOMPARE(instCount + 42, RefCounted::instanceCount.loadRelaxed());
}
- QCOMPARE(instCount, RefCounted::instanceCount.load());
+ QCOMPARE(instCount, RefCounted::instanceCount.loadRelaxed());
{
QScopedArrayPointer<RefCounted> array(new RefCounted[42]);
- QCOMPARE(instCount + 42, RefCounted::instanceCount.load());
+ QCOMPARE(instCount + 42, RefCounted::instanceCount.loadRelaxed());
array.reset(new RefCounted[28]);
- QCOMPARE(instCount + 28, RefCounted::instanceCount.load());
+ QCOMPARE(instCount + 28, RefCounted::instanceCount.loadRelaxed());
array.reset(0);
- QCOMPARE(instCount, RefCounted::instanceCount.load());
+ QCOMPARE(instCount, RefCounted::instanceCount.loadRelaxed());
}
- QCOMPARE(instCount, RefCounted::instanceCount.load());
+ QCOMPARE(instCount, RefCounted::instanceCount.loadRelaxed());
}
diff --git a/tests/auto/corelib/tools/qscopedvaluerollback/tst_qscopedvaluerollback.cpp b/tests/auto/corelib/tools/qscopedvaluerollback/tst_qscopedvaluerollback.cpp
index 656dd6a6e3..9b607db608 100644
--- a/tests/auto/corelib/tools/qscopedvaluerollback/tst_qscopedvaluerollback.cpp
+++ b/tests/auto/corelib/tools/qscopedvaluerollback/tst_qscopedvaluerollback.cpp
@@ -46,6 +46,7 @@ private Q_SLOTS:
void rollbackToPreviousCommit();
void exceptions();
void earlyExitScope();
+ void moveOnly();
private:
void earlyExitScope_helper(int exitpoint, int &member);
};
@@ -190,5 +191,17 @@ void tst_QScopedValueRollback::earlyExitScope_helper(int exitpoint, int& member)
r.commit();
}
+void tst_QScopedValueRollback::moveOnly()
+{
+ std::unique_ptr<int> uniquePtr;
+ std::unique_ptr<int> newVal(new int(5));
+ QVERIFY(!uniquePtr);
+ {
+ QScopedValueRollback<std::unique_ptr<int>> r(uniquePtr, std::move(newVal));
+ QVERIFY(uniquePtr);
+ }
+ QVERIFY(!uniquePtr);
+}
+
QTEST_MAIN(tst_QScopedValueRollback)
#include "tst_qscopedvaluerollback.moc"
diff --git a/tests/auto/corelib/tools/qset/tst_qset.cpp b/tests/auto/corelib/tools/qset/tst_qset.cpp
index 0b60350380..31b4c0449e 100644
--- a/tests/auto/corelib/tools/qset/tst_qset.cpp
+++ b/tests/auto/corelib/tools/qset/tst_qset.cpp
@@ -955,7 +955,6 @@ void tst_QSet::makeSureTheComfortFunctionsCompile()
void tst_QSet::initializerList()
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QSet<int> set = {1, 1, 2, 3, 4, 5};
QCOMPARE(set.count(), 5);
QVERIFY(set.contains(1));
@@ -976,9 +975,6 @@ void tst_QSet::initializerList()
QSet<int> set3{{}, {}, {}};
QVERIFY(!set3.isEmpty());
-#else
- QSKIP("Compiler doesn't support initializer lists");
-#endif
}
void tst_QSet::qhash()
@@ -1011,15 +1007,7 @@ void tst_QSet::qhash()
// check that sets of sets work:
//
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QSet<QSet<int> > intSetSet = { { 0, 1, 2 }, { 0, 1 }, { 1, 2 } };
-#else
- QSet<QSet<int> > intSetSet;
- QSet<int> intSet01, intSet12;
- intSet01 << 0 << 1;
- intSet12 << 1 << 2;
- intSetSet << intSet01 << intSet12 << (intSet01|intSet12);
-#endif
QCOMPARE(intSetSet.size(), 3);
}
}
diff --git a/tests/auto/corelib/tools/qsharedpointer/tst_qsharedpointer.cpp b/tests/auto/corelib/tools/qsharedpointer/tst_qsharedpointer.cpp
index e97848fb1c..187b73eeec 100644
--- a/tests/auto/corelib/tools/qsharedpointer/tst_qsharedpointer.cpp
+++ b/tests/auto/corelib/tools/qsharedpointer/tst_qsharedpointer.cpp
@@ -79,6 +79,7 @@ private slots:
void sharedPointerFromQObjectWithWeak();
void weakQObjectFromSharedPointer();
void objectCast();
+ void objectCastStdSharedPtr();
void differentPointers();
void virtualBaseDifferentPointers();
#ifndef QTEST_NO_RTTI
@@ -90,9 +91,7 @@ private slots:
#endif
void constCorrectness();
void customDeleter();
-#ifdef Q_COMPILER_LAMBDA
void lambdaCustomDeleter();
-#endif
void creating();
void creatingCvQualified();
void creatingVariadic();
@@ -227,7 +226,6 @@ struct NoDefaultConstructorConstRef2
NoDefaultConstructorConstRef2(const QByteArray &ba, int i = 42) : str(QString::fromLatin1(ba)), i(i) {}
};
-#ifdef Q_COMPILER_RVALUE_REFS
struct NoDefaultConstructorRRef1
{
int &i;
@@ -239,7 +237,6 @@ struct NoDefaultConstructorRRef2
std::unique_ptr<int> i;
NoDefaultConstructorRRef2(std::unique_ptr<int> &&i) : i(std::move(i)) {}
};
-#endif
void tst_QSharedPointer::basics_data()
{
@@ -297,8 +294,8 @@ void tst_QSharedPointer::basics()
QVERIFY(! (ptr == otherData));
QVERIFY(! (otherData == ptr));
}
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.load() == 1);
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.load() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.loadRelaxed() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.loadRelaxed() == 1);
{
// create another object:
@@ -310,8 +307,8 @@ void tst_QSharedPointer::basics()
// otherData is deleted here
}
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.load() == 1);
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.load() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.loadRelaxed() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.loadRelaxed() == 1);
{
// create a copy:
@@ -328,8 +325,8 @@ void tst_QSharedPointer::basics()
QCOMPARE(copy.get(), aData);
QVERIFY(copy == aData);
}
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.load() == 1);
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.load() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.loadRelaxed() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.loadRelaxed() == 1);
{
// create a weak reference:
@@ -361,8 +358,8 @@ void tst_QSharedPointer::basics()
QCOMPARE(strong.data(), aData);
QCOMPARE(strong.get(), aData);
}
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.load() == 1);
- QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.load() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->weakref.loadRelaxed() == 1);
+ QVERIFY(!refCountData(ptr) || refCountData(ptr)->strongref.loadRelaxed() == 1);
// aData is deleted here
}
@@ -508,7 +505,6 @@ void tst_QSharedPointer::swap()
void tst_QSharedPointer::moveSemantics()
{
-#ifdef Q_COMPILER_RVALUE_REFS
QSharedPointer<int> p1, p2(new int(42)), control = p2;
QVERIFY(p1 != control);
QVERIFY(p1.isNull());
@@ -561,9 +557,6 @@ void tst_QSharedPointer::moveSemantics()
QVERIFY(w1.isNull());
QVERIFY(w2.isNull());
QVERIFY(w3.isNull());
-#else
- QSKIP("This test requires C++11 rvalue/move semantics support in the compiler.");
-#endif
}
void tst_QSharedPointer::useOfForwardDeclared()
@@ -580,10 +573,10 @@ void tst_QSharedPointer::useOfForwardDeclared()
// move assignment:
QSharedPointer<ForwardDeclared> sp4;
- sp4 = qMove(sp);
+ sp4 = std::move(sp);
// and move constuction:
- QSharedPointer<ForwardDeclared> sp5 = qMove(sp2);
+ QSharedPointer<ForwardDeclared> sp5 = std::move(sp2);
// swapping:
sp4.swap(sp3);
@@ -850,15 +843,15 @@ void tst_QSharedPointer::upCast()
QVERIFY(baseptr == derivedptr);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QWeakPointer<DerivedData> derivedptr = qWeakPointerCast<DerivedData>(baseptr);
QVERIFY(baseptr == derivedptr);
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QWeakPointer<Data> weakptr = baseptr;
@@ -866,16 +859,16 @@ void tst_QSharedPointer::upCast()
QVERIFY(baseptr == derivedptr);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QSharedPointer<DerivedData> derivedptr = baseptr.staticCast<DerivedData>();
QVERIFY(baseptr == derivedptr);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
}
class OtherObject: public QObject
@@ -1122,6 +1115,60 @@ void tst_QSharedPointer::objectCast()
safetyCheck();
}
+
+void tst_QSharedPointer::objectCastStdSharedPtr()
+{
+ {
+ OtherObject *data = new OtherObject;
+ std::shared_ptr<QObject> baseptr = std::shared_ptr<QObject>(data);
+ QVERIFY(baseptr.get() == data);
+
+ // perform successful object cast
+ std::shared_ptr<OtherObject> ptr = qobject_pointer_cast<OtherObject>(baseptr);
+ QVERIFY(ptr.get());
+ QVERIFY(ptr.get() == data);
+
+ QVERIFY(baseptr.get() == data);
+ }
+
+ {
+ OtherObject *data = new OtherObject;
+ std::shared_ptr<QObject> baseptr = std::shared_ptr<QObject>(data);
+ QVERIFY(baseptr.get() == data);
+
+ // perform successful object cast
+ std::shared_ptr<OtherObject> ptr = qobject_pointer_cast<OtherObject>(std::move(baseptr));
+ QVERIFY(ptr.get());
+ QVERIFY(ptr.get() == data);
+
+ QVERIFY(!baseptr.get());
+ }
+
+ {
+ QObject *data = new QObject;
+ std::shared_ptr<QObject> baseptr = std::shared_ptr<QObject>(data);
+ QVERIFY(baseptr.get() == data);
+
+ // perform unsuccessful object cast
+ std::shared_ptr<OtherObject> ptr = qobject_pointer_cast<OtherObject>(baseptr);
+ QVERIFY(!ptr.get());
+
+ QVERIFY(baseptr.get() == data);
+ }
+
+ {
+ QObject *data = new QObject;
+ std::shared_ptr<QObject> baseptr = std::shared_ptr<QObject>(data);
+ QVERIFY(baseptr.get() == data);
+
+ // perform unsuccessful object cast
+ std::shared_ptr<OtherObject> ptr = qobject_pointer_cast<OtherObject>(std::move(baseptr));
+ QVERIFY(!ptr.get());
+
+ QVERIFY(baseptr.get() == data);
+ }
+}
+
void tst_QSharedPointer::differentPointers()
{
{
@@ -1250,8 +1297,8 @@ void tst_QSharedPointer::dynamicCast()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QWeakPointer<Data> weakptr = baseptr;
@@ -1260,8 +1307,8 @@ void tst_QSharedPointer::dynamicCast()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QSharedPointer<DerivedData> derivedptr = baseptr.dynamicCast<DerivedData>();
@@ -1269,8 +1316,8 @@ void tst_QSharedPointer::dynamicCast()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
}
void tst_QSharedPointer::dynamicCastDifferentPointers()
@@ -1285,8 +1332,8 @@ void tst_QSharedPointer::dynamicCastDifferentPointers()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QWeakPointer<Data> weakptr = baseptr;
@@ -1295,8 +1342,8 @@ void tst_QSharedPointer::dynamicCastDifferentPointers()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QSharedPointer<DiffPtrDerivedData> derivedptr = baseptr.dynamicCast<DiffPtrDerivedData>();
@@ -1304,8 +1351,8 @@ void tst_QSharedPointer::dynamicCastDifferentPointers()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
Stuffing *nakedptr = dynamic_cast<Stuffing *>(baseptr.data());
@@ -1330,8 +1377,8 @@ void tst_QSharedPointer::dynamicCastVirtualBase()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QWeakPointer<Data> weakptr = baseptr;
@@ -1340,8 +1387,8 @@ void tst_QSharedPointer::dynamicCastVirtualBase()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QSharedPointer<VirtualDerived> derivedptr = baseptr.dynamicCast<VirtualDerived>();
@@ -1349,8 +1396,8 @@ void tst_QSharedPointer::dynamicCastVirtualBase()
QCOMPARE(derivedptr.data(), aData);
QCOMPARE(static_cast<Data *>(derivedptr.data()), baseptr.data());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
}
void tst_QSharedPointer::dynamicCastFailure()
@@ -1362,15 +1409,15 @@ void tst_QSharedPointer::dynamicCastFailure()
QSharedPointer<DerivedData> derivedptr = qSharedPointerDynamicCast<DerivedData>(baseptr);
QVERIFY(derivedptr.isNull());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
{
QSharedPointer<DerivedData> derivedptr = baseptr.dynamicCast<DerivedData>();
QVERIFY(derivedptr.isNull());
}
- QCOMPARE(int(refCountData(baseptr)->weakref.load()), 1);
- QCOMPARE(int(refCountData(baseptr)->strongref.load()), 1);
+ QCOMPARE(int(refCountData(baseptr)->weakref.loadRelaxed()), 1);
+ QCOMPARE(int(refCountData(baseptr)->strongref.loadRelaxed()), 1);
}
void tst_QSharedPointer::dynamicCastFailureNoLeak()
@@ -1677,7 +1724,6 @@ void tst_QSharedPointer::customDeleter()
safetyCheck();
}
-#ifdef Q_COMPILER_LAMBDA
// The compiler needs to be in C++11 mode and to support lambdas
void tst_QSharedPointer::lambdaCustomDeleter()
{
@@ -1705,7 +1751,6 @@ void tst_QSharedPointer::lambdaCustomDeleter()
}
safetyCheck();
}
-#endif
void customQObjectDeleterFn(QObject *obj)
{
@@ -1741,8 +1786,8 @@ void tst_QSharedPointer::creating()
QCOMPARE(Data::destructorCounter, 1);
// valgrind will complain here if something happened to the pointer
- QVERIFY(d->weakref.load() == 1);
- QVERIFY(d->strongref.load() == 0);
+ QVERIFY(d->weakref.loadRelaxed() == 1);
+ QVERIFY(d->strongref.loadRelaxed() == 0);
}
safetyCheck();
@@ -1977,7 +2022,7 @@ void tst_QSharedPointer::threadStressTest()
for (int r = 0; r < 5; ++r) {
QVector<QThread*> allThreads(6 * qMax(strongThreadCount, weakThreadCount) + 3, 0);
QSharedPointer<ThreadData> base = QSharedPointer<ThreadData>(new ThreadData(&counter));
- counter.store(0);
+ counter.storeRelaxed(0);
// set the pointers
for (int i = 0; i < strongThreadCount; ++i) {
@@ -2011,8 +2056,8 @@ void tst_QSharedPointer::threadStressTest()
// verify that the count is the right range
int minValue = strongThreadCount;
int maxValue = strongThreadCount + weakThreadCount;
- QVERIFY(counter.load() >= minValue);
- QVERIFY(counter.load() <= maxValue);
+ QVERIFY(counter.loadRelaxed() >= minValue);
+ QVERIFY(counter.loadRelaxed() <= maxValue);
}
}
@@ -2245,11 +2290,9 @@ void tst_QSharedPointer::invalidConstructs_data()
<< &QTest::QExternalTest::tryCompileFail
<< "struct IncompatibleCustomDeleter { void operator()(int *); };\n"
"QSharedPointer<Data> ptr(new Data, IncompatibleCustomDeleter());\n";
-#ifdef Q_COMPILER_LAMBDA
QTest::newRow("incompatible-custom-lambda-deleter")
<< &QTest::QExternalTest::tryCompileFail
<< "QSharedPointer<Data> ptr(new Data, [](int *) {});\n";
-#endif
}
void tst_QSharedPointer::invalidConstructs()
diff --git a/tests/auto/corelib/tools/qstring/tst_qstring.cpp b/tests/auto/corelib/tools/qstring/tst_qstring.cpp
index e8ed22e427..79f5a8c46d 100644
--- a/tests/auto/corelib/tools/qstring/tst_qstring.cpp
+++ b/tests/auto/corelib/tools/qstring/tst_qstring.cpp
@@ -482,8 +482,8 @@ private slots:
void indexOf2();
void indexOf3_data();
// void indexOf3();
- void sprintf();
- void sprintfS();
+ void asprintf();
+ void asprintfS();
void fill();
void truncate();
void chop_data();
@@ -578,7 +578,7 @@ private slots:
#ifdef QT_USE_ICU
void toUpperLower_icu();
#endif
-#if !defined(QT_NO_UNICODE_LITERAL) && defined(Q_COMPILER_LAMBDA)
+#if !defined(QT_NO_UNICODE_LITERAL)
void literals();
#endif
void eightBitLiterals_data();
@@ -612,7 +612,7 @@ QString verifyZeroTermination(const QString &str)
int strSize = str.size();
QChar strTerminator = str.constData()[strSize];
if (QChar('\0') != strTerminator)
- return QString::fromAscii(
+ return QString::fromLatin1(
"*** Result ('%1') not null-terminated: 0x%2 ***").arg(str)
.arg(strTerminator.unicode(), 4, 16, QChar('0'));
@@ -625,11 +625,11 @@ QString verifyZeroTermination(const QString &str)
const_cast<QChar *>(strData)[strSize] = QChar('x');
if (QChar('x') != str.constData()[strSize]) {
- return QString::fromAscii("*** Failed to replace null-terminator in "
+ return QString::fromLatin1("*** Failed to replace null-terminator in "
"result ('%1') ***").arg(str);
}
if (str != strCopy) {
- return QString::fromAscii( "*** Result ('%1') differs from its copy "
+ return QString::fromLatin1( "*** Result ('%1') differs from its copy "
"after null-terminator was replaced ***").arg(str);
}
const_cast<QChar *>(strData)[strSize] = QChar('\0'); // Restore sanity
@@ -1075,9 +1075,8 @@ void tst_QString::isNull()
QString a;
QVERIFY(a.isNull());
- const char *zero = 0;
- a.sprintf( zero );
- QVERIFY(!a.isNull());
+ const char *zero = nullptr;
+ QVERIFY(!QString::asprintf(zero).isNull());
}
QT_WARNING_POP
@@ -1263,75 +1262,66 @@ static inline const void *ptrValue(quintptr v)
return reinterpret_cast<const void *>(v);
}
-void tst_QString::sprintf()
+void tst_QString::asprintf()
{
QString a;
- a.sprintf("COMPARE");
- QCOMPARE(a, QLatin1String("COMPARE"));
- a.sprintf("%%%d",1);
- QCOMPARE(a, QLatin1String("%1"));
- QCOMPARE(a.sprintf("X%dY",2), QLatin1String("X2Y"));
- QCOMPARE(a.sprintf("X%9iY", 50000 ), QLatin1String("X 50000Y"));
- QCOMPARE(a.sprintf("X%-9sY","hello"), QLatin1String("Xhello Y"));
- QCOMPARE(a.sprintf("X%-9iY", 50000 ), QLatin1String("X50000 Y"));
- QCOMPARE(a.sprintf("%lf", 1.23), QLatin1String("1.230000"));
- QCOMPARE(a.sprintf("%lf", 1.23456789), QLatin1String("1.234568"));
- QCOMPARE(a.sprintf("%p", ptrValue(0xbfffd350)), QLatin1String("0xbfffd350"));
- QCOMPARE(a.sprintf("%p", ptrValue(0)), QLatin1String("0x0"));
+ QCOMPARE(QString::asprintf("COMPARE"), QLatin1String("COMPARE"));
+ QCOMPARE(QString::asprintf("%%%d", 1), QLatin1String("%1"));
+ QCOMPARE(QString::asprintf("X%dY",2), QLatin1String("X2Y"));
+ QCOMPARE(QString::asprintf("X%9iY", 50000 ), QLatin1String("X 50000Y"));
+ QCOMPARE(QString::asprintf("X%-9sY","hello"), QLatin1String("Xhello Y"));
+ QCOMPARE(QString::asprintf("X%-9iY", 50000 ), QLatin1String("X50000 Y"));
+ QCOMPARE(QString::asprintf("%lf", 1.23), QLatin1String("1.230000"));
+ QCOMPARE(QString::asprintf("%lf", 1.23456789), QLatin1String("1.234568"));
+ QCOMPARE(QString::asprintf("%p", ptrValue(0xbfffd350)), QLatin1String("0xbfffd350"));
+ QCOMPARE(QString::asprintf("%p", ptrValue(0)), QLatin1String("0x0"));
int i = 6;
long l = -2;
float f = 4.023f;
- QString S1;
- S1.sprintf("%d %ld %f",i,l,f);
- QCOMPARE(S1, QLatin1String("6 -2 4.023000"));
+ QCOMPARE(QString::asprintf("%d %ld %f", i, l, f), QLatin1String("6 -2 4.023000"));
double d = -514.25683;
- S1.sprintf("%f",d);
- QCOMPARE(S1, QLatin1String("-514.256830"));
+ QCOMPARE(QString::asprintf("%f", d), QLatin1String("-514.256830"));
}
-void tst_QString::sprintfS()
+void tst_QString::asprintfS()
{
- QString a;
- QCOMPARE(a.sprintf("%.3s", "Hello" ), QLatin1String("Hel"));
- QCOMPARE(a.sprintf("%10.3s", "Hello" ), QLatin1String(" Hel"));
- QCOMPARE(a.sprintf("%.10s", "Hello" ), QLatin1String("Hello"));
- QCOMPARE(a.sprintf("%10.10s", "Hello" ), QLatin1String(" Hello"));
- QCOMPARE(a.sprintf("%-10.10s", "Hello" ), QLatin1String("Hello "));
- QCOMPARE(a.sprintf("%-10.3s", "Hello" ), QLatin1String("Hel "));
- QCOMPARE(a.sprintf("%-5.5s", "Hello" ), QLatin1String("Hello"));
+ QCOMPARE(QString::asprintf("%.3s", "Hello" ), QLatin1String("Hel"));
+ QCOMPARE(QString::asprintf("%10.3s", "Hello" ), QLatin1String(" Hel"));
+ QCOMPARE(QString::asprintf("%.10s", "Hello" ), QLatin1String("Hello"));
+ QCOMPARE(QString::asprintf("%10.10s", "Hello" ), QLatin1String(" Hello"));
+ QCOMPARE(QString::asprintf("%-10.10s", "Hello" ), QLatin1String("Hello "));
+ QCOMPARE(QString::asprintf("%-10.3s", "Hello" ), QLatin1String("Hel "));
+ QCOMPARE(QString::asprintf("%-5.5s", "Hello" ), QLatin1String("Hello"));
// Check utf8 conversion for %s
- QCOMPARE(a.sprintf("%s", "\303\266\303\244\303\274\303\226\303\204\303\234\303\270\303\246\303\245\303\230\303\206\303\205"), QString::fromLatin1("\366\344\374\326\304\334\370\346\345\330\306\305"));
+ QCOMPARE(QString::asprintf("%s", "\303\266\303\244\303\274\303\226\303\204\303\234\303\270\303\246\303\245\303\230\303\206\303\205"), QString::fromLatin1("\366\344\374\326\304\334\370\346\345\330\306\305"));
int n1;
- a.sprintf("%s%n%s", "hello", &n1, "goodbye");
+ QCOMPARE(QString::asprintf("%s%n%s", "hello", &n1, "goodbye"), QString("hellogoodbye"));
QCOMPARE(n1, 5);
- QCOMPARE(a, QString("hellogoodbye"));
qlonglong n2;
- a.sprintf("%s%s%lln%s", "foo", "bar", &n2, "whiz");
+ QCOMPARE(QString::asprintf("%s%s%lln%s", "foo", "bar", &n2, "whiz"), QString("foobarwhiz"));
QCOMPARE((int)n2, 6);
- QCOMPARE(a, QString("foobarwhiz"));
{ // %ls
- QCOMPARE(a.sprintf("%.3ls", qUtf16Printable("Hello")), QLatin1String("Hel"));
- QCOMPARE(a.sprintf("%10.3ls", qUtf16Printable("Hello")), QLatin1String(" Hel"));
- QCOMPARE(a.sprintf("%.10ls", qUtf16Printable("Hello")), QLatin1String("Hello"));
- QCOMPARE(a.sprintf("%10.10ls", qUtf16Printable("Hello")), QLatin1String(" Hello"));
- QCOMPARE(a.sprintf("%-10.10ls", qUtf16Printable("Hello")), QLatin1String("Hello "));
- QCOMPARE(a.sprintf("%-10.3ls", qUtf16Printable("Hello")), QLatin1String("Hel "));
- QCOMPARE(a.sprintf("%-5.5ls", qUtf16Printable("Hello")), QLatin1String("Hello"));
+ QCOMPARE(QString::asprintf("%.3ls", qUtf16Printable("Hello")), QLatin1String("Hel"));
+ QCOMPARE(QString::asprintf("%10.3ls", qUtf16Printable("Hello")), QLatin1String(" Hel"));
+ QCOMPARE(QString::asprintf("%.10ls", qUtf16Printable("Hello")), QLatin1String("Hello"));
+ QCOMPARE(QString::asprintf("%10.10ls", qUtf16Printable("Hello")), QLatin1String(" Hello"));
+ QCOMPARE(QString::asprintf("%-10.10ls", qUtf16Printable("Hello")), QLatin1String("Hello "));
+ QCOMPARE(QString::asprintf("%-10.3ls", qUtf16Printable("Hello")), QLatin1String("Hel "));
+ QCOMPARE(QString::asprintf("%-5.5ls", qUtf16Printable("Hello")), QLatin1String("Hello"));
// Check utf16 is preserved for %ls
- QCOMPARE(a.sprintf("%ls",
+ QCOMPARE(QString::asprintf("%ls",
qUtf16Printable("\303\266\303\244\303\274\303\226\303\204\303\234\303\270\303\246\303\245\303\230\303\206\303\205")),
QLatin1String("\366\344\374\326\304\334\370\346\345\330\306\305"));
int n;
- a.sprintf("%ls%n%s", qUtf16Printable("hello"), &n, "goodbye");
+ QCOMPARE(QString::asprintf("%ls%n%s", qUtf16Printable("hello"), &n, "goodbye"), QLatin1String("hellogoodbye"));
QCOMPARE(n, 5);
- QCOMPARE(a, QLatin1String("hellogoodbye"));
}
}
@@ -2212,12 +2202,12 @@ void tst_QString::toUpper()
// call rvalue-ref while shared (the original mustn't change)
QString copy = s;
- QCOMPARE(qMove(copy).toUpper(), QString("GROSSSTRASSE"));
+ QCOMPARE(std::move(copy).toUpper(), QString("GROSSSTRASSE"));
QCOMPARE(s, QString::fromUtf8("Gro\xc3\x9fstra\xc3\x9f""e"));
// call rvalue-ref version on detached case
copy.clear();
- QCOMPARE(qMove(s).toUpper(), QString("GROSSSTRASSE"));
+ QCOMPARE(std::move(s).toUpper(), QString("GROSSSTRASSE"));
}
QString lower, upper;
@@ -2427,11 +2417,11 @@ void tst_QString::trimmed()
QCOMPARE(a.trimmed(), QLatin1String("a"));
a="Text";
- QCOMPARE(qMove(a).trimmed(), QLatin1String("Text"));
+ QCOMPARE(std::move(a).trimmed(), QLatin1String("Text"));
a=" ";
- QCOMPARE(qMove(a).trimmed(), QLatin1String(""));
+ QCOMPARE(std::move(a).trimmed(), QLatin1String(""));
a=" a ";
- QCOMPARE(qMove(a).trimmed(), QLatin1String("a"));
+ QCOMPARE(std::move(a).trimmed(), QLatin1String("a"));
}
void tst_QString::simplified_data()
@@ -2486,13 +2476,13 @@ void tst_QString::simplified()
// without detaching:
QString copy1 = full;
- QCOMPARE(qMove(full).simplified(), simple);
+ QCOMPARE(std::move(full).simplified(), simple);
QCOMPARE(full, orig_full);
// force a detach
if (!full.isEmpty())
full[0] = full[0];
- QCOMPARE(qMove(full).simplified(), simple);
+ QCOMPARE(std::move(full).simplified(), simple);
}
void tst_QString::insert_data(bool emptyIsNoop)
@@ -3789,7 +3779,7 @@ void tst_QString::startsWith()
QVERIFY( !a.startsWith("C") );
QVERIFY( !a.startsWith("ABCDEF") );
QVERIFY( a.startsWith("") );
- QVERIFY( a.startsWith(QString::null) );
+ QVERIFY( a.startsWith(QString()) );
QVERIFY( a.startsWith('A') );
QVERIFY( a.startsWith(QLatin1Char('A')) );
QVERIFY( a.startsWith(QChar('A')) );
@@ -3816,7 +3806,7 @@ void tst_QString::startsWith()
QVERIFY( !a.startsWith("c", Qt::CaseInsensitive) );
QVERIFY( !a.startsWith("abcdef", Qt::CaseInsensitive) );
QVERIFY( a.startsWith("", Qt::CaseInsensitive) );
- QVERIFY( a.startsWith(QString::null, Qt::CaseInsensitive) );
+ QVERIFY( a.startsWith(QString(), Qt::CaseInsensitive) );
QVERIFY( a.startsWith('a', Qt::CaseInsensitive) );
QVERIFY( a.startsWith('A', Qt::CaseInsensitive) );
QVERIFY( a.startsWith(QLatin1Char('a'), Qt::CaseInsensitive) );
@@ -3855,7 +3845,7 @@ void tst_QString::startsWith()
a = "";
QVERIFY( a.startsWith("") );
- QVERIFY( a.startsWith(QString::null) );
+ QVERIFY( a.startsWith(QString()) );
QVERIFY( !a.startsWith("ABC") );
QVERIFY( a.startsWith(QLatin1String("")) );
@@ -3868,7 +3858,7 @@ void tst_QString::startsWith()
a = QString();
QVERIFY( !a.startsWith("") );
- QVERIFY( a.startsWith(QString::null) );
+ QVERIFY( a.startsWith(QString()) );
QVERIFY( !a.startsWith("ABC") );
QVERIFY( !a.startsWith(QLatin1String("")) );
@@ -3897,7 +3887,7 @@ void tst_QString::endsWith()
QVERIFY( !a.endsWith("C") );
QVERIFY( !a.endsWith("ABCDEF") );
QVERIFY( a.endsWith("") );
- QVERIFY( a.endsWith(QString::null) );
+ QVERIFY( a.endsWith(QString()) );
QVERIFY( a.endsWith('B') );
QVERIFY( a.endsWith(QLatin1Char('B')) );
QVERIFY( a.endsWith(QChar('B')) );
@@ -3924,7 +3914,7 @@ void tst_QString::endsWith()
QVERIFY( !a.endsWith("c", Qt::CaseInsensitive) );
QVERIFY( !a.endsWith("abcdef", Qt::CaseInsensitive) );
QVERIFY( a.endsWith("", Qt::CaseInsensitive) );
- QVERIFY( a.endsWith(QString::null, Qt::CaseInsensitive) );
+ QVERIFY( a.endsWith(QString(), Qt::CaseInsensitive) );
QVERIFY( a.endsWith('b', Qt::CaseInsensitive) );
QVERIFY( a.endsWith('B', Qt::CaseInsensitive) );
QVERIFY( a.endsWith(QLatin1Char('b'), Qt::CaseInsensitive) );
@@ -3966,7 +3956,7 @@ void tst_QString::endsWith()
a = "";
QVERIFY( a.endsWith("") );
- QVERIFY( a.endsWith(QString::null) );
+ QVERIFY( a.endsWith(QString()) );
QVERIFY( !a.endsWith("ABC") );
QVERIFY( !a.endsWith(QLatin1Char(0)) );
QVERIFY( !a.endsWith(QLatin1Char('x')) );
@@ -3978,7 +3968,7 @@ void tst_QString::endsWith()
a = QString();
QVERIFY( !a.endsWith("") );
- QVERIFY( a.endsWith(QString::null) );
+ QVERIFY( a.endsWith(QString()) );
QVERIFY( !a.endsWith("ABC") );
QVERIFY( !a.endsWith(QLatin1String("")) );
@@ -4534,7 +4524,7 @@ void tst_QString::toLatin1Roundtrip()
// try the rvalue version of toLatin1()
QString s = unicodesrc;
- QCOMPARE(qMove(s).toLatin1(), latin1);
+ QCOMPARE(std::move(s).toLatin1(), latin1);
// and verify that the moved-from object can still be used
s = "foo";
@@ -4838,7 +4828,7 @@ void tst_QString::arg()
QCOMPARE( QString("%1").arg("hello", 10), QLatin1String(" hello") );
QCOMPARE( QString("%1%1").arg("hello"), QLatin1String("hellohello") );
QCOMPARE( QString("%2%1").arg("hello"), QLatin1String("%2hello") );
- QCOMPARE( QString("%1%1").arg(QString::null), QLatin1String("") );
+ QCOMPARE( QString("%1%1").arg(QString()), QLatin1String("") );
QCOMPARE( QString("%2%1").arg(""), QLatin1String("%2") );
QCOMPARE( QString("%2 %L1").arg(12345.6789).arg(12345.6789),
@@ -4934,9 +4924,7 @@ void tst_QString::doubleOut()
QCOMPARE(QString::number(micro), expect);
QCOMPARE(QString("%1").arg(micro), expect);
{
- QString text;
- text.sprintf("%g", micro);
- QCOMPARE(text, expect);
+ QCOMPARE(QString::asprintf("%g", micro), expect);
}
{
QString text;
@@ -5480,8 +5468,6 @@ void tst_QString::tortureSprintfDouble()
{
const SprintfDoubleData *data = g_sprintf_double_data;
- QString s;
-
for (; data->fmt != 0; ++data) {
double d;
char *buff = (char *)&d;
@@ -5496,7 +5482,7 @@ void tst_QString::tortureSprintfDouble()
for (uint i = 0; i < 8; ++i)
buff[7 - i] = data->bytes[i];
# endif
- s.sprintf(data->fmt, d);
+ const QString s = QString::asprintf(data->fmt, d);
#ifdef QT_NO_FPU // reduced precision when running with hardfloats in qemu
if (d - 0.1 < 1e12)
QSKIP("clib sprintf doesn't fill with 0's on this platform");
@@ -6450,32 +6436,24 @@ void tst_QString::QCharRefDetaching() const
void tst_QString::sprintfZU() const
{
{
- QString string;
size_t s = 6;
- string.sprintf("%zu", s);
- QCOMPARE(string, QString::fromLatin1("6"));
+ QCOMPARE(QString::asprintf("%zu", s), QString::fromLatin1("6"));
}
{
- QString string;
- string.sprintf("%s\n", "foo");
- QCOMPARE(string, QString::fromLatin1("foo\n"));
+ QCOMPARE(QString::asprintf("%s\n", "foo"), QString::fromLatin1("foo\n"));
}
{
/* This code crashed. I don't know how to reduce it further. In other words,
* both %zu and %s needs to be present. */
size_t s = 6;
- QString string;
- string.sprintf("%zu%s", s, "foo");
- QCOMPARE(string, QString::fromLatin1("6foo"));
+ QCOMPARE(QString::asprintf("%zu%s", s, "foo"), QString::fromLatin1("6foo"));
}
{
size_t s = 6;
- QString string;
- string.sprintf("%zu %s\n", s, "foo");
- QCOMPARE(string, QString::fromLatin1("6 foo\n"));
+ QCOMPARE(QString::asprintf("%zu %s\n", s, "foo"), QString::fromLatin1("6 foo\n"));
}
}
@@ -6643,7 +6621,7 @@ void tst_QString::toUpperLower_icu()
}
#endif
-#if !defined(QT_NO_UNICODE_LITERAL) && defined(Q_COMPILER_LAMBDA)
+#if !defined(QT_NO_UNICODE_LITERAL)
// Only tested on c++0x compliant compiler or gcc
void tst_QString::literals()
{
diff --git a/tests/auto/corelib/tools/qstringapisymmetry/tst_qstringapisymmetry.cpp b/tests/auto/corelib/tools/qstringapisymmetry/tst_qstringapisymmetry.cpp
index 82d58becfe..24382a2b61 100644
--- a/tests/auto/corelib/tools/qstringapisymmetry/tst_qstringapisymmetry.cpp
+++ b/tests/auto/corelib/tools/qstringapisymmetry/tst_qstringapisymmetry.cpp
@@ -1,6 +1,7 @@
/****************************************************************************
**
** Copyright (C) 2015 Klarälvdalens Datakonsult AB, a KDAB Group company, info@kdab.com, author Marc Mutz <marc.mutz@kdab.com>
+** Copyright (C) 2019 Mail.ru Group.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the test suite of the Qt Toolkit.
@@ -48,6 +49,14 @@ QString toQString(const T &t) { return QString(t); }
QString toQString(const QStringRef &ref) { return ref.toString(); }
QString toQString(QStringView view) { return view.toString(); }
+template <typename Iterable>
+QStringList toQStringList(const Iterable &i) {
+ QStringList result;
+ for (auto &e : i)
+ result.push_back(toQString(e));
+ return result;
+}
+
// FIXME: these are missing at the time of writing, add them, then remove the dummies here:
#define MAKE_RELOP(op, A1, A2) \
static bool operator op (A1 lhs, A2 rhs) \
@@ -293,6 +302,26 @@ private Q_SLOTS:
void endsWith_QLatin1String_QChar() { endsWith_impl<QLatin1String, QChar>(); }
private:
+ void split_data(bool rhsHasVariableLength = true);
+ template <typename Haystack, typename Needle> void split_impl() const;
+
+private Q_SLOTS:
+ // test all combinations of {QString, QStringRef} x {QString, QLatin1String, QChar}:
+ void split_QString_QString_data() { split_data(); }
+ void split_QString_QString() { split_impl<QString, QString>(); }
+ void split_QString_QLatin1String_data() { split_data(); }
+ void split_QString_QLatin1String() { split_impl<QString, QLatin1String>(); }
+ void split_QString_QChar_data() { split_data(false); }
+ void split_QString_QChar() { split_impl<QString, QChar>(); }
+
+ void split_QStringRef_QString_data() { split_data(); }
+ void split_QStringRef_QString() { split_impl<QStringRef, QString>(); }
+ void split_QStringRef_QLatin1String_data() { split_data(); }
+ void split_QStringRef_QLatin1String() { split_impl<QStringRef, QLatin1String>(); }
+ void split_QStringRef_QChar_data() { split_data(false); }
+ void split_QStringRef_QChar() { split_impl<QStringRef, QChar>(); }
+
+private:
void mid_data();
template <typename String> void mid_impl();
@@ -416,6 +445,129 @@ private Q_SLOTS:
void toUcs4_QStringRef() { toUcs4_impl<QStringRef>(); }
void toUcs4_QStringView_data() { toUcs4_data(); }
void toUcs4_QStringView() { toUcs4_impl<QStringView>(); }
+
+private:
+ template <typename Haystack, typename Needle> void indexOf_impl() const;
+ void indexOf_data();
+
+private Q_SLOTS:
+ void indexOf_QString_QString_data() { indexOf_data(); }
+ void indexOf_QString_QString() { indexOf_impl<QString, QString>(); }
+ void indexOf_QString_QLatin1String_data() { indexOf_data(); }
+ void indexOf_QString_QLatin1String() { indexOf_impl<QString, QLatin1String>(); }
+ void indexOf_QString_QStringRef_data() { indexOf_data(); }
+ void indexOf_QString_QStringRef() { indexOf_impl<QString, QStringRef>(); }
+ void indexOf_QString_QStringView_data() { indexOf_data(); }
+ void indexOf_QString_QStringView() { indexOf_impl<QString, QStringView>(); }
+
+ void indexOf_QLatin1String_QString_data() { indexOf_data(); }
+ void indexOf_QLatin1String_QString() { indexOf_impl<QLatin1String, QString>(); }
+ void indexOf_QLatin1String_QLatin1String_data() { indexOf_data(); }
+ void indexOf_QLatin1String_QLatin1String() { indexOf_impl<QLatin1String, QLatin1String>(); }
+ void indexOf_QLatin1String_QStringRef_data() { indexOf_data(); }
+ void indexOf_QLatin1String_QStringRef() { indexOf_impl<QLatin1String, QStringRef>(); }
+ void indexOf_QLatin1String_QStringView_data() { indexOf_data(); }
+ void indexOf_QLatin1String_QStringView() { indexOf_impl<QLatin1String, QStringView>(); }
+
+ void indexOf_QStringRef_QString_data() { indexOf_data(); }
+ void indexOf_QStringRef_QString() { indexOf_impl<QStringRef, QString>(); }
+ void indexOf_QStringRef_QLatin1String_data() { indexOf_data(); }
+ void indexOf_QStringRef_QLatin1String() { indexOf_impl<QStringRef, QLatin1String>(); }
+ void indexOf_QStringRef_QStringRef_data() { indexOf_data(); }
+ void indexOf_QStringRef_QStringRef() { indexOf_impl<QStringRef, QStringRef>(); }
+ void indexOf_QStringRef_QStringView_data() { indexOf_data(); }
+ void indexOf_QStringRef_QStringView() { indexOf_impl<QStringRef, QStringView>(); }
+
+ void indexOf_QStringView_QString_data() { indexOf_data(); }
+ void indexOf_QStringView_QString() { indexOf_impl<QStringView, QString>(); }
+ void indexOf_QStringView_QLatin1String_data() { indexOf_data(); }
+ void indexOf_QStringView_QLatin1String() { indexOf_impl<QStringView, QLatin1String>(); }
+ void indexOf_QStringView_QStringRef_data() { indexOf_data(); }
+ void indexOf_QStringView_QStringRef() { indexOf_impl<QStringView, QStringRef>(); }
+ void indexOf_QStringView_QStringView_data() { indexOf_data(); }
+ void indexOf_QStringView_QStringView() { indexOf_impl<QStringView, QStringView>(); }
+
+private:
+ template <typename Haystack, typename Needle> void contains_impl() const;
+ void contains_data();
+
+private Q_SLOTS:
+ void contains_QString_QString_data() { contains_data(); }
+ void contains_QString_QString() { contains_impl<QString, QString>(); }
+ void contains_QString_QLatin1String_data() { contains_data(); }
+ void contains_QString_QLatin1String() { contains_impl<QString, QLatin1String>(); }
+ void contains_QString_QStringRef_data() { contains_data(); }
+ void contains_QString_QStringRef() { contains_impl<QString, QStringRef>(); }
+ void contains_QString_QStringView_data() { contains_data(); }
+ void contains_QString_QStringView() { contains_impl<QString, QStringView>(); }
+
+ void contains_QLatin1String_QString_data() { contains_data(); }
+ void contains_QLatin1String_QString() { contains_impl<QLatin1String, QString>(); }
+ void contains_QLatin1String_QLatin1String_data() { contains_data(); }
+ void contains_QLatin1String_QLatin1String() { contains_impl<QLatin1String, QLatin1String>(); }
+ void contains_QLatin1String_QStringRef_data() { contains_data(); }
+ void contains_QLatin1String_QStringRef() { contains_impl<QLatin1String, QStringRef>(); }
+ void contains_QLatin1String_QStringView_data() { contains_data(); }
+ void contains_QLatin1String_QStringView() { contains_impl<QLatin1String, QStringView>(); }
+
+ void contains_QStringRef_QString_data() { contains_data(); }
+ void contains_QStringRef_QString() { contains_impl<QStringRef, QString>(); }
+ void contains_QStringRef_QLatin1String_data() { contains_data(); }
+ void contains_QStringRef_QLatin1String() { contains_impl<QStringRef, QLatin1String>(); }
+ void contains_QStringRef_QStringRef_data() { contains_data(); }
+ void contains_QStringRef_QStringRef() { contains_impl<QStringRef, QStringRef>(); }
+ void contains_QStringRef_QStringView_data() { contains_data(); }
+ void contains_QStringRef_QStringView() { contains_impl<QStringRef, QStringView>(); }
+
+ void contains_QStringView_QString_data() { contains_data(); }
+ void contains_QStringView_QString() { contains_impl<QStringView, QString>(); }
+ void contains_QStringView_QLatin1String_data() { contains_data(); }
+ void contains_QStringView_QLatin1String() { contains_impl<QStringView, QLatin1String>(); }
+ void contains_QStringView_QStringRef_data() { contains_data(); }
+ void contains_QStringView_QStringRef() { contains_impl<QStringView, QStringRef>(); }
+ void contains_QStringView_QStringView_data() { contains_data(); }
+ void contains_QStringView_QStringView() { contains_impl<QStringView, QStringView>(); }
+
+private:
+ template <typename Haystack, typename Needle> void lastIndexOf_impl() const;
+ void lastIndexOf_data();
+
+private Q_SLOTS:
+ void lastIndexOf_QString_QString_data() { lastIndexOf_data(); }
+ void lastIndexOf_QString_QString() { lastIndexOf_impl<QString, QString>(); }
+ void lastIndexOf_QString_QLatin1String_data() { lastIndexOf_data(); }
+ void lastIndexOf_QString_QLatin1String() { lastIndexOf_impl<QString, QLatin1String>(); }
+ void lastIndexOf_QString_QStringRef_data() { lastIndexOf_data(); }
+ void lastIndexOf_QString_QStringRef() { lastIndexOf_impl<QString, QStringRef>(); }
+ void lastIndexOf_QString_QStringView_data() { lastIndexOf_data(); }
+ void lastIndexOf_QString_QStringView() { lastIndexOf_impl<QString, QStringView>(); }
+
+ void lastIndexOf_QLatin1String_QString_data() { lastIndexOf_data(); }
+ void lastIndexOf_QLatin1String_QString() { lastIndexOf_impl<QLatin1String, QString>(); }
+ void lastIndexOf_QLatin1String_QLatin1String_data() { lastIndexOf_data(); }
+ void lastIndexOf_QLatin1String_QLatin1String() { lastIndexOf_impl<QLatin1String, QLatin1String>(); }
+ void lastIndexOf_QLatin1String_QStringRef_data() { lastIndexOf_data(); }
+ void lastIndexOf_QLatin1String_QStringRef() { lastIndexOf_impl<QLatin1String, QStringRef>(); }
+ void lastIndexOf_QLatin1String_QStringView_data() { lastIndexOf_data(); }
+ void lastIndexOf_QLatin1String_QStringView() { lastIndexOf_impl<QLatin1String, QStringView>(); }
+
+ void lastIndexOf_QStringRef_QString_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringRef_QString() { lastIndexOf_impl<QStringRef, QString>(); }
+ void lastIndexOf_QStringRef_QLatin1String_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringRef_QLatin1String() { lastIndexOf_impl<QStringRef, QLatin1String>(); }
+ void lastIndexOf_QStringRef_QStringRef_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringRef_QStringRef() { lastIndexOf_impl<QStringRef, QStringRef>(); }
+ void lastIndexOf_QStringRef_QStringView_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringRef_QStringView() { lastIndexOf_impl<QStringRef, QStringView>(); }
+
+ void lastIndexOf_QStringView_QString_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringView_QString() { lastIndexOf_impl<QStringView, QString>(); }
+ void lastIndexOf_QStringView_QLatin1String_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringView_QLatin1String() { lastIndexOf_impl<QStringView, QLatin1String>(); }
+ void lastIndexOf_QStringView_QStringRef_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringView_QStringRef() { lastIndexOf_impl<QStringView, QStringRef>(); }
+ void lastIndexOf_QStringView_QStringView_data() { lastIndexOf_data(); }
+ void lastIndexOf_QStringView_QStringView() { lastIndexOf_impl<QStringView, QStringView>(); }
};
void tst_QStringApiSymmetry::compare_data(bool hasConceptOfNullAndEmpty)
@@ -540,6 +692,7 @@ void tst_QStringApiSymmetry::compare_impl() const
}
static QString empty = QLatin1String("");
+static QString null;
// the tests below rely on the fact that these objects' names match their contents:
static QString a = QStringLiteral("a");
static QString A = QStringLiteral("A");
@@ -547,6 +700,14 @@ static QString b = QStringLiteral("b");
static QString B = QStringLiteral("B");
static QString c = QStringLiteral("c");
static QString C = QStringLiteral("C");
+static QString d = QStringLiteral("d");
+static QString D = QStringLiteral("D");
+static QString e = QStringLiteral("e");
+static QString E = QStringLiteral("E");
+static QString f = QStringLiteral("f");
+static QString F = QStringLiteral("F");
+static QString g = QStringLiteral("g");
+static QString G = QStringLiteral("G");
static QString ab = QStringLiteral("ab");
static QString aB = QStringLiteral("aB");
static QString Ab = QStringLiteral("Ab");
@@ -738,6 +899,119 @@ void tst_QStringApiSymmetry::endsWith_impl() const
QCOMPARE(haystack.endsWith(needle, Qt::CaseInsensitive), resultCIS);
}
+void tst_QStringApiSymmetry::split_data(bool rhsHasVariableLength)
+{
+ QTest::addColumn<QStringRef>("haystackU16");
+ QTest::addColumn<QLatin1String>("haystackL1");
+ QTest::addColumn<QStringRef>("needleU16");
+ QTest::addColumn<QLatin1String>("needleL1");
+ QTest::addColumn<QStringList>("resultCS");
+ QTest::addColumn<QStringList>("resultCIS");
+
+ if (rhsHasVariableLength) {
+ QTest::addRow("null ~= null$") << QStringRef{} << QLatin1String{}
+ << QStringRef{} << QLatin1String{}
+ << QStringList{{}, {}} << QStringList{{}, {}};
+ QTest::addRow("empty ~= null$") << QStringRef{&empty} << QLatin1String("")
+ << QStringRef{} << QLatin1String{}
+ << QStringList{empty, empty} << QStringList{empty, empty};
+ QTest::addRow("a ~= null$") << QStringRef{&a} << QLatin1String{"a"}
+ << QStringRef{} << QLatin1String{}
+ << QStringList{empty, a, empty} << QStringList{empty, a, empty};
+ QTest::addRow("null ~= empty$") << QStringRef{} << QLatin1String{}
+ << QStringRef{&empty} << QLatin1String{""}
+ << QStringList{{}, {}} << QStringList{{}, {}};
+ QTest::addRow("a ~= empty$") << QStringRef{&a} << QLatin1String{"a"}
+ << QStringRef{&empty} << QLatin1String{""}
+ << QStringList{empty, a, empty} << QStringList{empty, a, empty};
+ QTest::addRow("empty ~= empty$") << QStringRef{&empty} << QLatin1String{""}
+ << QStringRef{&empty} << QLatin1String{""}
+ << QStringList{empty, empty} << QStringList{empty, empty};
+ }
+ QTest::addRow("null ~= a$") << QStringRef{} << QLatin1String{}
+ << QStringRef{&a} << QLatin1String{"a"}
+ << QStringList{{}} << QStringList{{}};
+ QTest::addRow("empty ~= a$") << QStringRef{&empty} << QLatin1String{""}
+ << QStringRef{&a} << QLatin1String{"a"}
+ << QStringList{empty} << QStringList{empty};
+
+#define ROW(h, n, cs, cis) \
+ QTest::addRow("%s ~= %s$", #h, #n) << QStringRef(&h) << QLatin1String(#h) \
+ << QStringRef(&n) << QLatin1String(#n) \
+ << QStringList cs << QStringList cis
+ ROW(a, a, ({empty, empty}), ({empty, empty}));
+ ROW(a, A, {a}, ({empty, empty}));
+ ROW(a, b, {a}, {a});
+
+ if (rhsHasVariableLength)
+ ROW(b, ab, {b}, {b});
+
+ ROW(ab, b, ({a, empty}), ({a, empty}));
+ if (rhsHasVariableLength) {
+ ROW(ab, ab, ({empty, empty}), ({empty, empty}));
+ ROW(ab, aB, {ab}, ({empty, empty}));
+ ROW(ab, Ab, {ab}, ({empty, empty}));
+ }
+ ROW(ab, c, {ab}, {ab});
+
+ if (rhsHasVariableLength)
+ ROW(bc, abc, {bc}, {bc});
+
+ ROW(Abc, c, ({Ab, empty}), ({Ab, empty}));
+#if 0
+ if (rhsHasVariableLength) {
+ ROW(Abc, bc, 1, 1);
+ ROW(Abc, bC, 0, 1);
+ ROW(Abc, Bc, 0, 1);
+ ROW(Abc, BC, 0, 1);
+ ROW(aBC, bc, 0, 1);
+ ROW(aBC, bC, 0, 1);
+ ROW(aBC, Bc, 0, 1);
+ ROW(aBC, BC, 1, 1);
+ }
+#endif
+ ROW(ABC, b, {ABC}, ({A, C}));
+ ROW(ABC, a, {ABC}, ({empty, BC}));
+#undef ROW
+}
+
+static QStringList skipped(const QStringList &sl)
+{
+ QStringList result;
+ result.reserve(sl.size());
+ for (const QString &s : sl) {
+ if (!s.isEmpty())
+ result.push_back(s);
+ }
+ return result;
+}
+
+template <typename Haystack, typename Needle>
+void tst_QStringApiSymmetry::split_impl() const
+{
+ QFETCH(const QStringRef, haystackU16);
+ QFETCH(const QLatin1String, haystackL1);
+ QFETCH(const QStringRef, needleU16);
+ QFETCH(const QLatin1String, needleL1);
+ QFETCH(const QStringList, resultCS);
+ QFETCH(const QStringList, resultCIS);
+
+ const QStringList skippedResultCS = skipped(resultCS);
+ const QStringList skippedResultCIS = skipped(resultCIS);
+
+ const auto haystackU8 = haystackU16.toUtf8();
+ const auto needleU8 = needleU16.toUtf8();
+
+ const auto haystack = make<Haystack>(haystackU16, haystackL1, haystackU8);
+ const auto needle = make<Needle>(needleU16, needleL1, needleU8);
+
+ QCOMPARE(toQStringList(haystack.split(needle)), resultCS);
+ QCOMPARE(toQStringList(haystack.split(needle, Qt::KeepEmptyParts, Qt::CaseSensitive)), resultCS);
+ QCOMPARE(toQStringList(haystack.split(needle, Qt::KeepEmptyParts, Qt::CaseInsensitive)), resultCIS);
+ QCOMPARE(toQStringList(haystack.split(needle, Qt::SkipEmptyParts, Qt::CaseSensitive)), skippedResultCS);
+ QCOMPARE(toQStringList(haystack.split(needle, Qt::SkipEmptyParts, Qt::CaseInsensitive)), skippedResultCIS);
+}
+
void tst_QStringApiSymmetry::mid_data()
{
QTest::addColumn<QStringRef>("unicode");
@@ -1216,6 +1490,296 @@ void tst_QStringApiSymmetry::toUcs4_impl()
QCOMPARE(unicode.isEmpty(), ucs4.isEmpty());
}
+void tst_QStringApiSymmetry::indexOf_data()
+{
+ QTest::addColumn<QString>("haystackU16");
+ QTest::addColumn<QLatin1String>("haystackL1");
+ QTest::addColumn<QString>("needleU16");
+ QTest::addColumn<QLatin1String>("needleL1");
+ QTest::addColumn<qsizetype>("startpos");
+ QTest::addColumn<qsizetype>("resultCS");
+ QTest::addColumn<qsizetype>("resultCIS");
+
+ constexpr qsizetype zeroPos = 0;
+ constexpr qsizetype minus1Pos = -1;
+
+ QTest::addRow("haystack: null, needle: null") << null << QLatin1String()
+ << null << QLatin1String() << zeroPos << zeroPos << zeroPos;
+ QTest::addRow("haystack: empty, needle: null") << empty << QLatin1String("")
+ << null << QLatin1String() << zeroPos << zeroPos << zeroPos;
+ QTest::addRow("haystack: a, needle: null") << a << QLatin1String("a")
+ << null << QLatin1String() << zeroPos << zeroPos << zeroPos;
+ QTest::addRow("haystack: null, needle: empty") << null << QLatin1String()
+ << empty << QLatin1String("") << zeroPos << zeroPos << zeroPos;
+ QTest::addRow("haystack: a, needle: empty") << a << QLatin1String("a")
+ << empty << QLatin1String("") << zeroPos << zeroPos << zeroPos;
+ QTest::addRow("haystack: empty, needle: empty") << empty << QLatin1String("")
+ << empty << QLatin1String("") << zeroPos << zeroPos << zeroPos;
+ QTest::addRow("haystack: empty, needle: a") << empty << QLatin1String("")
+ << a << QLatin1String("a") << zeroPos << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: null, needle: a") << null << QLatin1String()
+ << a << QLatin1String("a") << zeroPos << minus1Pos << minus1Pos;
+
+
+#define ROW(h, n, st, cs, cis) \
+ QTest::addRow("haystack: %s, needle: %s", #h, #n) << h << QLatin1String(#h) \
+ << n << QLatin1String(#n) \
+ << qsizetype(st) << qsizetype(cs) << qsizetype(cis)
+
+ ROW(abc, a, 0, 0, 0);
+ ROW(abc, A, 0, -1, 0);
+ ROW(abc, a, 1, -1, -1);
+ ROW(abc, A, 1, -1, -1);
+ ROW(abc, b, 0, 1, 1);
+ ROW(abc, B, 0, -1, 1);
+ ROW(abc, b, 1, 1, 1);
+ ROW(abc, B, 1, -1, 1);
+ ROW(abc, B, 2, -1, -1);
+
+ ROW(ABC, A, 0, 0, 0);
+ ROW(ABC, a, 0, -1, 0);
+ ROW(ABC, A, 1, -1, -1);
+ ROW(ABC, a, 1, -1, -1);
+ ROW(ABC, B, 0, 1, 1);
+ ROW(ABC, b, 0, -1, 1);
+ ROW(ABC, B, 1, 1, 1);
+ ROW(ABC, b, 1, -1, 1);
+ ROW(ABC, B, 2, -1, -1);
+
+ ROW(aBc, bc, 0, -1, 1);
+ ROW(aBc, Bc, 0, 1, 1);
+ ROW(aBc, bC, 0, -1, 1);
+ ROW(aBc, BC, 0, -1, 1);
+
+ ROW(AbC, bc, 0, -1, 1);
+ ROW(AbC, Bc, 0, -1, 1);
+ ROW(AbC, bC, 0, 1, 1);
+ ROW(AbC, BC, 0, -1, 1);
+ ROW(AbC, BC, 1, -1, 1);
+ ROW(AbC, BC, 2, -1, -1);
+#undef ROW
+
+}
+
+template <typename Haystack, typename Needle>
+void tst_QStringApiSymmetry::indexOf_impl() const
+{
+ QFETCH(const QString, haystackU16);
+ QFETCH(const QLatin1String, haystackL1);
+ QFETCH(const QString, needleU16);
+ QFETCH(const QLatin1String, needleL1);
+ QFETCH(const qsizetype, startpos);
+ QFETCH(const qsizetype, resultCS);
+ QFETCH(const qsizetype, resultCIS);
+
+ const auto haystackU8 = haystackU16.toUtf8();
+ const auto needleU8 = needleU16.toUtf8();
+
+ const auto haystack = make<Haystack>(QStringRef(&haystackU16), haystackL1, haystackU8);
+ const auto needle = make<Needle>(QStringRef(&needleU16), needleL1, needleU8);
+
+ using size_type = typename Haystack::size_type;
+
+ QCOMPARE(haystack.indexOf(needle, startpos), size_type(resultCS));
+ QCOMPARE(haystack.indexOf(needle, startpos, Qt::CaseSensitive), size_type(resultCS));
+ QCOMPARE(haystack.indexOf(needle, startpos, Qt::CaseInsensitive), size_type(resultCIS));
+
+ if (needle.size() == 1)
+ {
+ QCOMPARE(haystack.indexOf(needle[0], startpos), size_type(resultCS));
+ QCOMPARE(haystack.indexOf(needle[0], startpos, Qt::CaseSensitive), size_type(resultCS));
+ QCOMPARE(haystack.indexOf(needle[0], startpos, Qt::CaseInsensitive), size_type(resultCIS));
+ }
+}
+
+static QString ABCDEFGHIEfGEFG = QStringLiteral("ABCDEFGHIEfGEFG");
+static QString EFG = QStringLiteral("EFG");
+static QString efg = QStringLiteral("efg");
+static QString asd = QStringLiteral("asd");
+static QString asdf = QStringLiteral("asdf");
+static QString Z = QStringLiteral("Z");
+
+void tst_QStringApiSymmetry::contains_data()
+{
+ QTest::addColumn<QString>("haystackU16");
+ QTest::addColumn<QLatin1String>("haystackL1");
+ QTest::addColumn<QString>("needleU16");
+ QTest::addColumn<QLatin1String>("needleL1");
+ QTest::addColumn<bool>("resultCS");
+ QTest::addColumn<bool>("resultCIS");
+
+ QTest::addRow("haystack: null, needle: null") << null << QLatin1String()
+ << null << QLatin1String() << true << true;
+ QTest::addRow("haystack: empty, needle: null") << empty << QLatin1String("")
+ << null << QLatin1String() << true << true;
+ QTest::addRow("haystack: a, needle: null") << a << QLatin1String("a")
+ << null << QLatin1String() << true << true;
+ QTest::addRow("haystack: null, needle: empty") << null << QLatin1String()
+ << empty << QLatin1String("") << true << true;
+ QTest::addRow("haystack: a, needle: empty") << a << QLatin1String("a")
+ << empty << QLatin1String("") << true << true;;
+ QTest::addRow("haystack: empty, needle: empty") << empty << QLatin1String("")
+ << empty << QLatin1String("") << true << true;
+ QTest::addRow("haystack: empty, needle: a") << empty << QLatin1String("")
+ << a << QLatin1String("a") << false << false;
+ QTest::addRow("haystack: null, needle: a") << null << QLatin1String()
+ << a << QLatin1String("a") << false << false;
+
+#define ROW(h, n, cs, cis) \
+ QTest::addRow("haystack: %s, needle: %s", #h, #n) << h << QLatin1String(#h) \
+ << n << QLatin1String(#n) \
+ << cs << cis
+
+ ROW(ABCDEFGHIEfGEFG, A, true, true);
+ ROW(ABCDEFGHIEfGEFG, a, false, true);
+ ROW(ABCDEFGHIEfGEFG, Z, false, false);
+ ROW(ABCDEFGHIEfGEFG, EFG, true, true);
+ ROW(ABCDEFGHIEfGEFG, efg, false, true);
+ ROW(ABCDEFGHIEfGEFG, E, true, true);
+ ROW(ABCDEFGHIEfGEFG, e, false, true);
+#undef ROW
+}
+
+template <typename Haystack, typename Needle>
+void tst_QStringApiSymmetry::contains_impl() const
+{
+ QFETCH(const QString, haystackU16);
+ QFETCH(const QLatin1String, haystackL1);
+ QFETCH(const QString, needleU16);
+ QFETCH(const QLatin1String, needleL1);
+ QFETCH(const bool, resultCS);
+ QFETCH(const bool, resultCIS);
+
+ const auto haystackU8 = haystackU16.toUtf8();
+ const auto needleU8 = needleU16.toUtf8();
+
+ const auto haystack = make<Haystack>(QStringRef(&haystackU16), haystackL1, haystackU8);
+ const auto needle = make<Needle>(QStringRef(&needleU16), needleL1, needleU8);
+
+ QCOMPARE(haystack.contains(needle), resultCS);
+ QCOMPARE(haystack.contains(needle, Qt::CaseSensitive), resultCS);
+ QCOMPARE(haystack.contains(needle, Qt::CaseInsensitive), resultCIS);
+
+ if (needle.size() == 1)
+ {
+ QCOMPARE(haystack.contains(needle[0]), resultCS);
+ QCOMPARE(haystack.contains(needle[0], Qt::CaseSensitive), resultCS);
+ QCOMPARE(haystack.contains(needle[0], Qt::CaseInsensitive), resultCIS);
+ }
+}
+
+void tst_QStringApiSymmetry::lastIndexOf_data()
+{
+ QTest::addColumn<QString>("haystackU16");
+ QTest::addColumn<QLatin1String>("haystackL1");
+ QTest::addColumn<QString>("needleU16");
+ QTest::addColumn<QLatin1String>("needleL1");
+ QTest::addColumn<qsizetype>("startpos");
+ QTest::addColumn<qsizetype>("resultCS");
+ QTest::addColumn<qsizetype>("resultCIS");
+
+ constexpr qsizetype zeroPos = 0;
+ constexpr qsizetype minus1Pos = -1;
+
+ QTest::addRow("haystack: null, needle: null") << null << QLatin1String()
+ << null << QLatin1String() << minus1Pos << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: empty, needle: null") << empty << QLatin1String("")
+ << null << QLatin1String() << minus1Pos << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: a, needle: null") << a << QLatin1String("a")
+ << null << QLatin1String() << minus1Pos << zeroPos << zeroPos;
+ QTest::addRow("haystack: null, needle: empty") << null << QLatin1String()
+ << empty << QLatin1String("") << minus1Pos << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: a, needle: empty") << a << QLatin1String("a")
+ << empty << QLatin1String("") << minus1Pos << zeroPos << zeroPos;
+ QTest::addRow("haystack: empty, needle: empty") << empty << QLatin1String("")
+ << empty << QLatin1String("") << minus1Pos << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: empty, needle: a") << empty << QLatin1String("")
+ << a << QLatin1String("a") << minus1Pos << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: null, needle: a") << null << QLatin1String()
+ << a << QLatin1String("a") << minus1Pos << minus1Pos << minus1Pos;
+
+ QTest::addRow("haystack: a, needle: null") << a << QLatin1String("a")
+ << null << QLatin1String() << qsizetype(1) << qsizetype(1) << qsizetype(1);
+ QTest::addRow("haystack: a, needle: empty") << a << QLatin1String("a")
+ << empty << QLatin1String("") << qsizetype(1) << qsizetype(1) << qsizetype(1);
+ QTest::addRow("haystack: a, needle: null") << a << QLatin1String("a")
+ << null << QLatin1String() << qsizetype(2) << minus1Pos << minus1Pos;
+ QTest::addRow("haystack: a, needle: empty") << a << QLatin1String("a")
+ << empty << QLatin1String("") << qsizetype(2) << minus1Pos << minus1Pos;
+
+#define ROW(h, n, st, cs, cis) \
+ QTest::addRow("haystack: %s, needle: %s", #h, #n) << h << QLatin1String(#h) \
+ << n << QLatin1String(#n) \
+ << qsizetype(st) << qsizetype(cs) << qsizetype(cis)
+
+ ROW(asd, asdf, -1, -1, -1);
+
+ ROW(ABCDEFGHIEfGEFG, G, -1, 14, 14);
+ ROW(ABCDEFGHIEfGEFG, g, -1, -1, 14);
+ ROW(ABCDEFGHIEfGEFG, G, -3, 11, 11);
+ ROW(ABCDEFGHIEfGEFG, g, -3, -1, 11);
+ ROW(ABCDEFGHIEfGEFG, G, -5, 6, 6);
+ ROW(ABCDEFGHIEfGEFG, g, -5, -1, 6);
+ ROW(ABCDEFGHIEfGEFG, G, 14, 14, 14);
+ ROW(ABCDEFGHIEfGEFG, g, 14, -1, 14);
+ ROW(ABCDEFGHIEfGEFG, G, 13, 11, 11);
+ ROW(ABCDEFGHIEfGEFG, g, 13, -1, 11);
+ ROW(ABCDEFGHIEfGEFG, G, 15, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, g, 15, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, B, 14, 1, 1);
+ ROW(ABCDEFGHIEfGEFG, b, 14, -1, 1);
+ ROW(ABCDEFGHIEfGEFG, B, -1, 1, 1);
+ ROW(ABCDEFGHIEfGEFG, b, -1, -1, 1);
+ ROW(ABCDEFGHIEfGEFG, B, 1, 1, 1);
+ ROW(ABCDEFGHIEfGEFG, b, 1, -1, 1);
+ ROW(ABCDEFGHIEfGEFG, B, 0, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, b, 0, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, A, 0, 0, 0);
+ ROW(ABCDEFGHIEfGEFG, a, 0, -1, 0);
+ ROW(ABCDEFGHIEfGEFG, A, -15, 0, 0);
+ ROW(ABCDEFGHIEfGEFG, a, -15, -1, 0);
+
+ ROW(ABCDEFGHIEfGEFG, efg, 0, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, efg, 15, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, efg, -15, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, efg, 14, -1, 12);
+ ROW(ABCDEFGHIEfGEFG, efg, 12, -1, 12);
+ ROW(ABCDEFGHIEfGEFG, efg, -12, -1, -1);
+ ROW(ABCDEFGHIEfGEFG, efg, 11, -1, 9);
+#undef ROW
+}
+
+template <typename Haystack, typename Needle>
+void tst_QStringApiSymmetry::lastIndexOf_impl() const
+{
+ QFETCH(const QString, haystackU16);
+ QFETCH(const QLatin1String, haystackL1);
+ QFETCH(const QString, needleU16);
+ QFETCH(const QLatin1String, needleL1);
+ QFETCH(const qsizetype, startpos);
+ QFETCH(const qsizetype, resultCS);
+ QFETCH(const qsizetype, resultCIS);
+
+ const auto haystackU8 = haystackU16.toUtf8();
+ const auto needleU8 = needleU16.toUtf8();
+
+ const auto haystack = make<Haystack>(QStringRef(&haystackU16), haystackL1, haystackU8);
+ const auto needle = make<Needle>(QStringRef(&needleU16), needleL1, needleU8);
+
+ using size_type = typename Haystack::size_type;
+
+ QCOMPARE(haystack.lastIndexOf(needle, startpos), size_type(resultCS));
+ QCOMPARE(haystack.lastIndexOf(needle, startpos, Qt::CaseSensitive), size_type(resultCS));
+ QCOMPARE(haystack.lastIndexOf(needle, startpos, Qt::CaseInsensitive), size_type(resultCIS));
+
+ if (needle.size() == 1)
+ {
+ QCOMPARE(haystack.lastIndexOf(needle[0], startpos), size_type(resultCS));
+ QCOMPARE(haystack.lastIndexOf(needle[0], startpos, Qt::CaseSensitive), size_type(resultCS));
+ QCOMPARE(haystack.lastIndexOf(needle[0], startpos, Qt::CaseInsensitive), size_type(resultCIS));
+ }
+}
+
QTEST_APPLESS_MAIN(tst_QStringApiSymmetry)
#include "tst_qstringapisymmetry.moc"
diff --git a/tests/auto/corelib/tools/qstringlist/tst_qstringlist.cpp b/tests/auto/corelib/tools/qstringlist/tst_qstringlist.cpp
index 42bdf62a93..2b5aa8e98b 100644
--- a/tests/auto/corelib/tools/qstringlist/tst_qstringlist.cpp
+++ b/tests/auto/corelib/tools/qstringlist/tst_qstringlist.cpp
@@ -30,13 +30,17 @@
#include <qregexp.h>
#include <qregularexpression.h>
#include <qstringlist.h>
+#include <qvector.h>
#include <locale.h>
+#include <algorithm>
+
class tst_QStringList : public QObject
{
Q_OBJECT
private slots:
+ void constructors();
void sort();
void filter();
void replaceInStrings();
@@ -59,13 +63,44 @@ private slots:
void joinChar() const;
void joinChar_data() const;
-#ifdef Q_COMPILER_INITIALIZER_LISTS
void initializeList() const;
-#endif
};
extern const char email[];
+void tst_QStringList::constructors()
+{
+ {
+ QStringList list;
+ QVERIFY(list.isEmpty());
+ QCOMPARE(list.size(), 0);
+ QVERIFY(list == QStringList());
+ }
+ {
+ QString str = "abc";
+ QStringList list(str);
+ QVERIFY(!list.isEmpty());
+ QCOMPARE(list.size(), 1);
+ QCOMPARE(list.at(0), str);
+ }
+ {
+ QStringList list{ "a", "b", "c" };
+ QVERIFY(!list.isEmpty());
+ QCOMPARE(list.size(), 3);
+ QCOMPARE(list.at(0), "a");
+ QCOMPARE(list.at(1), "b");
+ QCOMPARE(list.at(2), "c");
+ }
+ {
+ const QVector<QString> reference{ "a", "b", "c" };
+ QCOMPARE(reference.size(), 3);
+
+ QStringList list(reference.cbegin(), reference.cend());
+ QCOMPARE(list.size(), reference.size());
+ QVERIFY(std::equal(list.cbegin(), list.cend(), reference.cbegin()));
+ }
+}
+
void tst_QStringList::indexOf_regExp()
{
QStringList list;
@@ -482,8 +517,6 @@ void tst_QStringList::joinEmptiness() const
QVERIFY(string.isNull());
}
-#ifdef Q_COMPILER_INITIALIZER_LISTS
-// C++0x support is required
void tst_QStringList::initializeList() const
{
@@ -491,7 +524,6 @@ void tst_QStringList::initializeList() const
QCOMPARE(v1, (QStringList() << "hello" << "world" << "plop"));
QCOMPARE(v1, (QStringList{"hello","world","plop"}));
}
-#endif
QTEST_APPLESS_MAIN(tst_QStringList)
#include "tst_qstringlist.moc"
diff --git a/tests/auto/corelib/tools/qstringmatcher/tst_qstringmatcher.cpp b/tests/auto/corelib/tools/qstringmatcher/tst_qstringmatcher.cpp
index 8a55f54449..2d577bb0ab 100644
--- a/tests/auto/corelib/tools/qstringmatcher/tst_qstringmatcher.cpp
+++ b/tests/auto/corelib/tools/qstringmatcher/tst_qstringmatcher.cpp
@@ -100,6 +100,11 @@ void tst_QStringMatcher::indexIn()
matcher.setPattern(needle);
QCOMPARE(matcher.indexIn(haystack, from), indexIn);
+
+ const auto needleSV = QStringView(needle);
+ QStringMatcher matcherSV(needleSV);
+
+ QCOMPARE(matcherSV.indexIn(QStringView(haystack), from), indexIn);
}
void tst_QStringMatcher::setCaseSensitivity_data()
@@ -128,6 +133,7 @@ void tst_QStringMatcher::setCaseSensitivity()
matcher.setCaseSensitivity(static_cast<Qt::CaseSensitivity> (cs));
QCOMPARE(matcher.indexIn(haystack, from), indexIn);
+ QCOMPARE(matcher.indexIn(QStringView(haystack), from), indexIn);
}
void tst_QStringMatcher::assignOperator()
diff --git a/tests/auto/corelib/tools/qstringview/tst_qstringview.cpp b/tests/auto/corelib/tools/qstringview/tst_qstringview.cpp
index e800a0d794..794f39708a 100644
--- a/tests/auto/corelib/tools/qstringview/tst_qstringview.cpp
+++ b/tests/auto/corelib/tools/qstringview/tst_qstringview.cpp
@@ -134,6 +134,8 @@ private Q_SLOTS:
void literals() const;
void at() const;
+ void arg() const;
+
void fromQString() const;
void fromQStringRef() const;
@@ -425,6 +427,47 @@ void tst_QStringView::at() const
QCOMPARE(sv.at(4), QChar('o')); QCOMPARE(sv[4], QChar('o'));
}
+void tst_QStringView::arg() const
+{
+#define CHECK1(pattern, arg1, expected) \
+ do { \
+ auto p = QStringViewLiteral(pattern); \
+ QCOMPARE(p.arg(QLatin1String(arg1)), expected); \
+ QCOMPARE(p.arg(QStringViewLiteral(arg1)), expected); \
+ QCOMPARE(p.arg(QStringLiteral(arg1)), expected); \
+ QCOMPARE(p.arg(QString(QLatin1String(arg1))), expected); \
+ } while (false) \
+ /*end*/
+#define CHECK2(pattern, arg1, arg2, expected) \
+ do { \
+ auto p = QStringViewLiteral(pattern); \
+ QCOMPARE(p.arg(QLatin1String(arg1), QLatin1String(arg2)), expected); \
+ QCOMPARE(p.arg(QStringViewLiteral(arg1), QLatin1String(arg2)), expected); \
+ QCOMPARE(p.arg(QLatin1String(arg1), QStringViewLiteral(arg2)), expected); \
+ QCOMPARE(p.arg(QStringViewLiteral(arg1), QStringViewLiteral(arg2)), expected); \
+ } while (false) \
+ /*end*/
+
+ CHECK1("", "World", "");
+ CHECK1("%1", "World", "World");
+ CHECK1("!%1?", "World", "!World?");
+ CHECK1("%1%1", "World", "WorldWorld");
+ CHECK1("%1%2", "World", "World%2");
+ CHECK1("%2%1", "World", "%2World");
+
+ CHECK2("", "Hello", "World", "");
+ CHECK2("%1", "Hello", "World", "Hello");
+ CHECK2("!%1, %2?", "Hello", "World", "!Hello, World?");
+ CHECK2("%1%1", "Hello", "World", "HelloHello");
+ CHECK2("%1%2", "Hello", "World", "HelloWorld");
+ CHECK2("%2%1", "Hello", "World", "WorldHello");
+
+#undef CHECK2
+#undef CHECK1
+
+ QCOMPARE(QStringViewLiteral(" %2 %2 %1 %3 ").arg(QLatin1Char('c'), QChar::CarriageReturn, u'C'), " \r \r c C ");
+}
+
void tst_QStringView::fromQString() const
{
QString null;
diff --git a/tests/auto/corelib/tools/qtime/.gitignore b/tests/auto/corelib/tools/qtime/.gitignore
deleted file mode 100644
index 26a4c65cc2..0000000000
--- a/tests/auto/corelib/tools/qtime/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-tst_qtime
diff --git a/tests/auto/corelib/tools/qtime/qtime.pro b/tests/auto/corelib/tools/qtime/qtime.pro
deleted file mode 100644
index 0973b7a9ef..0000000000
--- a/tests/auto/corelib/tools/qtime/qtime.pro
+++ /dev/null
@@ -1,4 +0,0 @@
-CONFIG += testcase
-TARGET = tst_qtime
-QT = core testlib
-SOURCES = tst_qtime.cpp
diff --git a/tests/auto/corelib/tools/qtime/tst_qtime.cpp b/tests/auto/corelib/tools/qtime/tst_qtime.cpp
deleted file mode 100644
index 3e5724213e..0000000000
--- a/tests/auto/corelib/tools/qtime/tst_qtime.cpp
+++ /dev/null
@@ -1,802 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtTest/QtTest>
-#include "qdatetime.h"
-#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
-# include <locale.h>
-#endif
-
-class tst_QTime : public QObject
-{
- Q_OBJECT
-
-#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
-public:
- tst_QTime()
- {
- // Some tests depend on C locale - BF&I it with belt *and* braces:
- qputenv("LC_ALL", "C");
- setlocale(LC_ALL, "C");
- // Need to instantiate as early as possible, before anything accesses
- // the QSystemLocale singleton; once it exists, there's no changing it.
- }
-#endif // remove for ### Qt 6
-
-private slots:
- void msecsTo_data();
- void msecsTo();
- void secsTo_data();
- void secsTo();
- void setHMS_data();
- void setHMS();
- void hour_data();
- void hour();
- void isValid();
- void isNull();
- void addMSecs_data();
- void addMSecs();
- void addSecs_data();
- void addSecs();
- void operator_eq_eq_data();
- void operator_eq_eq();
- void operator_lt();
- void operator_gt();
- void operator_lt_eq();
- void operator_gt_eq();
- void fromStringFormat_data();
- void fromStringFormat();
- void fromStringDateFormat_data();
- void fromStringDateFormat();
- void toStringDateFormat_data();
- void toStringDateFormat();
- void toStringFormat_data();
- void toStringFormat();
- void toStringLocale();
- void msecsSinceStartOfDay_data();
- void msecsSinceStartOfDay();
-
-private:
- QTime invalidTime() { return QTime(-1, -1, -1); }
-};
-
-Q_DECLARE_METATYPE(Qt::DateFormat)
-
-void tst_QTime::addSecs_data()
-{
- QTest::addColumn<QTime>("t1");
- QTest::addColumn<int>("i");
- QTest::addColumn<QTime>("exp");
-
- QTest::newRow("Data0") << QTime(0,0,0) << 200 << QTime(0,3,20);
- QTest::newRow("Data1") << QTime(0,0,0) << 20 << QTime(0,0,20);
- QTest::newRow("overflow") << QTime(0,0,0) << (INT_MAX / 1000 + 1)
- << QTime(0,0,0).addSecs((INT_MAX / 1000 + 1) % 86400);
-}
-
-void tst_QTime::addSecs()
-{
- QFETCH( QTime, t1 );
- QFETCH( int, i );
- QTime t2;
- t2 = t1.addSecs( i );
- QFETCH( QTime, exp );
- QCOMPARE( t2, exp );
-}
-
-void tst_QTime::addMSecs_data()
-{
- QTest::addColumn<QTime>("t1");
- QTest::addColumn<int>("i");
- QTest::addColumn<QTime>("exp");
-
- // start with testing positive values
- QTest::newRow( "Data1_0") << QTime(0,0,0,0) << 2000 << QTime(0,0,2,0);
- QTest::newRow( "Data1_1") << QTime(0,0,0,0) << 200 << QTime(0,0,0,200);
- QTest::newRow( "Data1_2") << QTime(0,0,0,0) << 20 << QTime(0,0,0,20);
- QTest::newRow( "Data1_3") << QTime(0,0,0,1) << 1 << QTime(0,0,0,2);
- QTest::newRow( "Data1_4") << QTime(0,0,0,0) << 0 << QTime(0,0,0,0);
-
- QTest::newRow( "Data2_0") << QTime(0,0,0,98) << 0 << QTime(0,0,0,98);
- QTest::newRow( "Data2_1") << QTime(0,0,0,98) << 1 << QTime(0,0,0,99);
- QTest::newRow( "Data2_2") << QTime(0,0,0,98) << 2 << QTime(0,0,0,100);
- QTest::newRow( "Data2_3") << QTime(0,0,0,98) << 3 << QTime(0,0,0,101);
-
- QTest::newRow( "Data3_0") << QTime(0,0,0,998) << 0 << QTime(0,0,0,998);
- QTest::newRow( "Data3_1") << QTime(0,0,0,998) << 1 << QTime(0,0,0,999);
- QTest::newRow( "Data3_2") << QTime(0,0,0,998) << 2 << QTime(0,0,1,0);
- QTest::newRow( "Data3_3") << QTime(0,0,0,998) << 3 << QTime(0,0,1,1);
-
- QTest::newRow( "Data4_0") << QTime(0,0,1,995) << 4 << QTime(0,0,1,999);
- QTest::newRow( "Data4_1") << QTime(0,0,1,995) << 5 << QTime(0,0,2,0);
- QTest::newRow( "Data4_2") << QTime(0,0,1,995) << 6 << QTime(0,0,2,1);
- QTest::newRow( "Data4_3") << QTime(0,0,1,995) << 100 << QTime(0,0,2,95);
- QTest::newRow( "Data4_4") << QTime(0,0,1,995) << 105 << QTime(0,0,2,100);
-
- QTest::newRow( "Data5_0") << QTime(0,0,59,995) << 4 << QTime(0,0,59,999);
- QTest::newRow( "Data5_1") << QTime(0,0,59,995) << 5 << QTime(0,1,0,0);
- QTest::newRow( "Data5_2") << QTime(0,0,59,995) << 6 << QTime(0,1,0,1);
- QTest::newRow( "Data5_3") << QTime(0,0,59,995) << 1006 << QTime(0,1,1,1);
-
- QTest::newRow( "Data6_0") << QTime(0,59,59,995) << 4 << QTime(0,59,59,999);
- QTest::newRow( "Data6_1") << QTime(0,59,59,995) << 5 << QTime(1,0,0,0);
- QTest::newRow( "Data6_2") << QTime(0,59,59,995) << 6 << QTime(1,0,0,1);
- QTest::newRow( "Data6_3") << QTime(0,59,59,995) << 106 << QTime(1,0,0,101);
- QTest::newRow( "Data6_4") << QTime(0,59,59,995) << 1004 << QTime(1,0,0,999);
- QTest::newRow( "Data6_5") << QTime(0,59,59,995) << 1005 << QTime(1,0,1,0);
- QTest::newRow( "Data6_6") << QTime(0,59,59,995) << 61006 << QTime(1,1,1,1);
-
- QTest::newRow( "Data7_0") << QTime(23,59,59,995) << 0 << QTime(23,59,59,995);
- QTest::newRow( "Data7_1") << QTime(23,59,59,995) << 4 << QTime(23,59,59,999);
- QTest::newRow( "Data7_2") << QTime(23,59,59,995) << 5 << QTime(0,0,0,0);
- QTest::newRow( "Data7_3") << QTime(23,59,59,995) << 6 << QTime(0,0,0,1);
- QTest::newRow( "Data7_4") << QTime(23,59,59,995) << 7 << QTime(0,0,0,2);
-
- // must test negative values too...
- QTest::newRow( "Data11_0") << QTime(0,0,2,0) << -2000 << QTime(0,0,0,0);
- QTest::newRow( "Data11_1") << QTime(0,0,0,200) << -200 << QTime(0,0,0,0);
- QTest::newRow( "Data11_2") << QTime(0,0,0,20) << -20 << QTime(0,0,0,0);
- QTest::newRow( "Data11_3") << QTime(0,0,0,2) << -1 << QTime(0,0,0,1);
- QTest::newRow( "Data11_4") << QTime(0,0,0,0) << -0 << QTime(0,0,0,0);
-
- QTest::newRow( "Data12_0") << QTime(0,0,0,98) << -0 << QTime(0,0,0,98);
- QTest::newRow( "Data12_1") << QTime(0,0,0,99) << -1 << QTime(0,0,0,98);
- QTest::newRow( "Data12_2") << QTime(0,0,0,100) << -2 << QTime(0,0,0,98);
- QTest::newRow( "Data12_3") << QTime(0,0,0,101) << -3 << QTime(0,0,0,98);
-
- QTest::newRow( "Data13_0") << QTime(0,0,0,998) << -0 << QTime(0,0,0,998);
- QTest::newRow( "Data13_1") << QTime(0,0,0,999) << -1 << QTime(0,0,0,998);
- QTest::newRow( "Data13_2") << QTime(0,0,1,0) << -2 << QTime(0,0,0,998);
- QTest::newRow( "Data13_3") << QTime(0,0,1,1) << -3 << QTime(0,0,0,998);
-
- QTest::newRow( "Data14_0") << QTime(0,0,1,999) << -4 << QTime(0,0,1,995);
- QTest::newRow( "Data14_1") << QTime(0,0,2,0) << -5 << QTime(0,0,1,995);
- QTest::newRow( "Data14_2") << QTime(0,0,2,1) << -6 << QTime(0,0,1,995);
- QTest::newRow( "Data14_3") << QTime(0,0,2,95) << -100 << QTime(0,0,1,995);
- QTest::newRow( "Data14_4") << QTime(0,0,2,100) << -105 << QTime(0,0,1,995);
-
- QTest::newRow( "Data15_0") << QTime(0,0,59,999) << -4 << QTime(0,0,59,995);
- QTest::newRow( "Data15_1") << QTime(0,1,0,0) << -5 << QTime(0,0,59,995);
- QTest::newRow( "Data15_2") << QTime(0,1,0,1) << -6 << QTime(0,0,59,995);
- QTest::newRow( "Data15_3") << QTime(0,1,1,1) << -1006 << QTime(0,0,59,995);
-
- QTest::newRow( "Data16_0") << QTime(0,59,59,999) << -4 << QTime(0,59,59,995);
- QTest::newRow( "Data16_1") << QTime(1,0,0,0) << -5 << QTime(0,59,59,995);
- QTest::newRow( "Data16_2") << QTime(1,0,0,1) << -6 << QTime(0,59,59,995);
- QTest::newRow( "Data16_3") << QTime(1,0,0,101) << -106 << QTime(0,59,59,995);
- QTest::newRow( "Data16_4") << QTime(1,0,0,999) << -1004 << QTime(0,59,59,995);
- QTest::newRow( "Data16_5") << QTime(1,0,1,0) << -1005 << QTime(0,59,59,995);
- QTest::newRow( "Data16_6") << QTime(1,1,1,1) << -61006 << QTime(0,59,59,995);
-
- QTest::newRow( "Data17_0") << QTime(23,59,59,995) << -0 << QTime(23,59,59,995);
- QTest::newRow( "Data17_1") << QTime(23,59,59,999) << -4 << QTime(23,59,59,995);
- QTest::newRow( "Data17_2") << QTime(0,0,0,0) << -5 << QTime(23,59,59,995);
- QTest::newRow( "Data17_3") << QTime(0,0,0,1) << -6 << QTime(23,59,59,995);
- QTest::newRow( "Data17_4") << QTime(0,0,0,2) << -7 << QTime(23,59,59,995);
-
- QTest::newRow( "Data18_0" ) << invalidTime() << 1 << invalidTime();
-}
-
-void tst_QTime::addMSecs()
-{
- QFETCH( QTime, t1 );
- QFETCH( int, i );
- QTime t2;
- t2 = t1.addMSecs( i );
- QFETCH( QTime, exp );
- QCOMPARE( t2, exp );
-}
-
-void tst_QTime::isNull()
-{
- QTime t1;
- QVERIFY( t1.isNull() );
- QTime t2(0,0,0);
- QVERIFY( !t2.isNull() );
- QTime t3(0,0,1);
- QVERIFY( !t3.isNull() );
- QTime t4(0,0,0,1);
- QVERIFY( !t4.isNull() );
- QTime t5(23,59,59);
- QVERIFY( !t5.isNull() );
-}
-
-void tst_QTime::isValid()
-{
- QTime t1;
- QVERIFY( !t1.isValid() );
- QTime t2(24,0,0,0);
- QVERIFY( !t2.isValid() );
- QTime t3(23,60,0,0);
- QVERIFY( !t3.isValid() );
- QTime t4(23,0,-1,0);
- QVERIFY( !t4.isValid() );
- QTime t5(23,0,60,0);
- QVERIFY( !t5.isValid() );
- QTime t6(23,0,0,1000);
- QVERIFY( !t6.isValid() );
-}
-
-void tst_QTime::hour_data()
-{
- QTest::addColumn<int>("hour");
- QTest::addColumn<int>("minute");
- QTest::addColumn<int>("sec");
- QTest::addColumn<int>("msec");
-
- QTest::newRow( "data0" ) << 0 << 0 << 0 << 0;
- QTest::newRow( "data1" ) << 0 << 0 << 0 << 1;
- QTest::newRow( "data2" ) << 1 << 2 << 3 << 4;
- QTest::newRow( "data3" ) << 2 << 12 << 13 << 65;
- QTest::newRow( "data4" ) << 23 << 59 << 59 << 999;
- QTest::newRow( "data5" ) << -1 << -1 << -1 << -1;
-}
-
-void tst_QTime::hour()
-{
- QFETCH( int, hour );
- QFETCH( int, minute );
- QFETCH( int, sec );
- QFETCH( int, msec );
-
- QTime t1( hour, minute, sec, msec );
- QCOMPARE( t1.hour(), hour );
- QCOMPARE( t1.minute(), minute );
- QCOMPARE( t1.second(), sec );
- QCOMPARE( t1.msec(), msec );
-}
-
-void tst_QTime::setHMS_data()
-{
- QTest::addColumn<int>("hour");
- QTest::addColumn<int>("minute");
- QTest::addColumn<int>("sec");
-
- QTest::newRow( "data0" ) << 0 << 0 << 0;
- QTest::newRow( "data1" ) << 1 << 2 << 3;
- QTest::newRow( "data2" ) << 0 << 59 << 0;
- QTest::newRow( "data3" ) << 0 << 59 << 59;
- QTest::newRow( "data4" ) << 23 << 0 << 0;
- QTest::newRow( "data5" ) << 23 << 59 << 0;
- QTest::newRow( "data6" ) << 23 << 59 << 59;
- QTest::newRow( "data7" ) << -1 << -1 << -1;
-}
-
-void tst_QTime::setHMS()
-{
- QFETCH( int, hour );
- QFETCH( int, minute );
- QFETCH( int, sec );
-
- QTime t(3,4,5);
- t.setHMS( hour, minute, sec );
- QCOMPARE( t.hour(), hour );
- QCOMPARE( t.minute(), minute );
- QCOMPARE( t.second(), sec );
-}
-
-void tst_QTime::secsTo_data()
-{
- QTest::addColumn<QTime>("t1");
- QTest::addColumn<QTime>("t2");
- QTest::addColumn<int>("delta");
-
- QTest::newRow( "data0" ) << QTime(0,0,0) << QTime(0,0,59) << 59;
- QTest::newRow( "data1" ) << QTime(0,0,0) << QTime(0,1,0) << 60;
- QTest::newRow( "data2" ) << QTime(0,0,0) << QTime(0,10,0) << 600;
- QTest::newRow( "data3" ) << QTime(0,0,0) << QTime(23,59,59) << 86399;
- QTest::newRow( "data4" ) << QTime(-1, -1, -1) << QTime(0, 0, 0) << 0;
- QTest::newRow( "data5" ) << QTime(0, 0, 0) << QTime(-1, -1, -1) << 0;
- QTest::newRow( "data6" ) << QTime(-1, -1, -1) << QTime(-1, -1, -1) << 0;
- QTest::newRow("disregard msec (1s)") << QTime(12, 30, 1, 500) << QTime(12, 30, 2, 400) << 1;
- QTest::newRow("disregard msec (0s)") << QTime(12, 30, 1, 500) << QTime(12, 30, 1, 900) << 0;
- QTest::newRow("disregard msec (-1s)") << QTime(12, 30, 2, 400) << QTime(12, 30, 1, 500) << -1;
- QTest::newRow("disregard msec (0s)") << QTime(12, 30, 1, 900) << QTime(12, 30, 1, 500) << 0;
-}
-
-void tst_QTime::secsTo()
-{
- QFETCH( QTime, t1 );
- QFETCH( QTime, t2 );
- QFETCH( int, delta );
-
- QCOMPARE( t1.secsTo( t2 ), delta );
-}
-
-void tst_QTime::msecsTo_data()
-{
- QTest::addColumn<QTime>("t1");
- QTest::addColumn<QTime>("t2");
- QTest::addColumn<int>("delta");
-
- QTest::newRow( "data0" ) << QTime(0,0,0,0) << QTime(0,0,0,0) << 0;
- QTest::newRow( "data1" ) << QTime(0,0,0,0) << QTime(0,0,1,0) << 1000;
- QTest::newRow( "data2" ) << QTime(0,0,0,0) << QTime(0,0,10,0) << 10000;
- QTest::newRow( "data3" ) << QTime(0,0,0,0) << QTime(23,59,59,0) << 86399000;
- QTest::newRow( "data4" ) << QTime(-1, -1, -1, -1) << QTime(0, 0, 0, 0) << 0;
- QTest::newRow( "data5" ) << QTime(0, 0, 0, 0) << QTime(-1, -1, -1, -1) << 0;
- QTest::newRow( "data6" ) << QTime(-1, -1, -1, -1) << QTime(-1, -1, -1, -1) << 0;
-}
-
-void tst_QTime::msecsTo()
-{
- QFETCH( QTime, t1 );
- QFETCH( QTime, t2 );
- QFETCH( int, delta );
-
- QCOMPARE( t1.msecsTo( t2 ), delta );
-}
-
-void tst_QTime::operator_eq_eq_data()
-{
- QTest::addColumn<QTime>("t1");
- QTest::addColumn<QTime>("t2");
- QTest::addColumn<bool>("expectEqual");
-
- QTime time1(0, 0, 0, 0);
- QTime time2 = time1.addMSecs(1);
- QTime time3 = time1.addMSecs(-1);
- QTime time4(23, 59, 59, 999);
-
- QTest::newRow("data0") << time1 << time2 << false;
- QTest::newRow("data1") << time2 << time3 << false;
- QTest::newRow("data2") << time4 << time1 << false;
- QTest::newRow("data3") << time1 << time1 << true;
- QTest::newRow("data4") << QTime(12,34,56,20) << QTime(12,34,56,20) << true;
- QTest::newRow("data5") << QTime(01,34,56,20) << QTime(13,34,56,20) << false;
-}
-
-void tst_QTime::operator_eq_eq()
-{
- QFETCH(QTime, t1);
- QFETCH(QTime, t2);
- QFETCH(bool, expectEqual);
-
- bool equal = t1 == t2;
- QCOMPARE(equal, expectEqual);
- bool notEqual = t1 != t2;
- QCOMPARE(notEqual, !expectEqual);
-
- if (equal)
- QVERIFY(qHash(t1) == qHash(t2));
-}
-
-void tst_QTime::operator_lt()
-{
- QTime t1(0,0,0,0);
- QTime t2(0,0,0,0);
- QVERIFY( !(t1 < t2) );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(12,34,56,30);
- QVERIFY( t1 < t2 );
-
- t1 = QTime(13,34,46,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 < t2 );
-
- t1 = QTime(13,24,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 < t2 );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 < t2 );
-
- t1 = QTime(14,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 < t2) );
-
- t1 = QTime(13,44,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 < t2) );
-
- t1 = QTime(13,34,56,20);
- t2 = QTime(13,34,46,20);
- QVERIFY( !(t1 < t2) );
-
- t1 = QTime(13,44,56,30);
- t2 = QTime(13,44,56,20);
- QVERIFY( !(t1 < t2) );
-}
-
-void tst_QTime::operator_gt()
-{
- QTime t1(0,0,0,0);
- QTime t2(0,0,0,0);
- QVERIFY( !(t1 > t2) );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(12,34,56,30);
- QVERIFY( !(t1 > t2) );
-
- t1 = QTime(13,34,46,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 > t2) );
-
- t1 = QTime(13,24,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 > t2) );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 > t2) );
-
- t1 = QTime(14,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 > t2 );
-
- t1 = QTime(13,44,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 > t2 );
-
- t1 = QTime(13,34,56,20);
- t2 = QTime(13,34,46,20);
- QVERIFY( t1 > t2 );
-
- t1 = QTime(13,44,56,30);
- t2 = QTime(13,44,56,20);
- QVERIFY( t1 > t2 );
-}
-
-void tst_QTime::operator_lt_eq()
-{
- QTime t1(0,0,0,0);
- QTime t2(0,0,0,0);
- QVERIFY( t1 <= t2 );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(12,34,56,30);
- QVERIFY( t1 <= t2 );
-
- t1 = QTime(13,34,46,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 <= t2 );
-
- t1 = QTime(13,24,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 <= t2 );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 <= t2 );
-
- t1 = QTime(14,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 <= t2) );
-
- t1 = QTime(13,44,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 <= t2) );
-
- t1 = QTime(13,34,56,20);
- t2 = QTime(13,34,46,20);
- QVERIFY( !(t1 <= t2) );
-
- t1 = QTime(13,44,56,30);
- t2 = QTime(13,44,56,20);
- QVERIFY( !(t1 <= t2) );
-}
-
-void tst_QTime::operator_gt_eq()
-{
- QTime t1(0,0,0,0);
- QTime t2(0,0,0,0);
- QVERIFY( t1 >= t2 );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(12,34,56,30);
- QVERIFY( !(t1 >= t2) );
-
- t1 = QTime(13,34,46,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 >= t2) );
-
- t1 = QTime(13,24,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 >= t2) );
-
- t1 = QTime(12,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( !(t1 >= t2) );
-
- t1 = QTime(14,34,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 >= t2 );
-
- t1 = QTime(13,44,56,20);
- t2 = QTime(13,34,56,20);
- QVERIFY( t1 >= t2 );
-
- t1 = QTime(13,34,56,20);
- t2 = QTime(13,34,46,20);
- QVERIFY( t1 >= t2 );
-
- t1 = QTime(13,44,56,30);
- t2 = QTime(13,44,56,20);
- QVERIFY( t1 >= t2 );
-}
-
-void tst_QTime::fromStringFormat_data()
-{
- QTest::addColumn<QString>("string");
- QTest::addColumn<QString>("format");
- QTest::addColumn<QTime>("expected");
-
- QTest::newRow("data0") << QString("1010") << QString("mmm") << QTime(0, 10, 0);
- QTest::newRow("data1") << QString("00") << QString("hm") << invalidTime();
- QTest::newRow("data2") << QString("10am") << QString("hap") << QTime(10, 0, 0);
- QTest::newRow("data3") << QString("10pm") << QString("hap") << QTime(22, 0, 0);
- QTest::newRow("data4") << QString("10pmam") << QString("hapap") << invalidTime();
- QTest::newRow("data5") << QString("1070") << QString("hhm") << invalidTime();
- QTest::newRow("data6") << QString("1011") << QString("hh") << invalidTime();
- QTest::newRow("data7") << QString("25") << QString("hh") << invalidTime();
- QTest::newRow("data8") << QString("22pm") << QString("Hap") << QTime(22, 0, 0);
- QTest::newRow("data9") << QString("2221") << QString("hhhh") << invalidTime();
- QTest::newRow("data10") << QString("02:23PM") << QString("hh:mmAP") << QTime(14,23,0,0);
- QTest::newRow("data11") << QString("02:23pm") << QString("hh:mmap") << QTime(14,23,0,0);
- QTest::newRow("short-msecs-lt100") << QString("10:12:34:045") << QString("hh:m:ss:z") << QTime(10,12,34,45);
- QTest::newRow("short-msecs-gt100") << QString("10:12:34:45") << QString("hh:m:ss:z") << QTime(10,12,34,450);
- QTest::newRow("late") << QString("23:59:59.999") << QString("hh:mm:ss.z") << QTime(23, 59, 59, 999);
-}
-
-void tst_QTime::fromStringFormat()
-{
- QFETCH(QString, string);
- QFETCH(QString, format);
- QFETCH(QTime, expected);
-
- QTime dt = QTime::fromString(string, format);
- QCOMPARE(dt, expected);
-}
-
-void tst_QTime::fromStringDateFormat_data()
-{
- QTest::addColumn<QString>("string");
- QTest::addColumn<Qt::DateFormat>("format");
- QTest::addColumn<QTime>("expected");
-
- QTest::newRow("TextDate - data0") << QString("00:00:00") << Qt::TextDate << QTime(0,0,0,0);
- QTest::newRow("TextDate - data1") << QString("10:12:34") << Qt::TextDate << QTime(10,12,34,0);
- QTest::newRow("TextDate - data2") << QString("19:03:54.998601") << Qt::TextDate << QTime(19, 3, 54, 999);
- QTest::newRow("TextDate - data3") << QString("19:03:54.999601") << Qt::TextDate << QTime(19, 3, 54, 999);
- QTest::newRow("TextDate - data4") << QString("10:12") << Qt::TextDate << QTime(10, 12, 0, 0);
- QTest::newRow("TextDate - invalid, minutes") << QString::fromLatin1("23:XX:00") << Qt::TextDate << invalidTime();
- QTest::newRow("TextDate - invalid, minute fraction") << QString::fromLatin1("23:00.123456") << Qt::TextDate << invalidTime();
- QTest::newRow("TextDate - invalid, seconds") << QString::fromLatin1("23:00:XX") << Qt::TextDate << invalidTime();
- QTest::newRow("TextDate - invalid, milliseconds") << QString::fromLatin1("23:01:01:XXXX") << Qt::TextDate << QTime(23, 1, 1, 0);
- QTest::newRow("TextDate - midnight 24") << QString("24:00:00") << Qt::TextDate << QTime();
-
- QTest::newRow("IsoDate - valid, start of day, omit seconds") << QString::fromLatin1("00:00") << Qt::ISODate << QTime(0, 0, 0);
- QTest::newRow("IsoDate - valid, omit seconds") << QString::fromLatin1("22:21") << Qt::ISODate << QTime(22, 21, 0);
- QTest::newRow("IsoDate - valid, omit seconds (2)") << QString::fromLatin1("23:59") << Qt::ISODate << QTime(23, 59, 0);
- QTest::newRow("IsoDate - valid, end of day") << QString::fromLatin1("23:59:59") << Qt::ISODate << QTime(23, 59, 59);
-
- QTest::newRow("IsoDate - invalid, empty string") << QString::fromLatin1("") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, too many hours") << QString::fromLatin1("25:00") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, too many minutes") << QString::fromLatin1("10:70") << Qt::ISODate << invalidTime();
- // This is a valid time if it happens on June 30 or December 31 (leap seconds).
- QTest::newRow("IsoDate - invalid, too many seconds") << QString::fromLatin1("23:59:60") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, minutes") << QString::fromLatin1("23:XX:00") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, not enough minutes") << QString::fromLatin1("23:0") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, minute fraction") << QString::fromLatin1("23:00,XX") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, seconds") << QString::fromLatin1("23:00:XX") << Qt::ISODate << invalidTime();
- QTest::newRow("IsoDate - invalid, milliseconds") << QString::fromLatin1("23:01:01:XXXX") << Qt::ISODate << QTime(23, 1, 1, 0);
-
- QTest::newRow("IsoDate - data0") << QString("00:00:00") << Qt::ISODate << QTime(0,0,0,0);
- QTest::newRow("IsoDate - data1") << QString("10:12:34") << Qt::ISODate << QTime(10,12,34,0);
- QTest::newRow("IsoDate - data2") << QString("19:03:54.998601") << Qt::ISODate << QTime(19, 3, 54, 999);
- QTest::newRow("IsoDate - data3") << QString("19:03:54.999601") << Qt::ISODate << QTime(19, 3, 54, 999);
- QTest::newRow("IsoDate - midnight 24") << QString("24:00:00") << Qt::ISODate << QTime(0, 0, 0, 0);
- QTest::newRow("IsoDate - minute fraction midnight") << QString("24:00,0") << Qt::ISODate << QTime(0, 0, 0, 0);
-
- // Test Qt::RFC2822Date format (RFC 2822).
- QTest::newRow("RFC 2822") << QString::fromLatin1("13 Feb 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QTime(13, 24, 51);
- QTest::newRow("RFC 2822 with day") << QString::fromLatin1("Thu, 01 Jan 1970 00:12:34 +0000")
- << Qt::RFC2822Date << QTime(0, 12, 34);
- // No timezone
- QTest::newRow("RFC 2822 no timezone") << QString::fromLatin1("01 Jan 1970 00:12:34")
- << Qt::RFC2822Date << QTime(0, 12, 34);
- // No time specified
- QTest::newRow("RFC 2822 date only") << QString::fromLatin1("01 Nov 2002")
- << Qt::RFC2822Date << invalidTime();
- QTest::newRow("RFC 2822 with day date only") << QString::fromLatin1("Fri, 01 Nov 2002")
- << Qt::RFC2822Date << invalidTime();
- // Test invalid month, day, year
- QTest::newRow("RFC 2822 invalid month name") << QString::fromLatin1("13 Fev 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QTime(13, 24, 51);
- QTest::newRow("RFC 2822 invalid day") << QString::fromLatin1("36 Fev 1987 13:24:51 +0100")
- << Qt::RFC2822Date << QTime(13, 24, 51);
- QTest::newRow("RFC 2822 invalid year") << QString::fromLatin1("13 Fev 0000 13:24:51 +0100")
- << Qt::RFC2822Date << QTime(13, 24, 51);
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("RFC 2822 invalid character at end") << QString::fromLatin1("01 Jan 2012 08:00:00 +0100!")
- << Qt::RFC2822Date << QTime(8, 0, 0);
- QTest::newRow("RFC 2822 invalid character at front") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000")
- << Qt::RFC2822Date << invalidTime();
- QTest::newRow("RFC 2822 invalid character both ends") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000!")
- << Qt::RFC2822Date << invalidTime();
- QTest::newRow("RFC 2822 invalid character at front, 2 at back") << QString::fromLatin1("!01 Jan 2012 08:00:00 +0000..")
- << Qt::RFC2822Date << invalidTime();
- QTest::newRow("RFC 2822 invalid character 2 at front") << QString::fromLatin1("!!01 Jan 2012 08:00:00 +0000")
- << Qt::RFC2822Date << invalidTime();
-
- // Test Qt::RFC2822Date format (RFC 850 and 1036).
- QTest::newRow("RFC 850 and 1036") << QString::fromLatin1("Fri Feb 13 13:24:51 1987 +0100")
- << Qt::RFC2822Date << QTime(13, 24, 51);
- // No timezone
- QTest::newRow("RFC 850 and 1036 no timezone") << QString::fromLatin1("Thu Jan 01 00:12:34 1970")
- << Qt::RFC2822Date << QTime(0, 12, 34);
- // No time specified
- QTest::newRow("RFC 850 and 1036 date only") << QString::fromLatin1("Fri Nov 01 2002")
- << Qt::RFC2822Date << invalidTime();
- // Test invalid characters (should ignore invalid characters at end of string).
- QTest::newRow("RFC 850 and 1036 invalid character at end") << QString::fromLatin1("Sun Jan 01 08:00:00 2012 +0100!")
- << Qt::RFC2822Date << QTime(8, 0, 0);
- QTest::newRow("RFC 850 and 1036 invalid character at front") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000")
- << Qt::RFC2822Date << invalidTime();
- QTest::newRow("RFC 850 and 1036 invalid character both ends") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000!")
- << Qt::RFC2822Date << invalidTime();
- QTest::newRow("RFC 850 and 1036 invalid character at front, 2 at back") << QString::fromLatin1("!Sun Jan 01 08:00:00 2012 +0000..")
- << Qt::RFC2822Date << invalidTime();
-
- QTest::newRow("RFC empty") << QString::fromLatin1("") << Qt::RFC2822Date << invalidTime();
-}
-
-void tst_QTime::fromStringDateFormat()
-{
- QFETCH(QString, string);
- QFETCH(Qt::DateFormat, format);
- QFETCH(QTime, expected);
-
- QTime dt = QTime::fromString(string, format);
- QCOMPARE(dt, expected);
-}
-
-void tst_QTime::toStringDateFormat_data()
-{
- QTest::addColumn<QTime>("time");
- QTest::addColumn<Qt::DateFormat>("format");
- QTest::addColumn<QString>("expected");
-
- QTest::newRow("00:00:00.000") << QTime(0, 0, 0, 0) << Qt::TextDate << QString("00:00:00");
- QTest::newRow("ISO 00:00:00.000") << QTime(0, 0, 0, 0) << Qt::ISODate << QString("00:00:00");
- QTest::newRow("Text 10:12:34.000") << QTime(10, 12, 34, 0) << Qt::TextDate << QString("10:12:34");
- QTest::newRow("ISO 10:12:34.000") << QTime(10, 12, 34, 0) << Qt::ISODate << QString("10:12:34");
- QTest::newRow("Text 10:12:34.001") << QTime(10, 12, 34, 001) << Qt::TextDate << QString("10:12:34");
- QTest::newRow("ISO 10:12:34.001") << QTime(10, 12, 34, 001) << Qt::ISODate << QString("10:12:34");
- QTest::newRow("Text 10:12:34.999") << QTime(10, 12, 34, 999) << Qt::TextDate << QString("10:12:34");
- QTest::newRow("ISO 10:12:34.999") << QTime(10, 12, 34, 999) << Qt::ISODate << QString("10:12:34");
- QTest::newRow("RFC2822Date") << QTime(10, 12, 34, 999) << Qt::RFC2822Date << QString("10:12:34");
- QTest::newRow("ISOWithMs 10:12:34.000") << QTime(10, 12, 34, 0) << Qt::ISODateWithMs << QString("10:12:34.000");
- QTest::newRow("ISOWithMs 10:12:34.020") << QTime(10, 12, 34, 20) << Qt::ISODateWithMs << QString("10:12:34.020");
- QTest::newRow("ISOWithMs 10:12:34.999") << QTime(10, 12, 34, 999) << Qt::ISODateWithMs << QString("10:12:34.999");
-}
-
-void tst_QTime::toStringDateFormat()
-{
- QFETCH(QTime, time);
- QFETCH(Qt::DateFormat, format);
- QFETCH(QString, expected);
-
- QCOMPARE(time.toString(format), expected);
-}
-
-void tst_QTime::toStringFormat_data()
-{
- QTest::addColumn<QTime>("t");
- QTest::addColumn<QString>("format");
- QTest::addColumn<QString>("str");
-
- QTest::newRow( "midnight" ) << QTime(0,0,0,0) << QString("h:m:s:z") << QString("0:0:0:0");
- QTest::newRow( "full" ) << QTime(10,12,34,53) << QString("hh:mm:ss:zzz") << QString("10:12:34:053");
- QTest::newRow( "short-msecs-lt100" ) << QTime(10,12,34,45) << QString("hh:m:ss:z") << QString("10:12:34:045");
- QTest::newRow( "short-msecs-gt100" ) << QTime(10,12,34,450) << QString("hh:m:ss:z") << QString("10:12:34:45");
- QTest::newRow( "am-pm" ) << QTime(10,12,34,45) << QString("hh:ss ap") << QString("10:34 am");
- QTest::newRow( "AM-PM" ) << QTime(22,12,34,45) << QString("hh:zzz AP") << QString("10:045 PM");
- QTest::newRow( "invalid" ) << QTime(230,230,230,230) << QString("hh:mm:ss") << QString();
-}
-
-void tst_QTime::toStringFormat()
-{
- QFETCH( QTime, t );
- QFETCH( QString, format );
- QFETCH( QString, str );
-
- QCOMPARE( t.toString( format ), str );
-}
-
-void tst_QTime::toStringLocale()
-{
- QTime time(18, 30);
- QCOMPARE(time.toString(Qt::SystemLocaleShortDate),
- QLocale::system().toString(time, QLocale::ShortFormat));
- QCOMPARE(time.toString(Qt::DefaultLocaleShortDate),
- QLocale().toString(time, QLocale::ShortFormat));
- QCOMPARE(time.toString(Qt::SystemLocaleLongDate),
- QLocale::system().toString(time, QLocale::LongFormat));
- QCOMPARE(time.toString(Qt::DefaultLocaleLongDate),
- QLocale().toString(time, QLocale::LongFormat));
- QLocale::setDefault(QLocale::German);
- QCOMPARE(time.toString(Qt::SystemLocaleShortDate),
- QLocale::system().toString(time, QLocale::ShortFormat));
- QCOMPARE(time.toString(Qt::DefaultLocaleShortDate),
- QLocale().toString(time, QLocale::ShortFormat));
- QCOMPARE(time.toString(Qt::SystemLocaleLongDate),
- QLocale::system().toString(time, QLocale::LongFormat));
- QCOMPARE(time.toString(Qt::DefaultLocaleLongDate),
- QLocale().toString(time, QLocale::LongFormat));
-}
-
-void tst_QTime::msecsSinceStartOfDay_data()
-{
- QTest::addColumn<int>("msecs");
- QTest::addColumn<bool>("isValid");
- QTest::addColumn<int>("hour");
- QTest::addColumn<int>("minute");
- QTest::addColumn<int>("second");
- QTest::addColumn<int>("msec");
-
- QTest::newRow("00:00:00.000") << 0 << true
- << 0 << 0 << 0 << 0;
- QTest::newRow("01:00:00.001") << ((1 * 3600 * 1000) + 1) << true
- << 1 << 0 << 0 << 1;
- QTest::newRow("03:04:05.678") << ((3 * 3600 + 4 * 60 + 5) * 1000 + 678) << true
- << 3 << 4 << 5 << 678;
- QTest::newRow("23:59:59.999") << ((23 * 3600 + 59 * 60 + 59) * 1000 + 999) << true
- << 23 << 59 << 59 << 999;
- QTest::newRow("24:00:00.000") << ((24 * 3600) * 1000) << false
- << -1 << -1 << -1 << -1;
- QTest::newRow("-1 invalid") << -1 << false
- << -1 << -1 << -1 << -1;
-}
-
-void tst_QTime::msecsSinceStartOfDay()
-{
- QFETCH(int, msecs);
- QFETCH(bool, isValid);
- QFETCH(int, hour);
- QFETCH(int, minute);
- QFETCH(int, second);
- QFETCH(int, msec);
-
- QTime time = QTime::fromMSecsSinceStartOfDay(msecs);
- QCOMPARE(time.isValid(), isValid);
- if (msecs >= 0)
- QCOMPARE(time.msecsSinceStartOfDay(), msecs);
- else
- QCOMPARE(time.msecsSinceStartOfDay(), 0);
- QCOMPARE(time.hour(), hour);
- QCOMPARE(time.minute(), minute);
- QCOMPARE(time.second(), second);
- QCOMPARE(time.msec(), msec);
-}
-
-QTEST_APPLESS_MAIN(tst_QTime)
-#include "tst_qtime.moc"
diff --git a/tests/auto/corelib/tools/qtimezone/BLACKLIST b/tests/auto/corelib/tools/qtimezone/BLACKLIST
deleted file mode 100644
index 840c3b1181..0000000000
--- a/tests/auto/corelib/tools/qtimezone/BLACKLIST
+++ /dev/null
@@ -1,171 +0,0 @@
-# QTBUG-69122
-[dataStreamTest]
-android
-
-# QTBUG-69128
-[isTimeZoneIdAvailable]
-android
-
-# QTBUG-69129
-[specificTransition]
-android
-
-# QTBUG-69131
-[transitionEachZone:America/Cancun@2010]
-android
-[transitionEachZone:America/Eirunepe@2010]
-android
-[transitionEachZone:America/Montevideo@2010]
-android
-[transitionEachZone:America/Porto_Acre@2010]
-android
-[transitionEachZone:America/Rio_Branco@2010]
-android
-[transitionEachZone:Asia/Anadyr@2010]
-android
-[transitionEachZone:Asia/Chita@2010]
-android
-[transitionEachZone:Asia/Kamchatka@2010]
-android
-[transitionEachZone:Asia/Khandyga@2010]
-android
-[transitionEachZone:Asia/Magadan@2010]
-android
-[transitionEachZone:Asia/Novokuznetsk@2010]
-android
-[transitionEachZone:Asia/Pyongyang@2010]
-android
-[transitionEachZone:Asia/Ust-Nera@2010]
-android
-[transitionEachZone:Asia/Yerevan@2010]
-android
-[transitionEachZone:Europe/Kaliningrad@2010]
-android
-[transitionEachZone:Europe/Minsk@2010]
-android
-[transitionEachZone:Europe/Moscow@2010]
-android
-[transitionEachZone:Europe/Samara@2010]
-android
-[transitionEachZone:Europe/Simferopol@2010]
-android
-[transitionEachZone:Europe/Volgograd@2010]
-android
-[transitionEachZone:W-SU@2010]
-android
-[transitionEachZone:Africa/Bissau@1970]
-android
-[transitionEachZone:Africa/Juba@1970]
-android
-[transitionEachZone:Africa/Khartoum@1970]
-android
-[transitionEachZone:America/Metlakatla@1970]
-android
-[transitionEachZone:America/Montevideo@1970]
-android
-[transitionEachZone:America/Paramaribo@1970]
-android
-[transitionEachZone:America/Santarem@1970]
-android
-[transitionEachZone:America/Santo_Domingo@1970]
-android
-[transitionEachZone:Asia/Anadyr@1970]
-android
-[transitionEachZone:Asia/Bahrain@1970]
-android
-[transitionEachZone:Asia/Chita@1970]
-android
-[transitionEachZone:Asia/Dushanbe@1970]
-android
-[transitionEachZone:Asia/Ho_Chi_Minh@1970]
-android
-[transitionEachZone:Asia/Kathmandu@1970]
-android
-[transitionEachZone:Asia/Katmandu@1970]
-android
-[transitionEachZone:Asia/Kuala_Lumpur@1970]
-android
-[transitionEachZone:Asia/Magadan@1970]
-android
-[transitionEachZone:Asia/Novosibirsk@1970]
-android
-[transitionEachZone:Asia/Pontianak@1970]
-android
-[transitionEachZone:Asia/Pyongyang@1970]
-android
-[transitionEachZone:Asia/Qatar@1970]
-android
-[transitionEachZone:Asia/Qyzylorda@1970]
-android
-[transitionEachZone:Asia/Saigon@1970]
-android
-[transitionEachZone:Asia/Sakhalin@1970]
-android
-[transitionEachZone:Asia/Singapore@1970]
-android
-[transitionEachZone:Asia/Tashkent@1970]
-android
-[transitionEachZone:Asia/Thimbu@1970]
-android
-[transitionEachZone:Asia/Thimphu@1970]
-android
-[transitionEachZone:Asia/Ust-Nera@1970]
-android
-[transitionEachZone:Atlantic/Cape_Verde@1970]
-android
-[transitionEachZone:Chile/EasterIsland@1970]
-android
-[transitionEachZone:Europe/Kaliningrad@1970]
-android
-[transitionEachZone:Pacific/Bougainville@1970]
-android
-[transitionEachZone:Pacific/Easter@1970]
-android
-[transitionEachZone:Pacific/Enderbury@1970]
-android
-[transitionEachZone:Pacific/Galapagos@1970]
-android
-[transitionEachZone:Pacific/Kiritimati@1970]
-android
-[transitionEachZone:Pacific/Kosrae@1970]
-android
-[transitionEachZone:Pacific/Kwajalein@1970]
-android
-[transitionEachZone:Pacific/Nauru@1970]
-android
-[transitionEachZone:Pacific/Niue@1970]
-android
-[transitionEachZone:Singapore@1970]
-android
-[transitionEachZone:Brazil/Acre@2010]
-android
-[transitionEachZone:Pacific/Bougainville@2010]
-android
-[transitionEachZone:Africa/Algiers@1970]
-android
-[transitionEachZone:Africa/Monrovia@1970]
-android
-[transitionEachZone:Kwajalein@1970]
-android
-[transitionEachZone:Indian/Chagos@1970]
-android
-[transitionEachZone:Europe/Volgograd@1970]
-android
-[transitionEachZone:Atlantic/Stanley@1970]
-android
-[transitionEachZone:Antarctica/Mawson@1970]
-android
-[transitionEachZone:America/Swift_Current@1970]
-android
-[transitionEachZone:America/Guyana@1970]
-android
-[transitionEachZone:America/Grand_Turk@1970]
-android
-[transitionEachZone:America/Dawson_Creek@1970]
-android
-[transitionEachZone:America/Cancun@1970]
-android
-[transitionEachZone:America/Caracas@1970]
-android
-[transitionEachZone:America/Danmarkshavn@1970]
-android
diff --git a/tests/auto/corelib/tools/qtimezone/qtimezone.pro b/tests/auto/corelib/tools/qtimezone/qtimezone.pro
deleted file mode 100644
index 5ec8d008e7..0000000000
--- a/tests/auto/corelib/tools/qtimezone/qtimezone.pro
+++ /dev/null
@@ -1,12 +0,0 @@
-CONFIG += testcase
-TARGET = tst_qtimezone
-QT = core-private testlib
-SOURCES = tst_qtimezone.cpp
-qtConfig(icu) {
- QMAKE_USE_PRIVATE += icu
-}
-
-darwin {
- OBJECTIVE_SOURCES += tst_qtimezone_darwin.mm
- LIBS += -framework Foundation
-}
diff --git a/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp b/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp
deleted file mode 100644
index bb6c48a2ed..0000000000
--- a/tests/auto/corelib/tools/qtimezone/tst_qtimezone.cpp
+++ /dev/null
@@ -1,1333 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtTest/QtTest>
-#include <qtimezone.h>
-#include <private/qtimezoneprivate_p.h>
-#include <qlocale.h>
-
-#if defined(Q_OS_WIN) && !QT_CONFIG(icu)
-# define USING_WIN_TZ
-#endif
-
-class tst_QTimeZone : public QObject
-{
- Q_OBJECT
-
-public:
- tst_QTimeZone();
-
-private slots:
- // Public class default system tests
- void createTest();
- void nullTest();
- void dataStreamTest();
- void isTimeZoneIdAvailable();
- void availableTimeZoneIds();
- void specificTransition_data();
- void specificTransition();
- void transitionEachZone_data();
- void transitionEachZone();
- void checkOffset_data();
- void checkOffset();
- void stressTest();
- void windowsId();
- void isValidId_data();
- void isValidId();
- // Backend tests
- void utcTest();
- void icuTest();
- void tzTest();
- void macTest();
- void darwinTypes();
- void winTest();
-
-private:
- void printTimeZone(const QTimeZone &tz);
-#ifdef QT_BUILD_INTERNAL
- // Generic tests of privates, called by implementation-specific private tests:
- void testCetPrivate(const QTimeZonePrivate &tzp);
- void testEpochTranPrivate(const QTimeZonePrivate &tzp);
-#endif // QT_BUILD_INTERNAL
- const bool debug;
-};
-
-tst_QTimeZone::tst_QTimeZone()
- // Set to true to print debug output, test Display Names and run long stress tests
- : debug(false)
-{
-}
-
-void tst_QTimeZone::printTimeZone(const QTimeZone &tz)
-{
- QDateTime now = QDateTime::currentDateTime();
- QDateTime jan = QDateTime(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime jun = QDateTime(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC);
- qDebug() << "";
- qDebug() << "Time Zone = " << tz;
- qDebug() << "";
- qDebug() << "Is Valid = " << tz.isValid();
- qDebug() << "";
- qDebug() << "Zone ID = " << tz.id();
- qDebug() << "Country = " << QLocale::countryToString(tz.country());
- qDebug() << "Comment = " << tz.comment();
- qDebug() << "";
- qDebug() << "Locale = " << QLocale().name();
- qDebug() << "Name Long = " << tz.displayName(QTimeZone::StandardTime, QTimeZone::LongName);
- qDebug() << "Name Short = " << tz.displayName(QTimeZone::StandardTime, QTimeZone::ShortName);
- qDebug() << "Name Offset = " << tz.displayName(QTimeZone::StandardTime, QTimeZone::OffsetName);
- qDebug() << "Name Long DST = " << tz.displayName(QTimeZone::DaylightTime, QTimeZone::LongName);
- qDebug() << "Name Short DST = " << tz.displayName(QTimeZone::DaylightTime, QTimeZone::ShortName);
- qDebug() << "Name Offset DST = " << tz.displayName(QTimeZone::DaylightTime, QTimeZone::OffsetName);
- qDebug() << "Name Long Generic = " << tz.displayName(QTimeZone::GenericTime, QTimeZone::LongName);
- qDebug() << "Name Short Generic = " << tz.displayName(QTimeZone::GenericTime, QTimeZone::ShortName);
- qDebug() << "Name Offset Generic = " << tz.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName);
- qDebug() << "";
- QLocale locale = QLocale(QStringLiteral("de_DE"));
- qDebug() << "Locale = " << locale.name();
- qDebug() << "Name Long = " << tz.displayName(QTimeZone::StandardTime, QTimeZone::LongName, locale);
- qDebug() << "Name Short = " << tz.displayName(QTimeZone::StandardTime, QTimeZone::ShortName, locale);
- qDebug() << "Name Offset = " << tz.displayName(QTimeZone::StandardTime, QTimeZone::OffsetName, locale);
- qDebug() << "Name Long DST = " << tz.displayName(QTimeZone::DaylightTime, QTimeZone::LongName,locale);
- qDebug() << "Name Short DST = " << tz.displayName(QTimeZone::DaylightTime, QTimeZone::ShortName, locale);
- qDebug() << "Name Offset DST = " << tz.displayName(QTimeZone::DaylightTime, QTimeZone::OffsetName, locale);
- qDebug() << "Name Long Generic = " << tz.displayName(QTimeZone::GenericTime, QTimeZone::LongName, locale);
- qDebug() << "Name Short Generic = " << tz.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, locale);
- qDebug() << "Name Offset Generic = " << tz.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName, locale);
- qDebug() << "";
- qDebug() << "Abbreviation Now = " << tz.abbreviation(now);
- qDebug() << "Abbreviation on 1 Jan = " << tz.abbreviation(jan);
- qDebug() << "Abbreviation on 1 June = " << tz.abbreviation(jun);
- qDebug() << "";
- qDebug() << "Offset on 1 January = " << tz.offsetFromUtc(jan);
- qDebug() << "Offset on 1 June = " << tz.offsetFromUtc(jun);
- qDebug() << "Offset Now = " << tz.offsetFromUtc(now);
- qDebug() << "";
- qDebug() << "UTC Offset Now = " << tz.standardTimeOffset(now);
- qDebug() << "UTC Offset on 1 January = " << tz.standardTimeOffset(jan);
- qDebug() << "UTC Offset on 1 June = " << tz.standardTimeOffset(jun);
- qDebug() << "";
- qDebug() << "DST Offset on 1 January = " << tz.daylightTimeOffset(jan);
- qDebug() << "DST Offset on 1 June = " << tz.daylightTimeOffset(jun);
- qDebug() << "DST Offset Now = " << tz.daylightTimeOffset(now);
- qDebug() << "";
- qDebug() << "Has DST = " << tz.hasDaylightTime();
- qDebug() << "Is DST Now = " << tz.isDaylightTime(now);
- qDebug() << "Is DST on 1 January = " << tz.isDaylightTime(jan);
- qDebug() << "Is DST on 1 June = " << tz.isDaylightTime(jun);
- qDebug() << "";
- qDebug() << "Has Transitions = " << tz.hasTransitions();
- qDebug() << "Transition after 1 Jan = " << tz.nextTransition(jan).atUtc;
- qDebug() << "Transition after 1 Jun = " << tz.nextTransition(jun).atUtc;
- qDebug() << "Transition before 1 Jan = " << tz.previousTransition(jan).atUtc;
- qDebug() << "Transition before 1 Jun = " << tz.previousTransition(jun).atUtc;
- qDebug() << "";
-}
-
-void tst_QTimeZone::createTest()
-{
- QTimeZone tz("Pacific/Auckland");
-
- if (debug)
- printTimeZone(tz);
-
- // If the tz is not valid then skip as is probably using the UTC backend which is tested later
- if (!tz.isValid())
- return;
-
- // Validity tests
- QCOMPARE(tz.isValid(), true);
-
- // Comparison tests
- QTimeZone tz2("Pacific/Auckland");
- QTimeZone tz3("Australia/Sydney");
- QCOMPARE((tz == tz2), true);
- QCOMPARE((tz != tz2), false);
- QCOMPARE((tz == tz3), false);
- QCOMPARE((tz != tz3), true);
-
- QCOMPARE(tz.country(), QLocale::NewZealand);
-
- QDateTime jan = QDateTime(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime jun = QDateTime(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime janPrev = QDateTime(QDate(2011, 1, 1), QTime(0, 0, 0), Qt::UTC);
-
- QCOMPARE(tz.offsetFromUtc(jan), 13 * 3600);
- QCOMPARE(tz.offsetFromUtc(jun), 12 * 3600);
-
- QCOMPARE(tz.standardTimeOffset(jan), 12 * 3600);
- QCOMPARE(tz.standardTimeOffset(jun), 12 * 3600);
-
- QCOMPARE(tz.daylightTimeOffset(jan), 3600);
- QCOMPARE(tz.daylightTimeOffset(jun), 0);
-
- QCOMPARE(tz.hasDaylightTime(), true);
- QCOMPARE(tz.isDaylightTime(jan), true);
- QCOMPARE(tz.isDaylightTime(jun), false);
-
- // Only test transitions if host system supports them
- if (tz.hasTransitions()) {
- QTimeZone::OffsetData tran = tz.nextTransition(jan);
- // 2012-04-01 03:00 NZDT, +13 -> +12
- QCOMPARE(tran.atUtc,
- QDateTime(QDate(2012, 4, 1), QTime(3, 0), Qt::OffsetFromUTC, 13 * 3600));
- QCOMPARE(tran.offsetFromUtc, 12 * 3600);
- QCOMPARE(tran.standardTimeOffset, 12 * 3600);
- QCOMPARE(tran.daylightTimeOffset, 0);
-
- tran = tz.nextTransition(jun);
- // 2012-09-30 02:00 NZST, +12 -> +13
- QCOMPARE(tran.atUtc,
- QDateTime(QDate(2012, 9, 30), QTime(2, 0), Qt::OffsetFromUTC, 12 * 3600));
- QCOMPARE(tran.offsetFromUtc, 13 * 3600);
- QCOMPARE(tran.standardTimeOffset, 12 * 3600);
- QCOMPARE(tran.daylightTimeOffset, 3600);
-
- tran = tz.previousTransition(jan);
- // 2011-09-25 02:00 NZST, +12 -> +13
- QCOMPARE(tran.atUtc,
- QDateTime(QDate(2011, 9, 25), QTime(2, 0), Qt::OffsetFromUTC, 12 * 3600));
- QCOMPARE(tran.offsetFromUtc, 13 * 3600);
- QCOMPARE(tran.standardTimeOffset, 12 * 3600);
- QCOMPARE(tran.daylightTimeOffset, 3600);
-
- tran = tz.previousTransition(jun);
- // 2012-04-01 03:00 NZDT, +13 -> +12 (again)
- QCOMPARE(tran.atUtc,
- QDateTime(QDate(2012, 4, 1), QTime(3, 0), Qt::OffsetFromUTC, 13 * 3600));
- QCOMPARE(tran.offsetFromUtc, 12 * 3600);
- QCOMPARE(tran.standardTimeOffset, 12 * 3600);
- QCOMPARE(tran.daylightTimeOffset, 0);
-
- QTimeZone::OffsetDataList expected;
- tran.atUtc = QDateTime(QDate(2011, 4, 3), QTime(2, 0), Qt::OffsetFromUTC, 13 * 3600);
- tran.offsetFromUtc = 13 * 3600;
- tran.standardTimeOffset = 12 * 3600;
- tran.daylightTimeOffset = 3600;
- expected << tran;
- tran.atUtc = QDateTime(QDate(2011, 9, 25), QTime(2, 0), Qt::OffsetFromUTC, 12 * 3600);
- tran.offsetFromUtc = 12 * 3600;
- tran.standardTimeOffset = 12 * 3600;
- tran.daylightTimeOffset = 0;
- expected << tran;
- QTimeZone::OffsetDataList result = tz.transitions(janPrev, jan);
- QCOMPARE(result.count(), expected.count());
- for (int i = 0; i > expected.count(); ++i) {
- QCOMPARE(result.at(i).atUtc, expected.at(i).atUtc);
- QCOMPARE(result.at(i).offsetFromUtc, expected.at(i).offsetFromUtc);
- QCOMPARE(result.at(i).standardTimeOffset, expected.at(i).standardTimeOffset);
- QCOMPARE(result.at(i).daylightTimeOffset, expected.at(i).daylightTimeOffset);
- }
- }
-}
-
-void tst_QTimeZone::nullTest()
-{
- QTimeZone nullTz1;
- QTimeZone nullTz2;
- QTimeZone utc("UTC");
-
- // Validity tests
- QCOMPARE(nullTz1.isValid(), false);
- QCOMPARE(nullTz2.isValid(), false);
- QCOMPARE(utc.isValid(), true);
-
- // Comparison tests
- QCOMPARE((nullTz1 == nullTz2), true);
- QCOMPARE((nullTz1 != nullTz2), false);
- QCOMPARE((nullTz1 == utc), false);
- QCOMPARE((nullTz1 != utc), true);
-
- // Assignment tests
- nullTz2 = utc;
- QCOMPARE(nullTz2.isValid(), true);
- utc = nullTz1;
- QCOMPARE(utc.isValid(), false);
-
- QCOMPARE(nullTz1.id(), QByteArray());
- QCOMPARE(nullTz1.country(), QLocale::AnyCountry);
- QCOMPARE(nullTz1.comment(), QString());
-
- QDateTime jan = QDateTime(QDate(2012, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime jun = QDateTime(QDate(2012, 6, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime janPrev = QDateTime(QDate(2011, 1, 1), QTime(0, 0, 0), Qt::UTC);
-
- QCOMPARE(nullTz1.abbreviation(jan), QString());
- QCOMPARE(nullTz1.displayName(jan), QString());
- QCOMPARE(nullTz1.displayName(QTimeZone::StandardTime), QString());
-
- QCOMPARE(nullTz1.offsetFromUtc(jan), 0);
- QCOMPARE(nullTz1.offsetFromUtc(jun), 0);
-
- QCOMPARE(nullTz1.standardTimeOffset(jan), 0);
- QCOMPARE(nullTz1.standardTimeOffset(jun), 0);
-
- QCOMPARE(nullTz1.daylightTimeOffset(jan), 0);
- QCOMPARE(nullTz1.daylightTimeOffset(jun), 0);
-
- QCOMPARE(nullTz1.hasDaylightTime(), false);
- QCOMPARE(nullTz1.isDaylightTime(jan), false);
- QCOMPARE(nullTz1.isDaylightTime(jun), false);
-
- QTimeZone::OffsetData data = nullTz1.offsetData(jan);
- QCOMPARE(data.atUtc, QDateTime());
- QCOMPARE(data.offsetFromUtc, std::numeric_limits<int>::min());
- QCOMPARE(data.standardTimeOffset, std::numeric_limits<int>::min());
- QCOMPARE(data.daylightTimeOffset, std::numeric_limits<int>::min());
-
- QCOMPARE(nullTz1.hasTransitions(), false);
-
- data = nullTz1.nextTransition(jan);
- QCOMPARE(data.atUtc, QDateTime());
- QCOMPARE(data.offsetFromUtc, std::numeric_limits<int>::min());
- QCOMPARE(data.standardTimeOffset, std::numeric_limits<int>::min());
- QCOMPARE(data.daylightTimeOffset, std::numeric_limits<int>::min());
-
- data = nullTz1.previousTransition(jan);
- QCOMPARE(data.atUtc, QDateTime());
- QCOMPARE(data.offsetFromUtc, std::numeric_limits<int>::min());
- QCOMPARE(data.standardTimeOffset, std::numeric_limits<int>::min());
- QCOMPARE(data.daylightTimeOffset, std::numeric_limits<int>::min());
-}
-
-void tst_QTimeZone::dataStreamTest()
-{
- // Test the OffsetFromUtc backend serialization. First with a custom timezone:
- QTimeZone tz1("QST", 123456, "Qt Standard Time", "QST", QLocale::Norway, "Qt Testing");
- QByteArray tmp;
- {
- QDataStream ds(&tmp, QIODevice::WriteOnly);
- ds << tz1;
- }
- QTimeZone tz2("UTC");
- {
- QDataStream ds(&tmp, QIODevice::ReadOnly);
- ds >> tz2;
- }
- QCOMPARE(tz2.id(), QByteArray("QST"));
- QCOMPARE(tz2.comment(), QString("Qt Testing"));
- QCOMPARE(tz2.country(), QLocale::Norway);
- QCOMPARE(tz2.abbreviation(QDateTime::currentDateTime()), QString("QST"));
- QCOMPARE(tz2.displayName(QTimeZone::StandardTime, QTimeZone::LongName, QString()),
- QString("Qt Standard Time"));
- QCOMPARE(tz2.displayName(QTimeZone::DaylightTime, QTimeZone::LongName, QString()),
- QString("Qt Standard Time"));
- QCOMPARE(tz2.offsetFromUtc(QDateTime::currentDateTime()), 123456);
-
- // And then with a standard IANA timezone (QTBUG-60595):
- tz1 = QTimeZone("UTC");
- QCOMPARE(tz1.isValid(), true);
- {
- QDataStream ds(&tmp, QIODevice::WriteOnly);
- ds << tz1;
- }
- {
- QDataStream ds(&tmp, QIODevice::ReadOnly);
- ds >> tz2;
- }
- QCOMPARE(tz2.isValid(), true);
- QCOMPARE(tz2.id(), tz1.id());
-
- // Test the system backend serialization
- tz1 = QTimeZone("Pacific/Auckland");
-
- // If not valid then probably using the UTC system backend so skip
- if (!tz1.isValid())
- return;
-
- {
- QDataStream ds(&tmp, QIODevice::WriteOnly);
- ds << tz1;
- }
- tz2 = QTimeZone("UTC");
- {
- QDataStream ds(&tmp, QIODevice::ReadOnly);
- ds >> tz2;
- }
- QCOMPARE(tz2.id(), tz1.id());
-}
-
-void tst_QTimeZone::isTimeZoneIdAvailable()
-{
- QList<QByteArray> available = QTimeZone::availableTimeZoneIds();
- foreach (const QByteArray &id, available)
- QVERIFY(QTimeZone::isTimeZoneIdAvailable(id));
-
-#ifdef QT_BUILD_INTERNAL
- // a-z, A-Z, 0-9, '.', '-', '_' are valid chars
- // Can't start with '-'
- // Parts separated by '/', each part min 1 and max of 14 chars
- QCOMPARE(QTimeZonePrivate::isValidId("az"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("AZ"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("09"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("a/z"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("a.z"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("a-z"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("a_z"), true);
- QCOMPARE(QTimeZonePrivate::isValidId(".z"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("_z"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("12345678901234"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("12345678901234/12345678901234"), true);
- QCOMPARE(QTimeZonePrivate::isValidId("a z"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("a\\z"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("a,z"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("/z"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("-z"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("123456789012345"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("123456789012345/12345678901234"), false);
- QCOMPARE(QTimeZonePrivate::isValidId("12345678901234/123456789012345"), false);
-#endif // QT_BUILD_INTERNAL
-}
-
-void tst_QTimeZone::specificTransition_data()
-{
- QTest::addColumn<QByteArray>("zone");
- QTest::addColumn<QDate>("start");
- QTest::addColumn<QDate>("stop");
- QTest::addColumn<int>("count");
- QTest::addColumn<QDateTime>("atUtc");
- // In minutes:
- QTest::addColumn<int>("offset");
- QTest::addColumn<int>("stdoff");
- QTest::addColumn<int>("dstoff");
-
- // Moscow ditched DST on 2010-10-31 but has since changed standard offset twice.
-#ifdef USING_WIN_TZ
- // Win7 is too old to know about this transition:
- if (QOperatingSystemVersion::current() > QOperatingSystemVersion::Windows7)
-#endif
- {
- QTest::newRow("Moscow/2014") // From original bug-report
- << QByteArray("Europe/Moscow")
- << QDate(2011, 4, 1) << QDate(2017, 12,31) << 1
- << QDateTime(QDate(2014, 10, 26), QTime(2, 0, 0),
- Qt::OffsetFromUTC, 4 * 3600).toUTC()
- << 3 * 3600 << 3 * 3600 << 0;
- }
- QTest::newRow("Moscow/2011") // Transition on 2011-03-27
- << QByteArray("Europe/Moscow")
- << QDate(2010, 11, 1) << QDate(2014, 10, 25) << 1
- << QDateTime(QDate(2011, 3, 27), QTime(2, 0, 0),
- Qt::OffsetFromUTC, 3 * 3600).toUTC()
- << 4 * 3600 << 4 * 3600 << 0;
-}
-
-void tst_QTimeZone::specificTransition()
-{
- // Regression test for QTBUG-42021 (on MS-Win)
- QFETCH(QByteArray, zone);
- QFETCH(QDate, start);
- QFETCH(QDate, stop);
- QFETCH(int, count);
- // No attempt to check abbreviations; to much cross-platform variation.
- QFETCH(QDateTime, atUtc);
- QFETCH(int, offset);
- QFETCH(int, stdoff);
- QFETCH(int, dstoff);
-
- QTimeZone timeZone(zone);
- if (!timeZone.isValid())
- QSKIP("Missing time-zone data");
- QTimeZone::OffsetDataList transits =
- timeZone.transitions(QDateTime(start, QTime(0, 0), timeZone),
- QDateTime(stop, QTime(23, 59), timeZone));
- QCOMPARE(transits.length(), count);
- const QTimeZone::OffsetData &transition = transits.at(0);
- QCOMPARE(transition.offsetFromUtc, offset);
- QCOMPARE(transition.standardTimeOffset, stdoff);
- QCOMPARE(transition.daylightTimeOffset, dstoff);
- QCOMPARE(transition.atUtc, atUtc);
-}
-
-void tst_QTimeZone::transitionEachZone_data()
-{
- QTest::addColumn<QByteArray>("zone");
- QTest::addColumn<qint64>("secs");
- QTest::addColumn<int>("start");
- QTest::addColumn<int>("stop");
-
- struct {
- qint64 baseSecs;
- int start, stop;
- int year;
- } table[] = {
- { 25666200, 3, 12, 1970 }, // 1970-10-25 01:30 UTC; North America
- { 1288488600, -4, 8, 2010 } // 2010-10-31 01:30 UTC; Europe, Russia
- };
-
- QString name;
- const auto zones = QTimeZone::availableTimeZoneIds();
- for (int k = sizeof(table) / sizeof(table[0]); k-- > 0; ) {
- for (const QByteArray &zone : zones) {
- name.sprintf("%s@%d", zone.constData(), table[k].year);
- QTest::newRow(name.toUtf8().constData())
- << zone
- << table[k].baseSecs
- << table[k].start
- << table[k].stop;
- }
- }
-}
-
-void tst_QTimeZone::transitionEachZone()
-{
- // Regression test: round-trip fromMsecs/toMSecs should be idempotent; but
- // various zones failed during fall-back transitions.
- QFETCH(QByteArray, zone);
- QFETCH(qint64, secs);
- QFETCH(int, start);
- QFETCH(int, stop);
- QTimeZone named(zone);
-
- for (int i = start; i < stop; i++) {
-#ifdef USING_WIN_TZ
- // See QTBUG-64985: MS's TZ APIs' misdescription of Europe/Samara leads
- // to mis-disambiguation of its fall-back here.
- if (zone == "Europe/Samara" && i == -3) {
- continue;
- }
-#endif
-#ifdef Q_OS_ANDROID
- if (zone == "America/Mazatlan" || zone == "Mexico/BajaSur")
- QSKIP("Crashes on Android, see QTBUG-69132");
-#endif
- qint64 here = secs + i * 3600;
- QDateTime when = QDateTime::fromMSecsSinceEpoch(here * 1000, named);
- qint64 stamp = when.toMSecsSinceEpoch();
- if (here * 1000 != stamp) // (The +1 is due to using *1*:30 as baseSecs.)
- qDebug() << "Failing for" << zone << "at half past" << (i + 1) << "UTC";
- QCOMPARE(stamp % 1000, 0);
- QCOMPARE(here - stamp / 1000, 0);
- }
-}
-
-void tst_QTimeZone::checkOffset_data()
-{
- QTest::addColumn<QByteArray>("zoneName");
- QTest::addColumn<QDateTime>("when");
- QTest::addColumn<int>("netOffset");
- QTest::addColumn<int>("stdOffset");
- QTest::addColumn<int>("dstOffset");
-
- struct {
- const char *zone, *nick;
- int year, month, day, hour, min, sec;
- int std, dst;
- } table[] = {
- // Zone with no transitions (QTBUG-74614, QTBUG-74666, when TZ backend uses minimal data)
- { "Etc/UTC", "epoch", 1970, 1, 1, 0, 0, 0, 0, 0 },
- { "Etc/UTC", "pre_int32", 1901, 12, 13, 20, 45, 51, 0, 0 },
- { "Etc/UTC", "post_int32", 2038, 1, 19, 3, 14, 9, 0, 0 },
- { "Etc/UTC", "post_uint32", 2106, 2, 7, 6, 28, 17, 0, 0 },
- { "Etc/UTC", "initial", -292275056, 5, 16, 16, 47, 5, 0, 0 },
- { "Etc/UTC", "final", 292278994, 8, 17, 7, 12, 55, 0, 0 },
- // Kiev: regression test for QTBUG-64122 (on MS):
- { "Europe/Kiev", "summer", 2017, 10, 27, 12, 0, 0, 2 * 3600, 3600 },
- { "Europe/Kiev", "winter", 2017, 10, 29, 12, 0, 0, 2 * 3600, 0 }
- };
- for (const auto &entry : table) {
- QTimeZone zone(entry.zone);
- if (zone.isValid()) {
- QTest::addRow("%s@%s", entry.zone, entry.nick)
- << QByteArray(entry.zone)
- << QDateTime(QDate(entry.year, entry.month, entry.day),
- QTime(entry.hour, entry.min, entry.sec), zone)
- << entry.dst + entry.std << entry.std << entry.dst;
- } else {
- qWarning("Skipping %s@%s test as zone is invalid", entry.zone, entry.nick);
- }
- }
-}
-
-void tst_QTimeZone::checkOffset()
-{
- QFETCH(QByteArray, zoneName);
- QFETCH(QDateTime, when);
- QFETCH(int, netOffset);
- QFETCH(int, stdOffset);
- QFETCH(int, dstOffset);
-
- QTimeZone zone(zoneName);
- QVERIFY(zone.isValid()); // It was when _data() added the row !
- QCOMPARE(zone.offsetFromUtc(when), netOffset);
- QCOMPARE(zone.standardTimeOffset(when), stdOffset);
- QCOMPARE(zone.daylightTimeOffset(when), dstOffset);
- QCOMPARE(zone.isDaylightTime(when), dstOffset != 0);
-}
-
-void tst_QTimeZone::availableTimeZoneIds()
-{
- if (debug) {
- qDebug() << "";
- qDebug() << "Available Time Zones" ;
- qDebug() << QTimeZone::availableTimeZoneIds();
- qDebug() << "";
- qDebug() << "Available Time Zones in the US";
- qDebug() << QTimeZone::availableTimeZoneIds(QLocale::UnitedStates);
- qDebug() << "";
- qDebug() << "Available Time Zones with UTC Offset 0";
- qDebug() << QTimeZone::availableTimeZoneIds(0);
- qDebug() << "";
- } else {
- //Just test the calls work, we cannot know what any test machine has available
- QList<QByteArray> listAll = QTimeZone::availableTimeZoneIds();
- QList<QByteArray> listUs = QTimeZone::availableTimeZoneIds(QLocale::UnitedStates);
- QList<QByteArray> listZero = QTimeZone::availableTimeZoneIds(0);
- }
-}
-
-void tst_QTimeZone::stressTest()
-{
- QList<QByteArray> idList = QTimeZone::availableTimeZoneIds();
- foreach (const QByteArray &id, idList) {
- QTimeZone testZone = QTimeZone(id);
- QCOMPARE(testZone.isValid(), true);
- QCOMPARE(testZone.id(), id);
- QDateTime testDate = QDateTime(QDate(2015, 1, 1), QTime(0, 0, 0), Qt::UTC);
- testZone.country();
- testZone.comment();
- testZone.displayName(testDate);
- testZone.displayName(QTimeZone::DaylightTime);
- testZone.displayName(QTimeZone::StandardTime);
- testZone.abbreviation(testDate);
- testZone.offsetFromUtc(testDate);
- testZone.standardTimeOffset(testDate);
- testZone.daylightTimeOffset(testDate);
- testZone.hasDaylightTime();
- testZone.isDaylightTime(testDate);
- testZone.offsetData(testDate);
- testZone.hasTransitions();
- testZone.nextTransition(testDate);
- testZone.previousTransition(testDate);
- // Dates known to be outside possible tz file pre-calculated rules range
- QDateTime lowDate1 = QDateTime(QDate(1800, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime lowDate2 = QDateTime(QDate(1800, 6, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime highDate1 = QDateTime(QDate(2200, 1, 1), QTime(0, 0, 0), Qt::UTC);
- QDateTime highDate2 = QDateTime(QDate(2200, 6, 1), QTime(0, 0, 0), Qt::UTC);
- testZone.nextTransition(lowDate1);
- testZone.nextTransition(lowDate2);
- testZone.previousTransition(lowDate2);
- testZone.previousTransition(lowDate2);
- testZone.nextTransition(highDate1);
- testZone.nextTransition(highDate2);
- testZone.previousTransition(highDate1);
- testZone.previousTransition(highDate2);
- if (debug) {
- // This could take a long time, depending on platform and database
- qDebug() << "Stress test calculating transistions for" << testZone.id();
- testZone.transitions(lowDate1, highDate1);
- }
- testDate.setTimeZone(testZone);
- testDate.isValid();
- testDate.offsetFromUtc();
- testDate.timeZoneAbbreviation();
- }
-}
-
-void tst_QTimeZone::windowsId()
-{
-/*
- Current Windows zones for "Central Standard Time":
- Region IANA Id(s)
- Default "America/Chicago"
- Canada "America/Winnipeg America/Rainy_River America/Rankin_Inlet America/Resolute"
- Mexico "America/Matamoros"
- USA "America/Chicago America/Indiana/Knox America/Indiana/Tell_City America/Menominee"
- "America/North_Dakota/Beulah America/North_Dakota/Center"
- "America/North_Dakota/New_Salem"
- AnyCountry "CST6CDT"
-*/
- QCOMPARE(QTimeZone::ianaIdToWindowsId("America/Chicago"),
- QByteArray("Central Standard Time"));
- QCOMPARE(QTimeZone::ianaIdToWindowsId("America/Resolute"),
- QByteArray("Central Standard Time"));
-
- // Partials shouldn't match
- QCOMPARE(QTimeZone::ianaIdToWindowsId("America/Chi"), QByteArray());
- QCOMPARE(QTimeZone::ianaIdToWindowsId("InvalidZone"), QByteArray());
- QCOMPARE(QTimeZone::ianaIdToWindowsId(QByteArray()), QByteArray());
-
- // Check default value
- QCOMPARE(QTimeZone::windowsIdToDefaultIanaId("Central Standard Time"),
- QByteArray("America/Chicago"));
- QCOMPARE(QTimeZone::windowsIdToDefaultIanaId("Central Standard Time", QLocale::Canada),
- QByteArray("America/Winnipeg"));
- QCOMPARE(QTimeZone::windowsIdToDefaultIanaId("Central Standard Time", QLocale::AnyCountry),
- QByteArray("CST6CDT"));
- QCOMPARE(QTimeZone::windowsIdToDefaultIanaId(QByteArray()), QByteArray());
-
- // No country is sorted list of all zones
- QList<QByteArray> list;
- list << "America/Chicago" << "America/Indiana/Knox" << "America/Indiana/Tell_City"
- << "America/Matamoros" << "America/Menominee" << "America/North_Dakota/Beulah"
- << "America/North_Dakota/Center" << "America/North_Dakota/New_Salem"
- << "America/Rainy_River" << "America/Rankin_Inlet" << "America/Resolute"
- << "America/Winnipeg" << "CST6CDT";
- QCOMPARE(QTimeZone::windowsIdToIanaIds("Central Standard Time"), list);
-
- // Check country with no match returns empty list
- list.clear();
- QCOMPARE(QTimeZone::windowsIdToIanaIds("Central Standard Time", QLocale::NewZealand),
- list);
-
- // Check valid country returns list in preference order
- list.clear();
- list << "America/Winnipeg" << "America/Rainy_River" << "America/Rankin_Inlet"
- << "America/Resolute";
- QCOMPARE(QTimeZone::windowsIdToIanaIds("Central Standard Time", QLocale::Canada), list);
-
- list.clear();
- list << "America/Matamoros";
- QCOMPARE(QTimeZone::windowsIdToIanaIds("Central Standard Time", QLocale::Mexico), list);
-
- list.clear();
- list << "America/Chicago" << "America/Indiana/Knox" << "America/Indiana/Tell_City"
- << "America/Menominee" << "America/North_Dakota/Beulah" << "America/North_Dakota/Center"
- << "America/North_Dakota/New_Salem";
- QCOMPARE(QTimeZone::windowsIdToIanaIds("Central Standard Time", QLocale::UnitedStates),
- list);
-
- list.clear();
- list << "CST6CDT";
- QCOMPARE(QTimeZone::windowsIdToIanaIds("Central Standard Time", QLocale::AnyCountry),
- list);
-
- // Check no windowsId return empty
- list.clear();
- QCOMPARE(QTimeZone::windowsIdToIanaIds(QByteArray()), list);
- QCOMPARE(QTimeZone::windowsIdToIanaIds(QByteArray(), QLocale::AnyCountry), list);
-}
-
-void tst_QTimeZone::isValidId_data()
-{
-#ifdef QT_BUILD_INTERNAL
- QTest::addColumn<QByteArray>("input");
- QTest::addColumn<bool>("valid");
-
-#define TESTSET(name, section, valid) \
- QTest::newRow(name " front") << QByteArray(section "/xyz/xyz") << valid; \
- QTest::newRow(name " middle") << QByteArray("xyz/" section "/xyz") << valid; \
- QTest::newRow(name " back") << QByteArray("xyz/xyz/" section) << valid
-
- TESTSET("empty", "", false);
- TESTSET("minimal", "m", true);
- TESTSET("maximal", "12345678901234", true);
- TESTSET("too long", "123456789012345", false);
-
- TESTSET("bad hyphen", "-hyphen", false);
- TESTSET("good hyphen", "hy-phen", true);
-
- TESTSET("valid char _", "_", true);
- TESTSET("valid char .", ".", true);
- TESTSET("valid char :", ":", true);
- TESTSET("valid char +", "+", true);
- TESTSET("valid char A", "A", true);
- TESTSET("valid char Z", "Z", true);
- TESTSET("valid char a", "a", true);
- TESTSET("valid char z", "z", true);
- TESTSET("valid char 0", "0", true);
- TESTSET("valid char 9", "9", true);
-
- TESTSET("invalid char ^", "^", false);
- TESTSET("invalid char \"", "\"", false);
- TESTSET("invalid char $", "$", false);
- TESTSET("invalid char %", "%", false);
- TESTSET("invalid char &", "&", false);
- TESTSET("invalid char (", "(", false);
- TESTSET("invalid char )", ")", false);
- TESTSET("invalid char =", "=", false);
- TESTSET("invalid char ?", "?", false);
- TESTSET("invalid char ß", "ß", false);
- TESTSET("invalid char \\x01", "\x01", false);
- TESTSET("invalid char ' '", " ", false);
-
-#undef TESTSET
-#endif // QT_BUILD_INTERNAL
-}
-
-void tst_QTimeZone::isValidId()
-{
-#ifdef QT_BUILD_INTERNAL
- QFETCH(QByteArray, input);
- QFETCH(bool, valid);
-
- QCOMPARE(QTimeZonePrivate::isValidId(input), valid);
-#else
- QSKIP("This test requires a Qt -developer-build.");
-#endif
-}
-
-void tst_QTimeZone::utcTest()
-{
-#ifdef QT_BUILD_INTERNAL
- // Test default UTC constructor
- QUtcTimeZonePrivate tzp;
- QCOMPARE(tzp.isValid(), true);
- QCOMPARE(tzp.id(), QByteArray("UTC"));
- QCOMPARE(tzp.country(), QLocale::AnyCountry);
- QCOMPARE(tzp.abbreviation(0), QString("UTC"));
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::LongName, QString()), QString("UTC"));
- QCOMPARE(tzp.offsetFromUtc(0), 0);
- QCOMPARE(tzp.standardTimeOffset(0), 0);
- QCOMPARE(tzp.daylightTimeOffset(0), 0);
- QCOMPARE(tzp.hasDaylightTime(), false);
- QCOMPARE(tzp.hasTransitions(), false);
-
- // Test create from UTC Offset
- QDateTime now = QDateTime::currentDateTime();
- QTimeZone tz(36000);
- QCOMPARE(tz.isValid(), true);
- QCOMPARE(tz.id(), QByteArray("UTC+10:00"));
- QCOMPARE(tz.offsetFromUtc(now), 36000);
- QCOMPARE(tz.standardTimeOffset(now), 36000);
- QCOMPARE(tz.daylightTimeOffset(now), 0);
-
- // Test invalid UTC offset, must be in range -14 to +14 hours
- int min = -14*60*60;
- int max = 14*60*60;
- QCOMPARE(QTimeZone(min - 1).isValid(), false);
- QCOMPARE(QTimeZone(min).isValid(), true);
- QCOMPARE(QTimeZone(min + 1).isValid(), true);
- QCOMPARE(QTimeZone(max - 1).isValid(), true);
- QCOMPARE(QTimeZone(max).isValid(), true);
- QCOMPARE(QTimeZone(max + 1).isValid(), false);
-
- // Test create from standard name
- tz = QTimeZone("UTC+10:00");
- QCOMPARE(tz.isValid(), true);
- QCOMPARE(tz.id(), QByteArray("UTC+10:00"));
- QCOMPARE(tz.offsetFromUtc(now), 36000);
- QCOMPARE(tz.standardTimeOffset(now), 36000);
- QCOMPARE(tz.daylightTimeOffset(now), 0);
-
- // Test invalid UTC ID, must be in available list
- tz = QTimeZone("UTC+00:01");
- QCOMPARE(tz.isValid(), false);
-
- // Test create custom zone
- tz = QTimeZone("QST", 123456, "Qt Standard Time", "QST", QLocale::Norway, "Qt Testing");
- QCOMPARE(tz.isValid(), true);
- QCOMPARE(tz.id(), QByteArray("QST"));
- QCOMPARE(tz.comment(), QString("Qt Testing"));
- QCOMPARE(tz.country(), QLocale::Norway);
- QCOMPARE(tz.abbreviation(now), QString("QST"));
- QCOMPARE(tz.displayName(QTimeZone::StandardTime, QTimeZone::LongName, QString()),
- QString("Qt Standard Time"));
- QCOMPARE(tz.offsetFromUtc(now), 123456);
- QCOMPARE(tz.standardTimeOffset(now), 123456);
- QCOMPARE(tz.daylightTimeOffset(now), 0);
-#endif // QT_BUILD_INTERNAL
-}
-
-void tst_QTimeZone::icuTest()
-{
-#if defined(QT_BUILD_INTERNAL) && QT_CONFIG(icu)
- // 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
- QIcuTimeZonePrivate tzpd;
- QVERIFY(tzpd.isValid());
-
- // Test invalid constructor
- QIcuTimeZonePrivate tzpi("Gondwana/Erewhon");
- QCOMPARE(tzpi.isValid(), false);
-
- // Test named constructor
- QIcuTimeZonePrivate tzp("Europe/Berlin");
- QVERIFY(tzp.isValid());
-
- // Only test names in debug mode, names used can vary by ICU version installed
- 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 Standard Time"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, enUS),
- QString("GMT+01:00"));
- 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);
- testEpochTranPrivate(QIcuTimeZonePrivate("America/Toronto"));
-#endif // icu
-}
-
-void tst_QTimeZone::tzTest()
-{
-#if defined QT_BUILD_INTERNAL && defined Q_OS_UNIX && !defined Q_OS_DARWIN && !defined Q_OS_ANDROID
- // 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
- QTzTimeZonePrivate tzpd;
- QVERIFY(tzpd.isValid());
-
- // Test invalid constructor
- QTzTimeZonePrivate tzpi("Gondwana/Erewhon");
- QCOMPARE(tzpi.isValid(), false);
-
- // Test named constructor
- QTzTimeZonePrivate tzp("Europe/Berlin");
- QVERIFY(tzp.isValid());
-
- // Test display names by type, either ICU or abbreviation only
- QLocale enUS("en_US");
- // Only test names in debug mode, names used can vary by ICU version installed
- if (debug) {
-#if QT_CONFIG(icu)
- 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 Standard Time"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, enUS),
- QString("GMT+01:00"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName, enUS),
- QString("UTC+01:00"));
-#else
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::LongName, enUS),
- QString("CET"));
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::ShortName, enUS),
- QString("CET"));
- QCOMPARE(tzp.displayName(QTimeZone::StandardTime, QTimeZone::OffsetName, enUS),
- QString("CET"));
- QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::LongName, enUS),
- QString("CEST"));
- QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::ShortName, enUS),
- QString("CEST"));
- QCOMPARE(tzp.displayName(QTimeZone::DaylightTime, QTimeZone::OffsetName, enUS),
- QString("CEST"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::LongName, enUS),
- QString("CET"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::ShortName, enUS),
- QString("CET"));
- QCOMPARE(tzp.displayName(QTimeZone::GenericTime, QTimeZone::OffsetName, enUS),
- QString("CET"));
-#endif // icu
-
- // Test Abbreviations
- QCOMPARE(tzp.abbreviation(std), QString("CET"));
- QCOMPARE(tzp.abbreviation(dst), QString("CEST"));
- }
-
- testCetPrivate(tzp);
- testEpochTranPrivate(QTzTimeZonePrivate("America/Toronto"));
-
- // Test first and last transition rule
- // Warning: This could vary depending on age of TZ file!
-
- // Test low date uses first rule found
- // Note: Depending on the OS in question, the database may be carrying the
- // Local Mean Time. which for Berlin is 0:53:28
- QTimeZonePrivate::Data dat = tzp.data(-9999999999999);
- QCOMPARE(dat.atMSecsSinceEpoch, (qint64)-9999999999999);
- QCOMPARE(dat.daylightTimeOffset, 0);
- if (dat.abbreviation == "LMT") {
- QCOMPARE(dat.standardTimeOffset, 3208);
- } else {
- QCOMPARE(dat.standardTimeOffset, 3600);
-
- // Test previous to low value is invalid
- dat = tzp.previousTransition(-9999999999999);
- QCOMPARE(dat.atMSecsSinceEpoch, std::numeric_limits<qint64>::min());
- QCOMPARE(dat.standardTimeOffset, std::numeric_limits<int>::min());
- QCOMPARE(dat.daylightTimeOffset, std::numeric_limits<int>::min());
- }
-
- dat = tzp.nextTransition(-9999999999999);
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(dat.atMSecsSinceEpoch, Qt::OffsetFromUTC, 3600),
- QDateTime(QDate(1893, 4, 1), QTime(0, 6, 32), Qt::OffsetFromUTC, 3600));
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 0);
-
- // Known high datetimes
- qint64 stdHi = QDateTime(QDate(2100, 1, 1), QTime(0, 0, 0), Qt::UTC).toMSecsSinceEpoch();
- qint64 dstHi = QDateTime(QDate(2100, 6, 1), QTime(0, 0, 0), Qt::UTC).toMSecsSinceEpoch();
-
- // Tets high dates use the POSIX rule
- dat = tzp.data(stdHi);
- QCOMPARE(dat.atMSecsSinceEpoch - stdHi, (qint64)0);
- QCOMPARE(dat.offsetFromUtc, 3600);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 0);
-
- dat = tzp.data(dstHi);
- QCOMPARE(dat.atMSecsSinceEpoch - dstHi, (qint64)0);
- QCOMPARE(dat.offsetFromUtc, 7200);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 3600);
-
- dat = tzp.previousTransition(stdHi);
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(dat.atMSecsSinceEpoch, Qt::OffsetFromUTC, 3600),
- QDateTime(QDate(2099, 10, 26), QTime(2, 0), Qt::OffsetFromUTC, 3600));
- QCOMPARE(dat.offsetFromUtc, 3600);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 0);
-
- dat = tzp.previousTransition(dstHi);
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(dat.atMSecsSinceEpoch, Qt::OffsetFromUTC, 3600),
- QDateTime(QDate(2100, 3, 29), QTime(2, 0), Qt::OffsetFromUTC, 3600));
- QCOMPARE(dat.offsetFromUtc, 7200);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 3600);
-
- dat = tzp.nextTransition(stdHi);
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(dat.atMSecsSinceEpoch, Qt::OffsetFromUTC, 3600),
- QDateTime(QDate(2100, 3, 29), QTime(2, 0), Qt::OffsetFromUTC, 3600));
- QCOMPARE(dat.offsetFromUtc, 7200);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 3600);
-
- dat = tzp.nextTransition(dstHi);
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(dat.atMSecsSinceEpoch, Qt::OffsetFromUTC, 3600),
- QDateTime(QDate(2100, 10, 25), QTime(2, 0), Qt::OffsetFromUTC, 3600));
- QCOMPARE(dat.offsetFromUtc, 3600);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 0);
-
- // Test TZ timezone vs UTC timezone for fractionary negative offset
- QTzTimeZonePrivate tztz1("America/Caracas");
- QUtcTimeZonePrivate tzutc1("UTC-04:30");
- QVERIFY(tztz1.isValid());
- QVERIFY(tzutc1.isValid());
- QTzTimeZonePrivate::Data datatz1 = tztz1.data(std);
- QTzTimeZonePrivate::Data datautc1 = tzutc1.data(std);
- QCOMPARE(datatz1.offsetFromUtc, datautc1.offsetFromUtc);
-
- // Test TZ timezone vs UTC timezone for fractionary positive offset
- QTzTimeZonePrivate tztz2("Asia/Calcutta");
- QUtcTimeZonePrivate tzutc2("UTC+05:30");
- QVERIFY(tztz2.isValid());
- QVERIFY(tzutc2.isValid());
- QTzTimeZonePrivate::Data datatz2 = tztz2.data(std);
- QTzTimeZonePrivate::Data datautc2 = tzutc2.data(std);
- QCOMPARE(datatz2.offsetFromUtc, datautc2.offsetFromUtc);
-
- // Test a timezone with a name that isn't all letters
- QTzTimeZonePrivate tzBarnaul("Asia/Barnaul");
- if (tzBarnaul.isValid()) {
- QCOMPARE(tzBarnaul.data(std).abbreviation, QString("+07"));
-
- // first full day of the new rule (tzdata2016b)
- QDateTime dt(QDate(2016, 3, 28), QTime(0, 0, 0), Qt::UTC);
- QCOMPARE(tzBarnaul.data(dt.toMSecsSinceEpoch()).abbreviation, QString("+07"));
- }
-#endif // QT_BUILD_INTERNAL && Q_OS_UNIX && !Q_OS_DARWIN
-}
-
-void tst_QTimeZone::macTest()
-{
-#if defined(QT_BUILD_INTERNAL) && defined(Q_OS_DARWIN)
- // 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
- QMacTimeZonePrivate tzpd;
- QVERIFY(tzpd.isValid());
-
- // Test invalid constructor
- QMacTimeZonePrivate tzpi("Gondwana/Erewhon");
- QCOMPARE(tzpi.isValid(), false);
-
- // Test named constructor
- QMacTimeZonePrivate 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("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);
- testEpochTranPrivate(QMacTimeZonePrivate("America/Toronto"));
-#endif // QT_BUILD_INTERNAL && Q_OS_DARWIN
-}
-
-void tst_QTimeZone::darwinTypes()
-{
-#ifndef Q_OS_DARWIN
- QSKIP("This is an Apple-only test");
-#else
- extern void tst_QTimeZone_darwinTypes(); // in tst_qtimezone_darwin.mm
- tst_QTimeZone_darwinTypes();
-#endif
-}
-
-void tst_QTimeZone::winTest()
-{
-#if defined(QT_BUILD_INTERNAL) && defined(USING_WIN_TZ)
- // 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);
- testEpochTranPrivate(QWinTimeZonePrivate("America/Toronto"));
-#endif // QT_BUILD_INTERNAL && USING_WIN_TZ
-}
-
-#ifdef QT_BUILD_INTERNAL
-// Test each private produces the same basic results for CET
-void tst_QTimeZone::testCetPrivate(const QTimeZonePrivate &tzp)
-{
- // 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();
- qint64 prev = QDateTime(QDate(2011, 1, 1), QTime(0, 0, 0), Qt::UTC).toMSecsSinceEpoch();
-
- QCOMPARE(tzp.offsetFromUtc(std), 3600);
- QCOMPARE(tzp.offsetFromUtc(dst), 7200);
-
- QCOMPARE(tzp.standardTimeOffset(std), 3600);
- QCOMPARE(tzp.standardTimeOffset(dst), 3600);
-
- QCOMPARE(tzp.daylightTimeOffset(std), 0);
- QCOMPARE(tzp.daylightTimeOffset(dst), 3600);
-
- QCOMPARE(tzp.hasDaylightTime(), true);
- QCOMPARE(tzp.isDaylightTime(std), false);
- QCOMPARE(tzp.isDaylightTime(dst), true);
-
- QTimeZonePrivate::Data dat = tzp.data(std);
- QCOMPARE(dat.atMSecsSinceEpoch, std);
- QCOMPARE(dat.offsetFromUtc, 3600);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 0);
- QCOMPARE(dat.abbreviation, tzp.abbreviation(std));
-
- dat = tzp.data(dst);
- QCOMPARE(dat.atMSecsSinceEpoch, dst);
- QCOMPARE(dat.offsetFromUtc, 7200);
- QCOMPARE(dat.standardTimeOffset, 3600);
- QCOMPARE(dat.daylightTimeOffset, 3600);
- QCOMPARE(dat.abbreviation, tzp.abbreviation(dst));
-
- // Only test transitions if host system supports them
- if (tzp.hasTransitions()) {
- QTimeZonePrivate::Data tran = tzp.nextTransition(std);
- // 2012-03-25 02:00 CET, +1 -> +2
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(tran.atMSecsSinceEpoch, Qt::UTC),
- QDateTime(QDate(2012, 3, 25), QTime(2, 0), Qt::OffsetFromUTC, 3600));
- QCOMPARE(tran.offsetFromUtc, 7200);
- QCOMPARE(tran.standardTimeOffset, 3600);
- QCOMPARE(tran.daylightTimeOffset, 3600);
-
- tran = tzp.nextTransition(dst);
- // 2012-10-28 03:00 CEST, +2 -> +1
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(tran.atMSecsSinceEpoch, Qt::UTC),
- QDateTime(QDate(2012, 10, 28), QTime(3, 0), Qt::OffsetFromUTC, 2 * 3600));
- QCOMPARE(tran.offsetFromUtc, 3600);
- QCOMPARE(tran.standardTimeOffset, 3600);
- QCOMPARE(tran.daylightTimeOffset, 0);
-
- tran = tzp.previousTransition(std);
- // 2011-10-30 03:00 CEST, +2 -> +1
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(tran.atMSecsSinceEpoch, Qt::UTC),
- QDateTime(QDate(2011, 10, 30), QTime(3, 0), Qt::OffsetFromUTC, 2 * 3600));
- QCOMPARE(tran.offsetFromUtc, 3600);
- QCOMPARE(tran.standardTimeOffset, 3600);
- QCOMPARE(tran.daylightTimeOffset, 0);
-
- tran = tzp.previousTransition(dst);
- // 2012-03-25 02:00 CET, +1 -> +2 (again)
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(tran.atMSecsSinceEpoch, Qt::UTC),
- QDateTime(QDate(2012, 3, 25), QTime(2, 0), Qt::OffsetFromUTC, 3600));
- QCOMPARE(tran.offsetFromUtc, 7200);
- QCOMPARE(tran.standardTimeOffset, 3600);
- QCOMPARE(tran.daylightTimeOffset, 3600);
-
- QTimeZonePrivate::DataList expected;
- // 2011-03-27 02:00 CET, +1 -> +2
- tran.atMSecsSinceEpoch = QDateTime(QDate(2011, 3, 27), QTime(2, 0),
- Qt::OffsetFromUTC, 3600).toMSecsSinceEpoch();
- tran.offsetFromUtc = 7200;
- tran.standardTimeOffset = 3600;
- tran.daylightTimeOffset = 3600;
- expected << tran;
- // 2011-10-30 03:00 CEST, +2 -> +1
- tran.atMSecsSinceEpoch = QDateTime(QDate(2011, 10, 30), QTime(3, 0),
- Qt::OffsetFromUTC, 2 * 3600).toMSecsSinceEpoch();
- tran.offsetFromUtc = 3600;
- tran.standardTimeOffset = 3600;
- tran.daylightTimeOffset = 0;
- expected << tran;
- QTimeZonePrivate::DataList result = tzp.transitions(prev, std);
- QCOMPARE(result.count(), expected.count());
- for (int i = 0; i < expected.count(); ++i) {
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(result.at(i).atMSecsSinceEpoch,
- Qt::OffsetFromUTC, 3600),
- QDateTime::fromMSecsSinceEpoch(expected.at(i).atMSecsSinceEpoch,
- Qt::OffsetFromUTC, 3600));
- QCOMPARE(result.at(i).offsetFromUtc, expected.at(i).offsetFromUtc);
- QCOMPARE(result.at(i).standardTimeOffset, expected.at(i).standardTimeOffset);
- QCOMPARE(result.at(i).daylightTimeOffset, expected.at(i).daylightTimeOffset);
- }
- }
-}
-
-// Needs a zone with DST around the epoch; currently America/Toronto (EST5EDT)
-void tst_QTimeZone::testEpochTranPrivate(const QTimeZonePrivate &tzp)
-{
- if (!tzp.hasTransitions())
- return; // test only viable for transitions
-
- QTimeZonePrivate::Data tran = tzp.nextTransition(0); // i.e. first after epoch
- // 1970-04-26 02:00 EST, -5 -> -4
- const QDateTime after = QDateTime(QDate(1970, 4, 26), QTime(2, 0), Qt::OffsetFromUTC, -5 * 3600);
- const QDateTime found = QDateTime::fromMSecsSinceEpoch(tran.atMSecsSinceEpoch, Qt::UTC);
-#ifdef USING_WIN_TZ // MS gets the date wrong: 5th April instead of 26th.
- QCOMPARE(found.toOffsetFromUtc(-5 * 3600).time(), after.time());
-#else
- QCOMPARE(found, after);
-#endif
- QCOMPARE(tran.offsetFromUtc, -4 * 3600);
- QCOMPARE(tran.standardTimeOffset, -5 * 3600);
- QCOMPARE(tran.daylightTimeOffset, 3600);
-
- // Pre-epoch time-zones might not be supported at all:
- tran = tzp.nextTransition(QDateTime(QDate(1601, 1, 1), QTime(0, 0),
- Qt::UTC).toMSecsSinceEpoch());
- if (tran.atMSecsSinceEpoch != QTimeZonePrivate::invalidMSecs()
- // Toronto *did* have a transition before 1970 (DST since 1918):
- && tran.atMSecsSinceEpoch < 0) {
- // ... but, if they are, we should be able to search back to them:
- tran = tzp.previousTransition(0); // i.e. last before epoch
- // 1969-10-26 02:00 EDT, -4 -> -5
- QCOMPARE(QDateTime::fromMSecsSinceEpoch(tran.atMSecsSinceEpoch, Qt::UTC),
- QDateTime(QDate(1969, 10, 26), QTime(2, 0), Qt::OffsetFromUTC, -4 * 3600));
- QCOMPARE(tran.offsetFromUtc, -5 * 3600);
- QCOMPARE(tran.standardTimeOffset, -5 * 3600);
- QCOMPARE(tran.daylightTimeOffset, 0);
- } else {
- // Do not use QSKIP(): that would discard the rest of this sub-test's caller.
- qDebug() << "No support for pre-epoch time-zone transitions";
- }
-}
-#endif // QT_BUILD_INTERNAL
-
-QTEST_APPLESS_MAIN(tst_QTimeZone)
-#include "tst_qtimezone.moc"
diff --git a/tests/auto/corelib/tools/qtimezone/tst_qtimezone_darwin.mm b/tests/auto/corelib/tools/qtimezone/tst_qtimezone_darwin.mm
deleted file mode 100644
index de801e55d0..0000000000
--- a/tests/auto/corelib/tools/qtimezone/tst_qtimezone_darwin.mm
+++ /dev/null
@@ -1,68 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2017 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtCore/QTimeZone>
-#include <QtTest/QtTest>
-
-#include <CoreFoundation/CoreFoundation.h>
-#include <Foundation/Foundation.h>
-
-void tst_QTimeZone_darwinTypes()
-{
-#if !defined(QT_NO_SYSTEMLOCALE)
- // QTimeZone <-> CFTimeZone
- {
- QTimeZone qtTimeZone("America/Los_Angeles");
- const CFTimeZoneRef cfTimeZone = qtTimeZone.toCFTimeZone();
- QCOMPARE(QTimeZone::fromCFTimeZone(cfTimeZone), qtTimeZone);
- CFRelease(cfTimeZone);
- }
- {
- CFTimeZoneRef cfTimeZone = CFTimeZoneCreateWithName(kCFAllocatorDefault,
- CFSTR("America/Los_Angeles"), false);
- const QTimeZone qtTimeZone = QTimeZone::fromCFTimeZone(cfTimeZone);
- QVERIFY(CFEqual(qtTimeZone.toCFTimeZone(), cfTimeZone));
- CFRelease(cfTimeZone);
- }
- // QTimeZone <-> NSTimeZone
- {
- NSAutoreleasePool *autoreleasepool = [[NSAutoreleasePool alloc] init];
- QTimeZone qtTimeZone("America/Los_Angeles");
- const NSTimeZone *nsTimeZone = qtTimeZone.toNSTimeZone();
- QCOMPARE(QTimeZone::fromNSTimeZone(nsTimeZone), qtTimeZone);
- [autoreleasepool release];
- }
- {
- NSAutoreleasePool *autoreleasepool = [[NSAutoreleasePool alloc] init];
- NSTimeZone *nsTimeZone = [NSTimeZone timeZoneWithName:@"America/Los_Angeles"];
- const QTimeZone qtTimeZone = QTimeZone::fromNSTimeZone(nsTimeZone);
- QVERIFY([qtTimeZone.toNSTimeZone() isEqual:nsTimeZone]);
- [autoreleasepool release];
- }
-#endif
-}
diff --git a/tests/auto/corelib/tools/qvarlengtharray/tst_qvarlengtharray.cpp b/tests/auto/corelib/tools/qvarlengtharray/tst_qvarlengtharray.cpp
index 5737db760c..fff8c75a90 100644
--- a/tests/auto/corelib/tools/qvarlengtharray/tst_qvarlengtharray.cpp
+++ b/tests/auto/corelib/tools/qvarlengtharray/tst_qvarlengtharray.cpp
@@ -908,7 +908,6 @@ void tst_QVarLengthArray::initializeListComplex()
template<typename T>
void tst_QVarLengthArray::initializeList()
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
T val1(110);
T val2(105);
T val3(101);
@@ -945,9 +944,6 @@ void tst_QVarLengthArray::initializeList()
v6 = {}; // assign empty
QCOMPARE(v6.size(), 0);
-#else
- QSKIP("This tests requires a compiler that supports initializer lists.");
-#endif
}
void tst_QVarLengthArray::insertMove()
diff --git a/tests/auto/corelib/tools/qvector/tst_qvector.cpp b/tests/auto/corelib/tools/qvector/tst_qvector.cpp
index a7faeb5ca5..3256130472 100644
--- a/tests/auto/corelib/tools/qvector/tst_qvector.cpp
+++ b/tests/auto/corelib/tools/qvector/tst_qvector.cpp
@@ -206,6 +206,9 @@ private slots:
void assignmentInt() const;
void assignmentMovable() const;
void assignmentCustom() const;
+ void assignFromInitializerListInt() const;
+ void assignFromInitializerListMovable() const;
+ void assignFromInitializerListCustom() const;
void addInt() const;
void addMovable() const;
void addCustom() const;
@@ -254,7 +257,6 @@ private slots:
void fromListInt() const;
void fromListMovable() const;
void fromListCustom() const;
- void fromStdVector() const;
void indexOf() const;
void insertInt() const;
void insertMovable() const;
@@ -293,7 +295,10 @@ private slots:
void swapMovable() const;
void swapCustom() const;
void toList() const;
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
+ void fromStdVector() const;
void toStdVector() const;
+#endif
void value() const;
void testOperators() const;
@@ -326,10 +331,13 @@ private slots:
void insertMove() const;
+ void swapItemsAt() const;
+
private:
template<typename T> void copyConstructor() const;
template<typename T> void add() const;
template<typename T> void append() const;
+ template<typename T> void assignFromInitializerList() const;
template<typename T> void capacity() const;
template<typename T> void clear() const;
template<typename T> void count() const;
@@ -543,6 +551,40 @@ void tst_QVector::assignmentCustom() const
}
template<typename T>
+void tst_QVector::assignFromInitializerList() const
+{
+ T val1(SimpleValue<T>::at(1));
+ T val2(SimpleValue<T>::at(2));
+ T val3(SimpleValue<T>::at(3));
+
+ QVector<T> v1 = {val1, val2, val3};
+ QCOMPARE(v1, QVector<T>() << val1 << val2 << val3);
+ QCOMPARE(v1, (QVector<T> {val1, val2, val3}));
+
+ v1 = {};
+ QCOMPARE(v1.size(), 0);
+}
+
+void tst_QVector::assignFromInitializerListInt() const
+{
+ assignFromInitializerList<int>();
+}
+
+void tst_QVector::assignFromInitializerListMovable() const
+{
+ const int instancesCount = Movable::counter.loadAcquire();
+ assignFromInitializerList<Movable>();
+ QCOMPARE(instancesCount, Movable::counter.loadAcquire());
+}
+
+void tst_QVector::assignFromInitializerListCustom() const
+{
+ const int instancesCount = Custom::counter.loadAcquire();
+ assignFromInitializerList<Custom>();
+ QCOMPARE(instancesCount, Custom::counter.loadAcquire());
+}
+
+template<typename T>
void tst_QVector::add() const
{
{
@@ -667,7 +709,6 @@ void tst_QVector::appendCustom() const
void tst_QVector::appendRvalue() const
{
-#ifdef Q_COMPILER_RVALUE_REFS
QVector<QString> v;
v.append("hello");
QString world = "world";
@@ -675,9 +716,6 @@ void tst_QVector::appendRvalue() const
QVERIFY(world.isEmpty());
QCOMPARE(v.front(), QString("hello"));
QCOMPARE(v.back(), QString("world"));
-#else
- QSKIP("This test requires that C++11 move semantics support is enabled in the compiler");
-#endif
}
void tst_QVector::at() const
@@ -1392,6 +1430,7 @@ void tst_QVector::fromListCustom() const
QCOMPARE(instancesCount, Custom::counter.loadAcquire());
}
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
void tst_QVector::fromStdVector() const
{
// stl = :(
@@ -1405,6 +1444,7 @@ void tst_QVector::fromStdVector() const
// test it converts ok
QCOMPARE(myvec, QVector<QString>() << "aaa" << "bbb" << "ninjas" << "pirates");
}
+#endif
void tst_QVector::indexOf() const
{
@@ -2297,6 +2337,7 @@ void tst_QVector::toList() const
QCOMPARE(myvec, QVector<QString>() << "A" << "B" << "C");
}
+#if QT_VERSION < QT_VERSION_CHECK(6,0,0)
void tst_QVector::toStdVector() const
{
QVector<QString> myvec;
@@ -2309,6 +2350,7 @@ void tst_QVector::toStdVector() const
QCOMPARE(myvec, QVector<QString>() << "A" << "B" << "C");
}
+#endif
void tst_QVector::value() const
{
@@ -2515,7 +2557,6 @@ void tst_QVector::reallocAfterCopy()
template<typename T>
void tst_QVector::initializeList()
{
-#ifdef Q_COMPILER_INITIALIZER_LISTS
T val1(SimpleValue<T>::at(1));
T val2(SimpleValue<T>::at(2));
T val3(SimpleValue<T>::at(3));
@@ -2532,7 +2573,6 @@ void tst_QVector::initializeList()
QVector<T> v4({});
QCOMPARE(v4.size(), 0);
-#endif
}
void tst_QVector::initializeListInt()
@@ -2842,7 +2882,7 @@ void tst_QVector::detachThreadSafety() const
struct : QThread {
void run() override
{
- QVector<T> copy(*detachThreadSafetyData<T>()->load());
+ QVector<T> copy(*detachThreadSafetyData<T>()->loadRelaxed());
QVERIFY(!copy.isDetached());
detachThreadSafetyLock.release();
detachThreadSafetyLock.acquire(100);
@@ -2952,5 +2992,22 @@ void tst_QVector::insertMove() const
QCOMPARE(Movable::counter.loadAcquire(), instancesCount);
}
+void tst_QVector::swapItemsAt() const
+{
+ QVector<int> v;
+ v << 0 << 1 << 2 << 3;
+
+ v.swapItemsAt(0, 2);
+ QCOMPARE(v.at(0), 2);
+ QCOMPARE(v.at(2), 0);
+
+ auto copy = v;
+ copy.swapItemsAt(0, 2);
+ QCOMPARE(v.at(0), 2);
+ QCOMPARE(v.at(2), 0);
+ QCOMPARE(copy.at(0), 0);
+ QCOMPARE(copy.at(2), 2);
+}
+
QTEST_MAIN(tst_QVector)
#include "tst_qvector.moc"
diff --git a/tests/auto/corelib/tools/qversionnumber/tst_qversionnumber.cpp b/tests/auto/corelib/tools/qversionnumber/tst_qversionnumber.cpp
index 05579dce6e..7c4d1071ce 100644
--- a/tests/auto/corelib/tools/qversionnumber/tst_qversionnumber.cpp
+++ b/tests/auto/corelib/tools/qversionnumber/tst_qversionnumber.cpp
@@ -260,12 +260,10 @@ void tst_QVersionNumber::constructorExplicit()
QCOMPARE(v5.segments(), v6.segments());
-#ifdef Q_COMPILER_INITIALIZER_LISTS
QVersionNumber v7(4, 5, 6);
QVersionNumber v8 = {4, 5, 6};
QCOMPARE(v7.segments(), v8.segments());
-#endif
}
void tst_QVersionNumber::constructorCopy_data()
@@ -436,7 +434,7 @@ void tst_QVersionNumber::normalized()
QFETCH(QVersionNumber, expected);
QCOMPARE(version.normalized(), expected);
- QCOMPARE(qMove(version).normalized(), expected);
+ QCOMPARE(std::move(version).normalized(), expected);
}
void tst_QVersionNumber::isNormalized_data()
@@ -586,30 +584,28 @@ void tst_QVersionNumber::serialize()
void tst_QVersionNumber::moveSemantics()
{
-#ifdef Q_COMPILER_RVALUE_REFS
// QVersionNumber(QVersionNumber &&)
{
QVersionNumber v1(1, 2, 3);
- QVersionNumber v2 = qMove(v1);
+ QVersionNumber v2 = std::move(v1);
QCOMPARE(v2, QVersionNumber(1, 2, 3));
}
// QVersionNumber &operator=(QVersionNumber &&)
{
QVersionNumber v1(1, 2, 3);
QVersionNumber v2;
- v2 = qMove(v1);
+ v2 = std::move(v1);
QCOMPARE(v2, QVersionNumber(1, 2, 3));
}
// QVersionNumber(QVector<int> &&)
{
QVector<int> segments = QVector<int>() << 1 << 2 << 3;
QVersionNumber v1(segments);
- QVersionNumber v2(qMove(segments));
+ QVersionNumber v2(std::move(segments));
QVERIFY(!v1.isNull());
QVERIFY(!v2.isNull());
QCOMPARE(v1, v2);
}
-#endif
#ifdef Q_COMPILER_REF_QUALIFIERS
// normalized()
{
@@ -620,7 +616,7 @@ void tst_QVersionNumber::moveSemantics()
QVERIFY(!v.isNull());
QVERIFY(!nv.isNull());
QVERIFY(nv.isNormalized());
- nv = qMove(v).normalized();
+ nv = std::move(v).normalized();
QVERIFY(!nv.isNull());
QVERIFY(nv.isNormalized());
}
@@ -632,13 +628,10 @@ void tst_QVersionNumber::moveSemantics()
segments = v.segments();
QVERIFY(!v.isNull());
QVERIFY(!segments.empty());
- segments = qMove(v).segments();
+ segments = std::move(v).segments();
QVERIFY(!segments.empty());
}
#endif
-#if !defined(Q_COMPILER_RVALUE_REFS) && !defined(Q_COMPILER_REF_QUALIFIERS)
- QSKIP("This test requires C++11 move semantics support in the compiler.");
-#endif
}
void tst_QVersionNumber::qtVersion()
diff --git a/tests/auto/corelib/tools/tools.pro b/tests/auto/corelib/tools/tools.pro
index 2a975e67d1..243e7e96f5 100644
--- a/tests/auto/corelib/tools/tools.pro
+++ b/tests/auto/corelib/tools/tools.pro
@@ -16,8 +16,6 @@ SUBDIRS=\
qcommandlineparser \
qcontiguouscache \
qcryptographichash \
- qdate \
- qdatetime \
qeasingcurve \
qexplicitlyshareddatapointer \
qfreelist \
@@ -46,6 +44,7 @@ SUBDIRS=\
qringbuffer \
qscopedpointer \
qscopedvaluerollback \
+ qscopeguard \
qset \
qsharedpointer \
qsize \
@@ -61,8 +60,6 @@ SUBDIRS=\
qstringref \
qstringview \
qtextboundaryfinder \
- qtime \
- qtimezone \
qtimeline \
qvarlengtharray \
qvector \