##// END OF EJS Templates
Modification of the testCosinusAcquisition to test with 2Millions point...
Modification of the testCosinusAcquisition to test with 2Millions point instead of 20 millions that could make failed tests on windows and on a debug mode

File last commit:

r1073:03df095ebc87
r1073:03df095ebc87
Show More
TestCosinusAcquisition.cpp
195 lines | 7.6 KiB | text/x-c | CppLexer
/ plugins / mockplugin / tests / TestCosinusAcquisition.cpp
Alexandre Leroux
Inits unit test
r742 #include "CosinusProvider.h"
Alexandre Leroux
Changes plugin products to integrate parametric frequencies
r783 #include "MockDefs.h"
Alexandre Leroux
Inits unit test
r742
Alexandre Leroux
Implements unit test (2)...
r744 #include <Data/DataProviderParameters.h>
Alexandre Leroux
Implements unit test (1)...
r743 #include <Data/ScalarSeries.h>
Alexandre Leroux
Inits unit test
r742 #include <SqpApplication.h>
Alexandre Leroux
Implements unit test (2)...
r744 #include <Time/TimeController.h>
#include <Variable/Variable.h>
#include <Variable/VariableController.h>
Alexandre Leroux
Inits unit test
r742
#include <QObject>
#include <QtTest>
Alexandre Leroux
Implements unit test (1)...
r743 #include <cmath>
#include <memory>
Alexandre Leroux
Inits unit test
r742 namespace {
/// Path for the tests
const auto TESTS_RESOURCES_PATH = QFileInfo{
QString{MOCKPLUGIN_TESTS_RESOURCES_DIR},
"TestCosinusAcquisition"}.absoluteFilePath();
Alexandre Leroux
Implements unit test (1)...
r743 /// Format of dates in data files
const auto DATETIME_FORMAT = QStringLiteral("yyyy/MM/dd hh:mm:ss:zzz");
Alexandre Leroux
Implements unit test (3)...
r745 /**
* Verifies that the data in the candidate series are identical to the data in the reference series
* in a specific range
* @param candidate the candidate data series
* @param range the range to check
* @param reference the reference data series
* @return true if the data of the candidate series and the reference series are identical in the
* range, false otherwise
*/
bool checkDataSeries(std::shared_ptr<IDataSeries> candidate, const SqpRange &range,
std::shared_ptr<IDataSeries> reference)
{
if (candidate == nullptr || reference == nullptr) {
return candidate == reference;
}
auto referenceIt = reference->xAxisRange(range.m_TStart, range.m_TEnd);
Improve cosinus tests with:...
r808 qInfo() << "candidateSize" << std::distance(candidate->cbegin(), candidate->cend());
qInfo() << "refSize" << std::distance(referenceIt.first, referenceIt.second);
Alexandre Leroux
Implements unit test (3)...
r745 return std::equal(candidate->cbegin(), candidate->cend(), referenceIt.first, referenceIt.second,
[](const auto &it1, const auto &it2) {
// - milliseconds precision for time
// - 1e-6 precision for value
return std::abs(it1.x() - it2.x()) < 1e-3
&& std::abs(it1.value() - it2.value()) < 1e-6;
});
}
Alexandre Leroux
Inits unit test
r742 } // namespace
/**
* @brief The TestCosinusAcquisition class tests acquisition in SciQlop (operations like zooms in,
* zooms out, pans) of data from CosinusProvider
* @sa CosinusProvider
*/
class TestCosinusAcquisition : public QObject {
Q_OBJECT
private slots:
/// Input data for @sa testAcquisition()
void testAcquisition_data();
void testAcquisition();
};
void TestCosinusAcquisition::testAcquisition_data()
{
Alexandre Leroux
Implements unit test (1)...
r743 // ////////////// //
// Test structure //
// ////////////// //
Improve cosinus tests with:...
r808 QTest::addColumn<SqpRange>("referenceRange"); // Range for generating reference series
QTest::addColumn<SqpRange>("initialRange"); // First acquisition
QTest::addColumn<int>("operationDelay"); // Acquisitions to make
Alexandre Leroux
Implements unit test (1)...
r743 QTest::addColumn<std::vector<SqpRange> >("operations"); // Acquisitions to make
Alexandre Leroux
Adds test case
r746
// ////////// //
// Test cases //
// ////////// //
auto dateTime = [](int year, int month, int day, int hours, int minutes, int seconds) {
return DateUtils::secondsSinceEpoch(
QDateTime{{year, month, day}, {hours, minutes, seconds}, Qt::UTC});
};
QTest::newRow("cosinus")
Improve cosinus tests with:...
r808 << SqpRange{dateTime(2017, 1, 1, 12, 0, 0), dateTime(2017, 1, 1, 13, 0, 0)}
<< SqpRange{dateTime(2017, 1, 1, 12, 30, 0), dateTime(2017, 1, 1, 12, 35, 1)} << 250
Alexandre Leroux
Adds test case
r746 << std::vector<SqpRange>{
// Pan (jump) left
SqpRange{dateTime(2017, 1, 1, 12, 45, 0), dateTime(2017, 1, 1, 12, 50, 0)},
// Pan (jump) right
SqpRange{dateTime(2017, 1, 1, 12, 15, 0), dateTime(2017, 1, 1, 12, 20, 0)},
// Pan (overlay) right
SqpRange{dateTime(2017, 1, 1, 12, 14, 0), dateTime(2017, 1, 1, 12, 19, 0)},
// Pan (overlay) left
SqpRange{dateTime(2017, 1, 1, 12, 15, 0), dateTime(2017, 1, 1, 12, 20, 0)},
// Pan (overlay) left
SqpRange{dateTime(2017, 1, 1, 12, 16, 0), dateTime(2017, 1, 1, 12, 21, 0)},
// Zoom in
SqpRange{dateTime(2017, 1, 1, 12, 17, 30), dateTime(2017, 1, 1, 12, 19, 30)},
// Zoom out
SqpRange{dateTime(2017, 1, 1, 12, 12, 30), dateTime(2017, 1, 1, 12, 24, 30)}};
Improve cosinus tests with:...
r808
QTest::newRow("cosinus_big")
<< SqpRange{dateTime(2017, 1, 1, 1, 0, 0), dateTime(2017, 1, 5, 13, 0, 0)}
<< SqpRange{dateTime(2017, 1, 2, 6, 30, 0), dateTime(2017, 1, 2, 18, 30, 0)} << 5000
<< std::vector<SqpRange>{
// Pan (jump) left
SqpRange{dateTime(2017, 1, 1, 13, 30, 0), dateTime(2017, 1, 1, 18, 30, 0)},
// Pan (jump) right
SqpRange{dateTime(2017, 1, 3, 4, 30, 0), dateTime(2017, 1, 3, 10, 30, 0)},
// Pan (overlay) right
SqpRange{dateTime(2017, 1, 3, 8, 30, 0), dateTime(2017, 1, 3, 12, 30, 0)},
// Pan (overlay) left
SqpRange{dateTime(2017, 1, 2, 8, 30, 0), dateTime(2017, 1, 3, 10, 30, 0)},
// Pan (overlay) left
SqpRange{dateTime(2017, 1, 1, 12, 30, 0), dateTime(2017, 1, 3, 5, 30, 0)},
// Zoom in
SqpRange{dateTime(2017, 1, 2, 2, 30, 0), dateTime(2017, 1, 2, 8, 30, 0)},
// Zoom out
SqpRange{dateTime(2017, 1, 1, 14, 30, 0), dateTime(2017, 1, 3, 12, 30, 0)}};
Alexandre Leroux
Inits unit test
r742 }
void TestCosinusAcquisition::testAcquisition()
{
Improve cosinus tests with:...
r808 // Retrieves reference range
QFETCH(SqpRange, referenceRange);
CosinusProvider referenceProvider{};
auto dataSeries = referenceProvider.provideDataSeries(
Modification of the testCosinusAcquisition to test with 2Millions point...
r1073 referenceRange, {{COSINUS_TYPE_KEY, "scalar"}, {COSINUS_FREQUENCY_KEY, 10.}});
Improve cosinus tests with:...
r808
auto end = dataSeries->cend() - 1;
qInfo() << dataSeries->nbPoints() << dataSeries->cbegin()->x() << end->x();
/// Lambda used to validate a variable at each step
auto validateVariable
= [dataSeries](std::shared_ptr<Variable> variable, const SqpRange &range) {
// Checks that the variable's range has changed
Modification of the test for the new vc request kernel
r826 qInfo() << "range vs expected range" << variable->range() << range;
Improve cosinus tests with:...
r808 QCOMPARE(variable->range(), range);
// Checks the variable's data series
QVERIFY(checkDataSeries(variable->dataSeries(), variable->cacheRange(), dataSeries));
};
// Creates variable
QFETCH(SqpRange, initialRange);
sqpApp->timeController().onTimeToUpdate(initialRange);
auto provider = std::make_shared<CosinusProvider>();
auto variable = sqpApp->variableController().createVariable(
Modification of the testCosinusAcquisition to test with 2Millions point...
r1073 "MMS", {{COSINUS_TYPE_KEY, "scalar"}, {COSINUS_FREQUENCY_KEY, 10.}}, provider);
Improve cosinus tests with:...
r808
Modification of the test for the new vc request kernel
r826
Improve cosinus tests with:...
r808 QFETCH(int, operationDelay);
QTest::qWait(operationDelay);
validateVariable(variable, initialRange);
Modification of the test for the new vc request kernel
r826 QTest::qWait(operationDelay);
Improve cosinus tests with:...
r808 // Makes operations on the variable
QFETCH(std::vector<SqpRange>, operations);
for (const auto &operation : operations) {
// Asks request on the variable and waits during its execution
Modification of the test for the new vc request kernel
r826 sqpApp->variableController().onRequestDataLoading({variable}, operation, false);
Improve cosinus tests with:...
r808
QTest::qWait(operationDelay);
validateVariable(variable, operation);
Alexandre Leroux
Implements unit test (1)...
r743 }
Improve cosinus tests with:...
r808
for (const auto &operation : operations) {
// Asks request on the variable and waits during its execution
Modification of the test for the new vc request kernel
r826 sqpApp->variableController().onRequestDataLoading({variable}, operation, false);
Alexandre Leroux
Implements unit test (1)...
r743 }
Improve cosinus tests with:...
r808 QTest::qWait(operationDelay);
validateVariable(variable, operations.back());
Alexandre Leroux
Inits unit test
r742 }
int main(int argc, char *argv[])
{
SqpApplication app{argc, argv};
app.setAttribute(Qt::AA_Use96Dpi, true);
TestCosinusAcquisition testObject{};
QTEST_SET_MAIN_SOURCE_PATH
return QTest::qExec(&testObject, argc, argv);
}
#include "TestCosinusAcquisition.moc"