mirror of
https://github.com/arcan1s/awesome-widgets.git
synced 2025-04-24 23:47:20 +00:00
add test library for random values generation
This commit is contained in:
parent
7b154af1b3
commit
cae9e0d2e3
@ -11,47 +11,53 @@ include_directories(
|
|||||||
${Kf5_INCLUDE}
|
${Kf5_INCLUDE}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
## library
|
||||||
|
set(AWTESTLIBRARY_HEADERS awtestlibrary.h)
|
||||||
|
set(AWTESTLIBRARY_SOURCES awtestlibrary.cpp)
|
||||||
|
add_library(${SUBPROJECT}-awtest STATIC ${AWTESTLIBRARY_SOURCES} ${AWTESTLIBRARY_HEADERS})
|
||||||
|
target_link_libraries(${SUBPROJECT}-awtest ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
||||||
|
set(LIBRARY_TEST_SET ${SUBPROJECT}-awtest ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
||||||
## extensions
|
## extensions
|
||||||
# abstractextitem
|
# abstractextitem
|
||||||
set(ABSTRACTEXTITEM_HEADERS testabstractextitem.h)
|
set(ABSTRACTEXTITEM_HEADERS testabstractextitem.h)
|
||||||
set(ABSTRACTEXTITEM_SOURCES testabstractextitem.cpp)
|
set(ABSTRACTEXTITEM_SOURCES testabstractextitem.cpp)
|
||||||
add_executable(${SUBPROJECT}-abstractextitem ${ABSTRACTEXTITEM_HEADERS} ${ABSTRACTEXTITEM_SOURCES})
|
add_executable(${SUBPROJECT}-abstractextitem ${ABSTRACTEXTITEM_HEADERS} ${ABSTRACTEXTITEM_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-abstractextitem ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-abstractextitem ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "AbstractExtItem" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-abstractextitem)
|
add_test(NAME "AbstractExtItem" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-abstractextitem)
|
||||||
# extquotes
|
# extquotes
|
||||||
set(EXTQUOTES_HEADERS testextquotes.h)
|
set(EXTQUOTES_HEADERS testextquotes.h)
|
||||||
set(EXTQUOTES_SOURCES testextquotes.cpp)
|
set(EXTQUOTES_SOURCES testextquotes.cpp)
|
||||||
add_executable(${SUBPROJECT}-extquotes ${EXTQUOTES_HEADERS} ${EXTQUOTES_SOURCES})
|
add_executable(${SUBPROJECT}-extquotes ${EXTQUOTES_HEADERS} ${EXTQUOTES_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-extquotes ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-extquotes ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "ExtQuotes" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extquotes)
|
add_test(NAME "ExtQuotes" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extquotes)
|
||||||
# extscript
|
# extscript
|
||||||
set(EXTSCRIPT_HEADERS testextscript.h)
|
set(EXTSCRIPT_HEADERS testextscript.h)
|
||||||
set(EXTSCRIPT_SOURCES testextscript.cpp)
|
set(EXTSCRIPT_SOURCES testextscript.cpp)
|
||||||
add_executable(${SUBPROJECT}-extscript ${EXTSCRIPT_HEADERS} ${EXTSCRIPT_SOURCES})
|
add_executable(${SUBPROJECT}-extscript ${EXTSCRIPT_HEADERS} ${EXTSCRIPT_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-extscript ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-extscript ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "ExtScript" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extscript)
|
add_test(NAME "ExtScript" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extscript)
|
||||||
# extupgrade
|
# extupgrade
|
||||||
set(EXTUPGRADE_HEADERS testextupgrade.h)
|
set(EXTUPGRADE_HEADERS testextupgrade.h)
|
||||||
set(EXTUPGRADE_SOURCES testextupgrade.cpp)
|
set(EXTUPGRADE_SOURCES testextupgrade.cpp)
|
||||||
add_executable(${SUBPROJECT}-extupgrade ${EXTUPGRADE_HEADERS} ${EXTUPGRADE_SOURCES})
|
add_executable(${SUBPROJECT}-extupgrade ${EXTUPGRADE_HEADERS} ${EXTUPGRADE_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-extupgrade ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-extupgrade ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "ExtUpgrade" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extupgrade)
|
add_test(NAME "ExtUpgrade" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extupgrade)
|
||||||
# extweather
|
# extweather
|
||||||
set(EXTWEATHER_HEADERS testextweather.h)
|
set(EXTWEATHER_HEADERS testextweather.h)
|
||||||
set(EXTWEATHER_SOURCES testextweather.cpp)
|
set(EXTWEATHER_SOURCES testextweather.cpp)
|
||||||
add_executable(${SUBPROJECT}-extweather ${EXTWEATHER_HEADERS} ${EXTWEATHER_SOURCES})
|
add_executable(${SUBPROJECT}-extweather ${EXTWEATHER_HEADERS} ${EXTWEATHER_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-extweather ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-extweather ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "ExtWeather" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extweather)
|
add_test(NAME "ExtWeather" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-extweather)
|
||||||
## formatters
|
## formatters
|
||||||
# float formatter
|
# float formatter
|
||||||
set(FLOATFORMATTER_HEADERS testfloatformatter.h)
|
set(FLOATFORMATTER_HEADERS testfloatformatter.h)
|
||||||
set(FLOATFORMATTER_SOURCES testfloatformatter.cpp)
|
set(FLOATFORMATTER_SOURCES testfloatformatter.cpp)
|
||||||
add_executable(${SUBPROJECT}-floatformatter ${FLOATFORMATTER_HEADERS} ${FLOATFORMATTER_SOURCES})
|
add_executable(${SUBPROJECT}-floatformatter ${FLOATFORMATTER_HEADERS} ${FLOATFORMATTER_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-floatformatter ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-floatformatter ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "FloatFormatter" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-floatformatter)
|
add_test(NAME "Float4Formatter" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-floatformatter)
|
||||||
# no formatter
|
# no formatter
|
||||||
set(NOFORMATTER_HEADERS testnoformatter.h)
|
set(NOFORMATTER_HEADERS testnoformatter.h)
|
||||||
set(NOFORMATTER_SOURCES testnoformatter.cpp)
|
set(NOFORMATTER_SOURCES testnoformatter.cpp)
|
||||||
add_executable(${SUBPROJECT}-noformatter ${NOFORMATTER_HEADERS} ${NOFORMATTER_SOURCES})
|
add_executable(${SUBPROJECT}-noformatter ${NOFORMATTER_HEADERS} ${NOFORMATTER_SOURCES})
|
||||||
target_link_libraries(${SUBPROJECT}-noformatter ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-noformatter ${LIBRARY_TEST_SET})
|
||||||
add_test(NAME "NoFormatter" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-noformatter)
|
add_test(NAME "NoFormatter" COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT}-noformatter)
|
||||||
|
61
sources/test/awtestlibrary.cpp
Normal file
61
sources/test/awtestlibrary.cpp
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* This file is part of awesome-widgets *
|
||||||
|
* *
|
||||||
|
* awesome-widgets is free software: you can redistribute it and/or *
|
||||||
|
* modify it under the terms of the GNU General Public License as *
|
||||||
|
* published by the Free Software Foundation, either version 3 of the *
|
||||||
|
* License, or (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* awesome-widgets is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* You should have received a copy of the GNU General Public License *
|
||||||
|
* along with awesome-widgets. If not, see http://www.gnu.org/licenses/ *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#include "awtestlibrary.h"
|
||||||
|
|
||||||
|
|
||||||
|
char AWTestLibrary::randomChar()
|
||||||
|
{
|
||||||
|
return 'A' + (rand() % static_cast<int>('Z' - 'A'));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
double AWTestLibrary::randomDouble()
|
||||||
|
{
|
||||||
|
return static_cast<double>(rand()) / static_cast<double>(RAND_MAX);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int AWTestLibrary::randomInt(const int max)
|
||||||
|
{
|
||||||
|
return rand() % max;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QString AWTestLibrary::randomString(const int max)
|
||||||
|
{
|
||||||
|
QString output;
|
||||||
|
|
||||||
|
int count = 1 + randomInt(max);
|
||||||
|
for (int i = 0; i < count; i++)
|
||||||
|
output += QChar(randomChar());
|
||||||
|
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QStringList AWTestLibrary::randomStringList(const int max)
|
||||||
|
{
|
||||||
|
QStringList output;
|
||||||
|
|
||||||
|
int count = 1 + randomInt(max);
|
||||||
|
for (int i = 0; i < count; i++)
|
||||||
|
output.append(randomString());
|
||||||
|
|
||||||
|
return output;
|
||||||
|
}
|
35
sources/test/awtestlibrary.h
Normal file
35
sources/test/awtestlibrary.h
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* This file is part of awesome-widgets *
|
||||||
|
* *
|
||||||
|
* awesome-widgets is free software: you can redistribute it and/or *
|
||||||
|
* modify it under the terms of the GNU General Public License as *
|
||||||
|
* published by the Free Software Foundation, either version 3 of the *
|
||||||
|
* License, or (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* awesome-widgets is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* You should have received a copy of the GNU General Public License *
|
||||||
|
* along with awesome-widgets. If not, see http://www.gnu.org/licenses/ *
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef AWTESTLIBRARY_H
|
||||||
|
#define AWTESTLIBRARY_H
|
||||||
|
|
||||||
|
#include <QStringList>
|
||||||
|
|
||||||
|
|
||||||
|
namespace AWTestLibrary
|
||||||
|
{
|
||||||
|
char randomChar();
|
||||||
|
double randomDouble();
|
||||||
|
int randomInt(const int max = 100);
|
||||||
|
QString randomString(const int max = 100);
|
||||||
|
QStringList randomStringList(const int max = 100);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* AWTESTLIBRARY_H */
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include <QtTest>
|
#include <QtTest>
|
||||||
|
|
||||||
|
#include "awtestlibrary.h"
|
||||||
#include "extupgrade.h"
|
#include "extupgrade.h"
|
||||||
|
|
||||||
|
|
||||||
@ -114,13 +115,10 @@ void TestAbstractExtItem::generateFilename()
|
|||||||
writeFileName = QString("%1/awesomewidgets/tmp/")
|
writeFileName = QString("%1/awesomewidgets/tmp/")
|
||||||
.arg(QStandardPaths::writableLocation(
|
.arg(QStandardPaths::writableLocation(
|
||||||
QStandardPaths::GenericDataLocation));
|
QStandardPaths::GenericDataLocation));
|
||||||
int diff = 'Z' - 'A';
|
|
||||||
int count = rand() % 20 + 1;
|
QString name = AWTestLibrary::randomString(20);
|
||||||
for (int i = 0; i < count; i++) {
|
fileName += name;
|
||||||
char c = 'A' + (rand() % diff);
|
writeFileName += name;
|
||||||
fileName += QChar(c);
|
|
||||||
writeFileName += QChar(c);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,12 +20,13 @@
|
|||||||
|
|
||||||
#include <QtTest>
|
#include <QtTest>
|
||||||
|
|
||||||
|
#include "awtestlibrary.h"
|
||||||
#include "extscript.h"
|
#include "extscript.h"
|
||||||
|
|
||||||
|
|
||||||
void TestExtScript::initTestCase()
|
void TestExtScript::initTestCase()
|
||||||
{
|
{
|
||||||
generateRandomString();
|
randomString = AWTestLibrary::randomString();
|
||||||
|
|
||||||
extScript = new ExtScript(nullptr);
|
extScript = new ExtScript(nullptr);
|
||||||
extScript->setInterval(1);
|
extScript->setInterval(1);
|
||||||
@ -102,17 +103,4 @@ void TestExtScript::test_copy()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void TestExtScript::generateRandomString()
|
|
||||||
{
|
|
||||||
randomString.clear();
|
|
||||||
|
|
||||||
int diff = 'Z' - 'A';
|
|
||||||
int count = rand() % 100 + 1;
|
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
char c = 'A' + (rand() % diff);
|
|
||||||
randomString += QChar(c);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
QTEST_MAIN(TestExtScript);
|
QTEST_MAIN(TestExtScript);
|
||||||
|
@ -40,7 +40,6 @@ private slots:
|
|||||||
void test_copy();
|
void test_copy();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void generateRandomString();
|
|
||||||
ExtScript *extScript = nullptr;
|
ExtScript *extScript = nullptr;
|
||||||
QString randomString;
|
QString randomString;
|
||||||
};
|
};
|
||||||
|
@ -20,12 +20,14 @@
|
|||||||
|
|
||||||
#include <QtTest>
|
#include <QtTest>
|
||||||
|
|
||||||
|
#include "awtestlibrary.h"
|
||||||
#include "extupgrade.h"
|
#include "extupgrade.h"
|
||||||
|
|
||||||
|
|
||||||
void TestExtUpgrade::initTestCase()
|
void TestExtUpgrade::initTestCase()
|
||||||
{
|
{
|
||||||
generateRandomStrings();
|
randomStrings = AWTestLibrary::randomStringList();
|
||||||
|
cmd = QString("echo -e '%1'").arg(randomStrings.join(QString("\n")));
|
||||||
|
|
||||||
extUpgrade = new ExtUpgrade(nullptr);
|
extUpgrade = new ExtUpgrade(nullptr);
|
||||||
extUpgrade->setInterval(1);
|
extUpgrade->setInterval(1);
|
||||||
@ -68,7 +70,7 @@ void TestExtUpgrade::test_run()
|
|||||||
|
|
||||||
void TestExtUpgrade::test_null()
|
void TestExtUpgrade::test_null()
|
||||||
{
|
{
|
||||||
int null = rand() % randomStrings.count();
|
int null = AWTestLibrary::randomInt(randomStrings.count());
|
||||||
extUpgrade->setNull(null);
|
extUpgrade->setNull(null);
|
||||||
QSignalSpy spy(extUpgrade, SIGNAL(dataReceived(const QVariantHash &)));
|
QSignalSpy spy(extUpgrade, SIGNAL(dataReceived(const QVariantHash &)));
|
||||||
extUpgrade->run();
|
extUpgrade->run();
|
||||||
@ -85,9 +87,9 @@ void TestExtUpgrade::test_null()
|
|||||||
void TestExtUpgrade::test_filter()
|
void TestExtUpgrade::test_filter()
|
||||||
{
|
{
|
||||||
QSet<QString> filters;
|
QSet<QString> filters;
|
||||||
int count = rand() % randomStrings.count();
|
int count = AWTestLibrary::randomInt(randomStrings.count());
|
||||||
for (int i = 0; i < count; i++) {
|
for (int i = 0; i < count; i++) {
|
||||||
int index = rand() % randomStrings.count();
|
int index = AWTestLibrary::randomInt(randomStrings.count());
|
||||||
filters << randomStrings.at(index);
|
filters << randomStrings.at(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -120,29 +122,4 @@ void TestExtUpgrade::test_copy()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
QString TestExtUpgrade::generateRandomString() const
|
|
||||||
{
|
|
||||||
QString string;
|
|
||||||
int diff = 'Z' - 'A';
|
|
||||||
int count = rand() % 100 + 1;
|
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
char c = 'A' + (rand() % diff);
|
|
||||||
string += QChar(c);
|
|
||||||
}
|
|
||||||
|
|
||||||
return string;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void TestExtUpgrade::generateRandomStrings()
|
|
||||||
{
|
|
||||||
randomStrings.clear();
|
|
||||||
|
|
||||||
int count = rand() % 100 + 1;
|
|
||||||
for (int i = 0; i < count; i++)
|
|
||||||
randomStrings.append(generateRandomString());
|
|
||||||
cmd = QString("echo -e '%1'").arg(randomStrings.join(QString("\n")));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
QTEST_MAIN(TestExtUpgrade);
|
QTEST_MAIN(TestExtUpgrade);
|
||||||
|
@ -41,8 +41,6 @@ private slots:
|
|||||||
void test_copy();
|
void test_copy();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString generateRandomString() const;
|
|
||||||
void generateRandomStrings();
|
|
||||||
ExtUpgrade *extUpgrade = nullptr;
|
ExtUpgrade *extUpgrade = nullptr;
|
||||||
QString cmd;
|
QString cmd;
|
||||||
QStringList randomStrings;
|
QStringList randomStrings;
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include <QtTest>
|
#include <QtTest>
|
||||||
|
|
||||||
|
#include "awtestlibrary.h"
|
||||||
#include "awfloatformatter.h"
|
#include "awfloatformatter.h"
|
||||||
|
|
||||||
|
|
||||||
@ -43,12 +44,12 @@ void TestAWFloatFormatter::test_values()
|
|||||||
void TestAWFloatFormatter::test_count()
|
void TestAWFloatFormatter::test_count()
|
||||||
{
|
{
|
||||||
// assign
|
// assign
|
||||||
int count = 10 + rand() % 200;
|
int count = 10 + AWTestLibrary::randomInt();
|
||||||
formatter->setCount(count);
|
formatter->setCount(count);
|
||||||
QCOMPARE(formatter->count(), count);
|
QCOMPARE(formatter->count(), count);
|
||||||
|
|
||||||
// test
|
// test
|
||||||
float value = getValue();
|
double value = AWTestLibrary::randomDouble();
|
||||||
QString output = formatter->convert(value);
|
QString output = formatter->convert(value);
|
||||||
QCOMPARE(output.count(), count);
|
QCOMPARE(output.count(), count);
|
||||||
|
|
||||||
@ -60,13 +61,13 @@ void TestAWFloatFormatter::test_count()
|
|||||||
void TestAWFloatFormatter::test_fillChar()
|
void TestAWFloatFormatter::test_fillChar()
|
||||||
{
|
{
|
||||||
// assign
|
// assign
|
||||||
char c = 'A' + (rand() % static_cast<int>('Z' - 'A'));
|
char c = AWTestLibrary::randomChar();
|
||||||
formatter->setFillChar(QChar(c));
|
formatter->setFillChar(QChar(c));
|
||||||
QCOMPARE(formatter->fillChar(), QChar(c));
|
QCOMPARE(formatter->fillChar(), QChar(c));
|
||||||
formatter->setCount(101);
|
formatter->setCount(101);
|
||||||
|
|
||||||
// test
|
// test
|
||||||
int value = rand() % 100;
|
int value = AWTestLibrary::randomInt();
|
||||||
QString output = formatter->convert(value);
|
QString output = formatter->convert(value);
|
||||||
QVERIFY(output.startsWith(QChar(c)));
|
QVERIFY(output.startsWith(QChar(c)));
|
||||||
|
|
||||||
@ -86,7 +87,7 @@ void TestAWFloatFormatter::test_format()
|
|||||||
QCOMPARE(formatter->format(), 'e');
|
QCOMPARE(formatter->format(), 'e');
|
||||||
|
|
||||||
// test
|
// test
|
||||||
float value = getValue();
|
double value = AWTestLibrary::randomDouble();
|
||||||
QString output = formatter->convert(value);
|
QString output = formatter->convert(value);
|
||||||
QVERIFY(output.contains('e'));
|
QVERIFY(output.contains('e'));
|
||||||
|
|
||||||
@ -98,12 +99,12 @@ void TestAWFloatFormatter::test_format()
|
|||||||
void TestAWFloatFormatter::test_precision()
|
void TestAWFloatFormatter::test_precision()
|
||||||
{
|
{
|
||||||
// assign
|
// assign
|
||||||
int precision = 1 + rand() % 5;
|
int precision = 1 + AWTestLibrary::randomInt(5);
|
||||||
formatter->setPrecision(precision);
|
formatter->setPrecision(precision);
|
||||||
QCOMPARE(formatter->precision(), precision);
|
QCOMPARE(formatter->precision(), precision);
|
||||||
|
|
||||||
// test
|
// test
|
||||||
float value = getValue();
|
double value = AWTestLibrary::randomDouble();
|
||||||
QString output = formatter->convert(value);
|
QString output = formatter->convert(value);
|
||||||
output.remove(QString("0."));
|
output.remove(QString("0."));
|
||||||
QCOMPARE(output.count(), precision);
|
QCOMPARE(output.count(), precision);
|
||||||
@ -118,13 +119,14 @@ void TestAWFloatFormatter::test_multiplier()
|
|||||||
formatter->setPrecision(6);
|
formatter->setPrecision(6);
|
||||||
|
|
||||||
// assign
|
// assign
|
||||||
double multiplier = getValue();
|
double multiplier = AWTestLibrary::randomDouble();
|
||||||
formatter->setMultiplier(multiplier);
|
formatter->setMultiplier(multiplier);
|
||||||
QCOMPARE(formatter->multiplier(), multiplier);
|
QCOMPARE(formatter->multiplier(), multiplier);
|
||||||
|
|
||||||
// test
|
// test
|
||||||
double value = getValue();
|
double value = AWTestLibrary::randomDouble();
|
||||||
QCOMPARE(formatter->convert(value), QString::number(value * multiplier, 'f', 6));
|
QCOMPARE(formatter->convert(value),
|
||||||
|
QString::number(value * multiplier, 'f', 6));
|
||||||
|
|
||||||
// reset
|
// reset
|
||||||
formatter->setMultiplier(1.0);
|
formatter->setMultiplier(1.0);
|
||||||
@ -134,13 +136,14 @@ void TestAWFloatFormatter::test_multiplier()
|
|||||||
void TestAWFloatFormatter::test_summand()
|
void TestAWFloatFormatter::test_summand()
|
||||||
{
|
{
|
||||||
// assign
|
// assign
|
||||||
double summand = getValue();
|
double summand = AWTestLibrary::randomDouble();
|
||||||
formatter->setSummand(summand);
|
formatter->setSummand(summand);
|
||||||
QCOMPARE(formatter->summand(), summand);
|
QCOMPARE(formatter->summand(), summand);
|
||||||
|
|
||||||
// test
|
// test
|
||||||
double value = getValue();
|
double value = AWTestLibrary::randomDouble();
|
||||||
QCOMPARE(formatter->convert(value), QString::number(value + summand, 'f', 6));
|
QCOMPARE(formatter->convert(value),
|
||||||
|
QString::number(value + summand, 'f', 6));
|
||||||
|
|
||||||
// reset
|
// reset
|
||||||
formatter->setSummand(1.0);
|
formatter->setSummand(1.0);
|
||||||
@ -166,18 +169,12 @@ void TestAWFloatFormatter::test_copy()
|
|||||||
|
|
||||||
void TestAWFloatFormatter::doRandom()
|
void TestAWFloatFormatter::doRandom()
|
||||||
{
|
{
|
||||||
formatter->setCount(rand() % 100);
|
formatter->setCount(AWTestLibrary::randomInt());
|
||||||
formatter->setFillChar(QChar('A' + (rand() % static_cast<int>('Z' - 'A'))));
|
formatter->setFillChar(QChar(AWTestLibrary::randomChar()));
|
||||||
formatter->setFormat('A' + (rand() % static_cast<int>('Z' - 'A')));
|
formatter->setFormat(AWTestLibrary::randomChar());
|
||||||
formatter->setMultiplier(getValue());
|
formatter->setMultiplier(AWTestLibrary::randomDouble());
|
||||||
formatter->setPrecision(rand() % 100);
|
formatter->setPrecision(AWTestLibrary::randomInt());
|
||||||
formatter->setSummand(getValue());
|
formatter->setSummand(AWTestLibrary::randomDouble());
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
float TestAWFloatFormatter::getValue() const
|
|
||||||
{
|
|
||||||
return static_cast<float>(rand()) / static_cast<float>(RAND_MAX);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -45,7 +45,6 @@ private slots:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
void doRandom();
|
void doRandom();
|
||||||
float getValue() const;
|
|
||||||
AWFloatFormatter *formatter = nullptr;
|
AWFloatFormatter *formatter = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include <QtTest>
|
#include <QtTest>
|
||||||
|
|
||||||
|
#include "awtestlibrary.h"
|
||||||
#include "awnoformatter.h"
|
#include "awnoformatter.h"
|
||||||
|
|
||||||
|
|
||||||
@ -43,12 +44,12 @@ void TestAWNoFormatter::test_values()
|
|||||||
void TestAWNoFormatter::test_conversion()
|
void TestAWNoFormatter::test_conversion()
|
||||||
{
|
{
|
||||||
// integer
|
// integer
|
||||||
int randomInt = rand();
|
int randomInt = AWTestLibrary::randomInt();
|
||||||
QCOMPARE(formatter->convert(randomInt), QString::number(randomInt));
|
QCOMPARE(formatter->convert(randomInt), QString::number(randomInt));
|
||||||
// float
|
// float
|
||||||
QWARN("Float conversion isn't tested here due to possible rounding errors");
|
QWARN("Float conversion isn't tested here due to possible rounding errors");
|
||||||
// string
|
// string
|
||||||
QString randomString = generateRandomString();
|
QString randomString = AWTestLibrary::randomString();
|
||||||
QCOMPARE(formatter->convert(randomString), randomString);
|
QCOMPARE(formatter->convert(randomString), randomString);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -63,19 +64,4 @@ void TestAWNoFormatter::test_copy()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
QString TestAWNoFormatter::generateRandomString()
|
|
||||||
{
|
|
||||||
QString string;
|
|
||||||
|
|
||||||
int diff = 'Z' - 'A';
|
|
||||||
int count = rand() % 100 + 1;
|
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
char c = 'A' + (rand() % diff);
|
|
||||||
string += QChar(c);
|
|
||||||
}
|
|
||||||
|
|
||||||
return string;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
QTEST_MAIN(TestAWNoFormatter);
|
QTEST_MAIN(TestAWNoFormatter);
|
||||||
|
@ -39,7 +39,6 @@ private slots:
|
|||||||
void test_copy();
|
void test_copy();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString generateRandomString();
|
|
||||||
AWNoFormatter *formatter = nullptr;
|
AWNoFormatter *formatter = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user