TestCosinusAcquisition.cpp
194 lines
| 7.6 KiB
| text/x-c
|
CppLexer
Alexandre Leroux
|
r742 | #include "CosinusProvider.h" | ||
Alexandre Leroux
|
r783 | #include "MockDefs.h" | ||
Alexandre Leroux
|
r742 | |||
Alexandre Leroux
|
r744 | #include <Data/DataProviderParameters.h> | ||
Alexandre Leroux
|
r743 | #include <Data/ScalarSeries.h> | ||
Alexandre Leroux
|
r742 | #include <SqpApplication.h> | ||
Alexandre Leroux
|
r744 | #include <Time/TimeController.h> | ||
#include <Variable/Variable.h> | ||||
#include <Variable/VariableController.h> | ||||
Alexandre Leroux
|
r742 | |||
#include <QObject> | ||||
#include <QtTest> | ||||
Alexandre Leroux
|
r743 | #include <cmath> | ||
#include <memory> | ||||
Alexandre Leroux
|
r742 | namespace { | ||
/// Path for the tests | ||||
const auto TESTS_RESOURCES_PATH = QFileInfo{ | ||||
QString{MOCKPLUGIN_TESTS_RESOURCES_DIR}, | ||||
"TestCosinusAcquisition"}.absoluteFilePath(); | ||||
Alexandre Leroux
|
r743 | /// Format of dates in data files | ||
const auto DATETIME_FORMAT = QStringLiteral("yyyy/MM/dd hh:mm:ss:zzz"); | ||||
Alexandre Leroux
|
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); | ||||
r808 | qInfo() << "candidateSize" << std::distance(candidate->cbegin(), candidate->cend()); | |||
qInfo() << "refSize" << std::distance(referenceIt.first, referenceIt.second); | ||||
Alexandre Leroux
|
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
|
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
|
r743 | // ////////////// // | ||
// Test structure // | ||||
// ////////////// // | ||||
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
|
r743 | QTest::addColumn<std::vector<SqpRange> >("operations"); // Acquisitions to make | ||
Alexandre Leroux
|
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") | ||||
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
|
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)}}; | ||||
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
|
r742 | } | ||
void TestCosinusAcquisition::testAcquisition() | ||||
{ | ||||
r808 | // Retrieves reference range | |||
QFETCH(SqpRange, referenceRange); | ||||
CosinusProvider referenceProvider{}; | ||||
auto dataSeries = referenceProvider.provideDataSeries( | ||||
referenceRange, {{COSINUS_TYPE_KEY, "scalar"}, {COSINUS_FREQUENCY_KEY, 100.}}); | ||||
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 | ||||
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( | ||||
"MMS", {{COSINUS_TYPE_KEY, "scalar"}, {COSINUS_FREQUENCY_KEY, 100.}}, provider); | ||||
QFETCH(int, operationDelay); | ||||
QTest::qWait(operationDelay); | ||||
validateVariable(variable, initialRange); | ||||
// 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 | ||||
sqpApp->variableController().onRequestDataLoading({variable}, operation, variable->range(), | ||||
true); | ||||
QTest::qWait(operationDelay); | ||||
validateVariable(variable, operation); | ||||
Alexandre Leroux
|
r743 | } | ||
r808 | ||||
for (const auto &operation : operations) { | ||||
// Asks request on the variable and waits during its execution | ||||
sqpApp->variableController().onRequestDataLoading({variable}, operation, variable->range(), | ||||
true); | ||||
Alexandre Leroux
|
r743 | } | ||
r808 | QTest::qWait(operationDelay); | |||
validateVariable(variable, operations.back()); | ||||
Alexandre Leroux
|
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" | ||||