// Copyright (C) 2019 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0 #include #include // pi, e // Tests for QTest::toString class tst_toString : public QObject { Q_OBJECT template void numeric_data(); template void numeric(); private slots: void floatTst_data() { numeric_data(); } void floatTst() { numeric(); } void doubleTst_data() { numeric_data(); } void doubleTst() { numeric(); } void intTst_data() { numeric_data(); } void intTst() { numeric(); } void unsignedTst_data() { numeric_data(); } void unsignedTst() { numeric(); } void quint64Tst_data() { numeric_data(); } void quint64Tst() { numeric(); } void qint64Tst_data() { numeric_data(); } void qint64Tst() { numeric(); } private: template void compare(); template void compare_eq(); private slots: void floatCompare_data() { numeric_data(); } void floatCompare() { compare(); } void floatCompareEq_data() { numeric_data(); } void floatCompareEq() { compare_eq(); } void doubleCompare_data() { numeric_data(); } void doubleCompare() { compare(); } void doubleCompareEq_data() { numeric_data(); } void doubleCompareEq() { compare_eq(); } void intCompare_data() { numeric_data(); } void intCompare() { compare(); } void intCompareEq_data() { numeric_data(); } void intCompareEq() { compare_eq(); } void unsignedCompare_data() { numeric_data(); } void unsignedCompare() { compare(); } void unsignedCompareEq_data() { numeric_data(); } void unsignedCompareEq() { compare_eq(); } void quint64Compare_data() { numeric_data(); } void quint64Compare() { compare(); } void quint64CompareEq_data() { numeric_data(); } void quint64CompareEq() { compare_eq(); } void qint64Compare_data() { numeric_data(); } void qint64Compare() { compare(); } void qint64CompareEq_data() { numeric_data(); } void qint64CompareEq() { compare_eq(); } }; template void tst_toString::numeric_data() { QTest::addColumn("datum"); const bool floaty = std::is_floating_point::value; QTest::newRow("zero") << T(0); QTest::newRow("one") << T(1); if (floaty) { QTest::newRow("pi") << T(M_PI); QTest::newRow("e") << T(M_E); // Stress canonicalisation of leading zeros on exponents: QTest::newRow("milli") << T(1e-3); QTest::newRow("micro") << T(1e-6); QTest::newRow("mu0") << T(.4e-6 * M_PI); // Henry/metre QTest::newRow("Planck") << T(662.606876e-36); // Joule.second/turn } QTest::newRow("2e9") << T(2000000000); QTest::newRow("c.s/m") << T(299792458); QTest::newRow("Avogadro") << T(6.022045e+23); // things/mol (.996 << 79, so ints overflow to max) QTest::newRow("lowest") << std::numeric_limits::lowest(); QTest::newRow("max") << std::numeric_limits::max(); if (floaty) { QTest::newRow("min") << std::numeric_limits::min(); if (std::numeric_limits::has_infinity) { const T uge = std::numeric_limits::infinity(); QTest::newRow("inf") << uge; QTest::newRow("-inf") << -uge; } if (std::numeric_limits::has_quiet_NaN) QTest::newRow("nan") << std::numeric_limits::quiet_NaN(); } } template void tst_toString::numeric() { QFETCH(T, datum); QBENCHMARK { auto tst = QTest::toString(datum); delete [] tst; } } template void tst_toString::compare() { QFETCH(T, datum); QBENCHMARK { QCOMPARE(datum, datum); } } template void tst_toString::compare_eq() { QFETCH(T, datum); if constexpr (std::numeric_limits::has_quiet_NaN) { if (qIsNaN(datum)) QSKIP("Unlike QCOMPARE, QCOMPARE_EQ doesn't handle NaN specially"); } QBENCHMARK { QCOMPARE_EQ(datum, datum); } } QTEST_MAIN(tst_toString) #include "tst_tostring.moc"