#include "Data/ArrayData.h" #include #include class TestOneDimArrayData : public QObject { Q_OBJECT private slots: /// Tests @sa ArrayData::data() void testData_data(); void testData(); /// Tests @sa ArrayData::data(int componentIndex) void testDataByComponentIndex_data(); void testDataByComponentIndex(); /// Tests @sa ArrayData::add() void testAdd_data(); void testAdd(); /// Tests @sa ArrayData::at(int index) void testAt_data(); void testAt(); /// Tests @sa ArrayData::clear() void testClear_data(); void testClear(); /// Tests @sa ArrayData::size() void testSize_data(); void testSize(); /// Tests @sa ArrayData::sort() void testSort_data(); void testSort(); }; void TestOneDimArrayData::testData_data() { // Test structure QTest::addColumn >("inputData"); // array's data input QTest::addColumn >("expectedData"); // expected data // Test cases QTest::newRow("data1") << QVector{1., 2., 3., 4., 5.} << QVector{1., 2., 3., 4., 5.}; } void TestOneDimArrayData::testData() { QFETCH(QVector, inputData); QFETCH(QVector, expectedData); ArrayData<1> arrayData{inputData}; QVERIFY(arrayData.data() == expectedData); } void TestOneDimArrayData::testDataByComponentIndex_data() { // Test structure QTest::addColumn >("inputData"); // array data's input QTest::addColumn("componentIndex"); // component index to test QTest::addColumn >("expectedData"); // expected data // Test cases QTest::newRow("validIndex") << QVector{1., 2., 3., 4., 5.} << 0 << QVector{1., 2., 3., 4., 5.}; QTest::newRow("invalidIndex1") << QVector{1., 2., 3., 4., 5.} << -1 << QVector{}; QTest::newRow("invalidIndex2") << QVector{1., 2., 3., 4., 5.} << 1 << QVector{}; } void TestOneDimArrayData::testDataByComponentIndex() { QFETCH(QVector, inputData); QFETCH(int, componentIndex); QFETCH(QVector, expectedData); ArrayData<1> arrayData{inputData}; QVERIFY(arrayData.data(componentIndex) == expectedData); } void TestOneDimArrayData::testAdd_data() { // Test structure QTest::addColumn >("inputData"); // array's data input QTest::addColumn >("otherData"); // array data's input to merge with QTest::addColumn("prepend"); // prepend or append merge QTest::addColumn >("expectedData"); // expected data after merge // Test cases QTest::newRow("appendMerge") << QVector{1., 2., 3., 4., 5.} << QVector{6., 7., 8.} << false << QVector{1., 2., 3., 4., 5., 6., 7., 8.}; QTest::newRow("prependMerge") << QVector{1., 2., 3., 4., 5.} << QVector{6., 7., 8.} << true << QVector{6., 7., 8., 1., 2., 3., 4., 5.}; } void TestOneDimArrayData::testAdd() { QFETCH(QVector, inputData); QFETCH(QVector, otherData); QFETCH(bool, prepend); QFETCH(QVector, expectedData); ArrayData<1> arrayData{inputData}; ArrayData<1> other{otherData}; arrayData.add(other, prepend); QVERIFY(arrayData.data() == expectedData); } void TestOneDimArrayData::testAt_data() { // Test structure QTest::addColumn >("inputData"); // array data's input QTest::addColumn("index"); // index to retrieve data QTest::addColumn("expectedData"); // expected data at index // Test cases QTest::newRow("data1") << QVector{1., 2., 3., 4., 5.} << 0 << 1.; QTest::newRow("data2") << QVector{1., 2., 3., 4., 5.} << 3 << 4.; } void TestOneDimArrayData::testAt() { QFETCH(QVector, inputData); QFETCH(int, index); QFETCH(double, expectedData); ArrayData<1> arrayData{inputData}; QVERIFY(arrayData.at(index) == expectedData); } void TestOneDimArrayData::testClear_data() { // Test structure QTest::addColumn >("inputData"); // array data's input // Test cases QTest::newRow("data1") << QVector{1., 2., 3., 4., 5.}; } void TestOneDimArrayData::testClear() { QFETCH(QVector, inputData); ArrayData<1> arrayData{inputData}; arrayData.clear(); QVERIFY(arrayData.data() == QVector{}); } void TestOneDimArrayData::testSize_data() { // Test structure QTest::addColumn >("inputData"); // array data's input QTest::addColumn("expectedSize"); // expected array data size // Test cases QTest::newRow("data1") << QVector{1., 2., 3., 4., 5.} << 5; } void TestOneDimArrayData::testSize() { QFETCH(QVector, inputData); QFETCH(int, expectedSize); ArrayData<1> arrayData{inputData}; QVERIFY(arrayData.size() == expectedSize); } void TestOneDimArrayData::testSort_data() { // Test structure QTest::addColumn >("inputData"); // array data's input QTest::addColumn >("sortPermutation"); // permutation used to sort data QTest::addColumn >("expectedData"); // expected data after sorting // Test cases QTest::newRow("data1") << QVector{1., 2., 3., 4., 5.} << std::vector{0, 2, 3, 1, 4} << QVector{1., 3., 4., 2., 5.}; QTest::newRow("data2") << QVector{1., 2., 3., 4., 5.} << std::vector{4, 1, 2, 3, 0} << QVector{5., 2., 3., 4., 1.}; } void TestOneDimArrayData::testSort() { QFETCH(QVector, inputData); QFETCH(std::vector, sortPermutation); QFETCH(QVector, expectedData); ArrayData<1> arrayData{inputData}; auto sortedArrayData = arrayData.sort(sortPermutation); QVERIFY(sortedArrayData != nullptr); QVERIFY(sortedArrayData->data() == expectedData); } QTEST_MAIN(TestOneDimArrayData) #include "TestOneDimArrayData.moc"