TestAmdaAcquisition.cpp
164 lines
| 5.9 KiB
| text/x-c
|
CppLexer
r590 | #include "AmdaProvider.h" | |||
#include "AmdaResultParser.h" | ||||
#include "SqpApplication.h" | ||||
#include <Data/DataSeries.h> | ||||
#include <Data/IDataSeries.h> | ||||
#include <Data/ScalarSeries.h> | ||||
#include <Time/TimeController.h> | ||||
#include <Variable/Variable.h> | ||||
#include <Variable/VariableController.h> | ||||
#include <QObject> | ||||
#include <QtTest> | ||||
#include <memory> | ||||
// TEST with REF: | ||||
// AmdaData-2012-01-01-12-00-00_2012-01-03-12-00-00 | ||||
// imf(0) - Type : Local Parameter @ CDPP/AMDA - | ||||
// Name : bx_gse - Units : nT - Size : 1 - | ||||
// Frame : GSE - Mission : ACE - | ||||
// Instrument : MFI - Dataset : mfi_final-prelim | ||||
// REFERENCE DOWNLOAD FILE = | ||||
r829 | // http://amdatest.irap.omp.eu/php/rest/getParameter.php?startTime=2012-01-01T12:00:00&stopTime=2012-01-03T12:00:00¶meterID=imf(0)&outputFormat=ASCII&timeFormat=ISO8601&gzip=0 | |||
r590 | ||||
namespace { | ||||
/// Path for the tests | ||||
const auto TESTS_RESOURCES_PATH | ||||
= QFileInfo{QString{AMDA_TESTS_RESOURCES_DIR}, "TestAmdaAcquisition"}.absoluteFilePath(); | ||||
r829 | /// Delay after each operation on the variable before validating it (in ms) | |||
const auto OPERATION_DELAY = 10000; | ||||
r590 | ||||
template <typename T> | ||||
bool compareDataSeries(std::shared_ptr<IDataSeries> candidate, SqpRange candidateCacheRange, | ||||
std::shared_ptr<IDataSeries> reference) | ||||
{ | ||||
auto compareLambda = [](const auto &it1, const auto &it2) { | ||||
return (it1.x() == it2.x()) && (it1.value() == it2.value()); | ||||
}; | ||||
auto candidateDS = std::dynamic_pointer_cast<T>(candidate); | ||||
auto referenceDS = std::dynamic_pointer_cast<T>(reference); | ||||
if (candidateDS && referenceDS) { | ||||
auto itRefs | ||||
Alexandre Leroux
|
r615 | = referenceDS->xAxisRange(candidateCacheRange.m_TStart, candidateCacheRange.m_TEnd); | ||
r590 | qDebug() << " DISTANCE" << std::distance(candidateDS->cbegin(), candidateDS->cend()) | |||
<< std::distance(itRefs.first, itRefs.second); | ||||
return std::equal(candidateDS->cbegin(), candidateDS->cend(), itRefs.first, itRefs.second, | ||||
compareLambda); | ||||
} | ||||
else { | ||||
return false; | ||||
} | ||||
} | ||||
} | ||||
class TestAmdaAcquisition : public QObject { | ||||
Q_OBJECT | ||||
private slots: | ||||
r829 | /// Input data for @sa testAcquisition() | |||
void testAcquisition_data(); | ||||
r590 | void testAcquisition(); | |||
}; | ||||
r829 | void TestAmdaAcquisition::testAcquisition_data() | |||
r590 | { | |||
r829 | // ////////////// // | |||
// Test structure // | ||||
// ////////////// // | ||||
r590 | ||||
r829 | QTest::addColumn<QString>("dataFilename"); // File containing expected data of acquisitions | |||
QTest::addColumn<SqpRange>("initialRange"); // First acquisition | ||||
QTest::addColumn<std::vector<SqpRange> >("operations"); // Acquisitions to make | ||||
r590 | ||||
r829 | // ////////// // | |||
// Test cases // | ||||
// ////////// // | ||||
r590 | ||||
r829 | 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}); | ||||
r590 | }; | |||
r829 | QTest::newRow("amda") | |||
<< "AmdaData-2012-01-01-12-00-00_2012-01-03-12-00-00.txt" | ||||
<< SqpRange{dateTime(2012, 1, 2, 2, 3, 0), dateTime(2012, 1, 2, 2, 4, 0)} | ||||
<< std::vector<SqpRange>{ | ||||
// 2 : pan (jump) left for two min | ||||
SqpRange{dateTime(2012, 1, 2, 2, 1, 0), dateTime(2012, 1, 2, 2, 2, 0)}, | ||||
// 3 : pan (jump) right for four min | ||||
SqpRange{dateTime(2012, 1, 2, 2, 5, 0), dateTime(2012, 1, 2, 2, 6, 0)}, | ||||
// 4 : pan (overlay) right for 30 sec | ||||
/*SqpRange{dateTime(2012, 1, 2, 2, 5, 30), dateTime(2012, 1, 2, 2, 6, 30)}, | ||||
// 5 : pan (overlay) left for 30 sec | ||||
SqpRange{dateTime(2012, 1, 2, 2, 5, 0), dateTime(2012, 1, 2, 2, 6, 0)}, | ||||
// 6 : pan (overlay) left for 30 sec - BIS | ||||
SqpRange{dateTime(2012, 1, 2, 2, 4, 30), dateTime(2012, 1, 2, 2, 5, 30)}, | ||||
// 7 : Zoom in Inside 20 sec range | ||||
SqpRange{dateTime(2012, 1, 2, 2, 4, 50), dateTime(2012, 1, 2, 2, 5, 10)}, | ||||
// 8 : Zoom out Inside 20 sec range | ||||
SqpRange{dateTime(2012, 1, 2, 2, 4, 30), dateTime(2012, 1, 2, 2, 5, 30)}*/}; | ||||
} | ||||
r590 | ||||
r829 | void TestAmdaAcquisition::testAcquisition() | |||
{ | ||||
/// @todo: update test to be compatible with AMDA v2 | ||||
r590 | ||||
r829 | // Retrieves data file | |||
QFETCH(QString, dataFilename); | ||||
auto filePath = QFileInfo{TESTS_RESOURCES_PATH, dataFilename}.absoluteFilePath(); | ||||
auto results = AmdaResultParser::readTxt(filePath, AmdaResultParser::ValueType::SCALAR); | ||||
r590 | ||||
r829 | /// Lambda used to validate a variable at each step | |||
auto validateVariable = [results](std::shared_ptr<Variable> variable, const SqpRange &range) { | ||||
// Checks that the variable's range has changed | ||||
qInfo() << tr("Compare var range vs range") << variable->range() << range; | ||||
QCOMPARE(variable->range(), range); | ||||
r590 | ||||
r829 | // Checks the variable's data series | |||
QVERIFY(compareDataSeries<ScalarSeries>(variable->dataSeries(), variable->cacheRange(), | ||||
results)); | ||||
qInfo() << "\n"; | ||||
}; | ||||
r590 | ||||
r829 | // Creates variable | |||
QFETCH(SqpRange, initialRange); | ||||
sqpApp->timeController().onTimeToUpdate(initialRange); | ||||
auto provider = std::make_shared<AmdaProvider>(); | ||||
auto variable = sqpApp->variableController().createVariable( | ||||
"bx_gse", {{"dataType", "scalar"}, {"xml:id", "imf(0)"}}, provider); | ||||
r590 | ||||
r829 | QTest::qWait(OPERATION_DELAY); | |||
validateVariable(variable, initialRange); | ||||
r590 | ||||
r829 | // 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, false); | ||||
r590 | ||||
r829 | QTest::qWait(OPERATION_DELAY); | |||
validateVariable(variable, operation); | ||||
} | ||||
r590 | } | |||
int main(int argc, char *argv[]) | ||||
{ | ||||
SqpApplication app(argc, argv); | ||||
app.setAttribute(Qt::AA_Use96Dpi, true); | ||||
TestAmdaAcquisition tc; | ||||
QTEST_SET_MAIN_SOURCE_PATH | ||||
return QTest::qExec(&tc, argc, argv); | ||||
} | ||||
// QTEST_MAIN(TestAmdaAcquisition) | ||||
#include "TestAmdaAcquisition.moc" | ||||