@@ -0,0 +1,8 | |||
|
1 | #include "FuzzingDefs.h" | |
|
2 | ||
|
3 | const QString NB_MAX_OPERATIONS_PROPERTY = QStringLiteral("component"); | |
|
4 | const QString NB_MAX_VARIABLES_PROPERTY = QStringLiteral("nbMaxVariables"); | |
|
5 | const QString AVAILABLE_OPERATIONS_PROPERTY = QStringLiteral("availableOperations"); | |
|
6 | const QString MAX_RANGE_PROPERTY = QStringLiteral("maxRange"); | |
|
7 | const QString METADATA_POOL_PROPERTY = QStringLiteral("metadataPool"); | |
|
8 | const QString PROVIDER_PROPERTY = QStringLiteral("provider"); |
@@ -0,0 +1,38 | |||
|
1 | #ifndef SCIQLOP_FUZZINGDEFS_H | |
|
2 | #define SCIQLOP_FUZZINGDEFS_H | |
|
3 | ||
|
4 | #include <QString> | |
|
5 | #include <QVariantHash> | |
|
6 | ||
|
7 | // /////// // | |
|
8 | // Aliases // | |
|
9 | // /////// // | |
|
10 | ||
|
11 | using MetadataPool = std::vector<QVariantHash>; | |
|
12 | Q_DECLARE_METATYPE(MetadataPool) | |
|
13 | ||
|
14 | using Properties = QVariantHash; | |
|
15 | ||
|
16 | // ///////// // | |
|
17 | // Constants // | |
|
18 | // ///////// // | |
|
19 | ||
|
20 | /// Max number of operations to generate | |
|
21 | extern const QString NB_MAX_OPERATIONS_PROPERTY; | |
|
22 | ||
|
23 | /// Max number of variables to manipulate through operations | |
|
24 | extern const QString NB_MAX_VARIABLES_PROPERTY; | |
|
25 | ||
|
26 | /// Set of operations available for the test | |
|
27 | extern const QString AVAILABLE_OPERATIONS_PROPERTY; | |
|
28 | ||
|
29 | /// Max range that an operation can reach | |
|
30 | extern const QString MAX_RANGE_PROPERTY; | |
|
31 | ||
|
32 | /// Set of metadata that can be associated to a variable | |
|
33 | extern const QString METADATA_POOL_PROPERTY; | |
|
34 | ||
|
35 | /// Provider used to retrieve data | |
|
36 | extern const QString PROVIDER_PROPERTY; | |
|
37 | ||
|
38 | #endif // SCIQLOP_FUZZINGDEFS_H |
@@ -0,0 +1,74 | |||
|
1 | #include "FuzzingOperations.h" | |
|
2 | #include "FuzzingUtils.h" | |
|
3 | ||
|
4 | #include <Data/IDataProvider.h> | |
|
5 | ||
|
6 | #include <Variable/Variable.h> | |
|
7 | #include <Variable/VariableController.h> | |
|
8 | ||
|
9 | #include <QUuid> | |
|
10 | ||
|
11 | Q_LOGGING_CATEGORY(LOG_FuzzingOperations, "FuzzingOperations") | |
|
12 | ||
|
13 | namespace { | |
|
14 | ||
|
15 | struct CreateOperation : public IFuzzingOperation { | |
|
16 | bool canExecute(std::shared_ptr<Variable> variable) const override | |
|
17 | { | |
|
18 | // A variable can be created only if it doesn't exist yet | |
|
19 | return variable == nullptr; | |
|
20 | } | |
|
21 | ||
|
22 | void execute(std::shared_ptr<Variable> &variable, VariableController &variableController, | |
|
23 | const Properties &properties) const override | |
|
24 | { | |
|
25 | // Retrieves metadata pool from properties, and choose one of the metadata entries to | |
|
26 | // associate it with the variable | |
|
27 | auto metaDataPool = properties.value(METADATA_POOL_PROPERTY).value<MetadataPool>(); | |
|
28 | auto variableMetadata = RandomGenerator::instance().randomChoice(metaDataPool); | |
|
29 | ||
|
30 | // Retrieves provider | |
|
31 | auto variableProvider | |
|
32 | = properties.value(PROVIDER_PROPERTY).value<std::shared_ptr<IDataProvider> >(); | |
|
33 | ||
|
34 | auto variableName = QString{"Var_%1"}.arg(QUuid::createUuid().toString()); | |
|
35 | qCInfo(LOG_FuzzingOperations()) | |
|
36 | << "Creating variable" << variableName << "(metadata:" << variableMetadata << ")"; | |
|
37 | ||
|
38 | auto newVariable | |
|
39 | = variableController.createVariable(variableName, variableMetadata, variableProvider); | |
|
40 | std::swap(variable, newVariable); | |
|
41 | } | |
|
42 | }; | |
|
43 | ||
|
44 | struct UnknownOperation : public IFuzzingOperation { | |
|
45 | bool canExecute(std::shared_ptr<Variable> variable) const override | |
|
46 | { | |
|
47 | Q_UNUSED(variable); | |
|
48 | return false; | |
|
49 | } | |
|
50 | ||
|
51 | void execute(std::shared_ptr<Variable> &variable, VariableController &variableController, | |
|
52 | const Properties &properties) const override | |
|
53 | { | |
|
54 | Q_UNUSED(variable); | |
|
55 | Q_UNUSED(variableController); | |
|
56 | Q_UNUSED(properties); | |
|
57 | // Does nothing | |
|
58 | } | |
|
59 | }; | |
|
60 | ||
|
61 | } // namespace | |
|
62 | ||
|
63 | std::unique_ptr<IFuzzingOperation> FuzzingOperationFactory::create(FuzzingOperationType type) | |
|
64 | { | |
|
65 | switch (type) { | |
|
66 | case FuzzingOperationType::CREATE: | |
|
67 | return std::make_unique<CreateOperation>(); | |
|
68 | default: | |
|
69 | // Default case returns unknown operation | |
|
70 | break; | |
|
71 | } | |
|
72 | ||
|
73 | return std::make_unique<UnknownOperation>(); | |
|
74 | } |
@@ -0,0 +1,49 | |||
|
1 | #ifndef SCIQLOP_FUZZINGOPERATIONS_H | |
|
2 | #define SCIQLOP_FUZZINGOPERATIONS_H | |
|
3 | ||
|
4 | #include "FuzzingDefs.h" | |
|
5 | ||
|
6 | #include <memory> | |
|
7 | #include <set> | |
|
8 | ||
|
9 | #include <QLoggingCategory> | |
|
10 | #include <QMetaType> | |
|
11 | ||
|
12 | Q_DECLARE_LOGGING_CATEGORY(LOG_FuzzingOperations) | |
|
13 | ||
|
14 | class Variable; | |
|
15 | class VariableController; | |
|
16 | ||
|
17 | /** | |
|
18 | * Enumeration of types of existing fuzzing operations | |
|
19 | */ | |
|
20 | enum class FuzzingOperationType { CREATE }; | |
|
21 | ||
|
22 | /// Interface that represents an operation that can be executed during a fuzzing test | |
|
23 | struct IFuzzingOperation { | |
|
24 | virtual ~IFuzzingOperation() noexcept = default; | |
|
25 | ||
|
26 | /// Checks if the operation can be executed according to the current state of the variable | |
|
27 | /// passed in parameter | |
|
28 | virtual bool canExecute(std::shared_ptr<Variable> variable) const = 0; | |
|
29 | /// Executes the operation on the variable passed in parameter | |
|
30 | /// @param variable the variable on which to execute the operation | |
|
31 | /// @param variableController the controller associated to the operation | |
|
32 | /// @param properties properties that can be used to configure the operation | |
|
33 | /// @remarks variable is passed as a reference because, according to the operation, it can be | |
|
34 | /// modified (in/out parameter) | |
|
35 | virtual void execute(std::shared_ptr<Variable> &variable, | |
|
36 | VariableController &variableController, | |
|
37 | const Properties &properties = {}) const = 0; | |
|
38 | }; | |
|
39 | ||
|
40 | /// Factory of @sa IFuzzingOperation | |
|
41 | struct FuzzingOperationFactory { | |
|
42 | /// Creates a fuzzing operation from a type | |
|
43 | static std::unique_ptr<IFuzzingOperation> create(FuzzingOperationType type); | |
|
44 | }; | |
|
45 | ||
|
46 | using OperationsTypes = std::set<FuzzingOperationType>; | |
|
47 | Q_DECLARE_METATYPE(OperationsTypes) | |
|
48 | ||
|
49 | #endif // SCIQLOP_FUZZINGOPERATIONS_H |
@@ -0,0 +1,25 | |||
|
1 | #include "FuzzingUtils.h" | |
|
2 | ||
|
3 | RandomGenerator &RandomGenerator::instance() | |
|
4 | { | |
|
5 | static auto instance = RandomGenerator(); | |
|
6 | return instance; | |
|
7 | } | |
|
8 | ||
|
9 | double RandomGenerator::generateDouble(double min, double max) | |
|
10 | { | |
|
11 | std::uniform_real_distribution<double> dist{min, max}; | |
|
12 | return dist(m_Mt); | |
|
13 | } | |
|
14 | ||
|
15 | int RandomGenerator::generateInt(int min, int max) | |
|
16 | { | |
|
17 | std::uniform_int_distribution<int> dist{min, max}; | |
|
18 | return dist(m_Mt); | |
|
19 | } | |
|
20 | ||
|
21 | RandomGenerator::RandomGenerator() | |
|
22 | { | |
|
23 | std::random_device rd{}; | |
|
24 | m_Mt = std::mt19937{rd()}; | |
|
25 | } |
@@ -0,0 +1,41 | |||
|
1 | #ifndef SCIQLOP_FUZZINGUTILS_H | |
|
2 | #define SCIQLOP_FUZZINGUTILS_H | |
|
3 | ||
|
4 | #include <random> | |
|
5 | ||
|
6 | /** | |
|
7 | * Class that proposes random utility methods | |
|
8 | */ | |
|
9 | class RandomGenerator { | |
|
10 | public: | |
|
11 | /// @return the unique instance of the random generator | |
|
12 | static RandomGenerator &instance(); | |
|
13 | ||
|
14 | /// Generates a random double between [min, max] | |
|
15 | double generateDouble(double min, double max); | |
|
16 | /// Generates a random int between [min, max] | |
|
17 | int generateInt(int min, int max); | |
|
18 | ||
|
19 | /// Returns a random element among the elements of a container. If the container is empty, | |
|
20 | /// returns an element built by default | |
|
21 | template <typename T, typename ValueType = typename T::value_type> | |
|
22 | ValueType randomChoice(const T &container); | |
|
23 | ||
|
24 | private: | |
|
25 | std::mt19937 m_Mt; | |
|
26 | ||
|
27 | explicit RandomGenerator(); | |
|
28 | }; | |
|
29 | ||
|
30 | template <typename T, typename ValueType> | |
|
31 | ValueType RandomGenerator::randomChoice(const T &container) | |
|
32 | { | |
|
33 | if (container.empty()) { | |
|
34 | return ValueType{}; | |
|
35 | } | |
|
36 | ||
|
37 | auto randomIndex = generateInt(0, container.size() - 1); | |
|
38 | return container.at(randomIndex); | |
|
39 | } | |
|
40 | ||
|
41 | #endif // SCIQLOP_FUZZINGUTILS |
@@ -0,0 +1,241 | |||
|
1 | #include "FuzzingDefs.h" | |
|
2 | #include "FuzzingOperations.h" | |
|
3 | #include "FuzzingUtils.h" | |
|
4 | ||
|
5 | #include "AmdaProvider.h" | |
|
6 | ||
|
7 | #include <Network/NetworkController.h> | |
|
8 | #include <SqpApplication.h> | |
|
9 | #include <Time/TimeController.h> | |
|
10 | #include <Variable/VariableController.h> | |
|
11 | ||
|
12 | #include <QLoggingCategory> | |
|
13 | #include <QObject> | |
|
14 | #include <QtTest> | |
|
15 | ||
|
16 | #include <memory> | |
|
17 | ||
|
18 | Q_LOGGING_CATEGORY(LOG_TestAmdaFuzzing, "TestAmdaFuzzing") | |
|
19 | ||
|
20 | namespace { | |
|
21 | ||
|
22 | // /////// // | |
|
23 | // Aliases // | |
|
24 | // /////// // | |
|
25 | ||
|
26 | using VariableId = int; | |
|
27 | ||
|
28 | using VariableOperation = std::pair<VariableId, std::shared_ptr<IFuzzingOperation> >; | |
|
29 | using VariablesOperations = std::vector<VariableOperation>; | |
|
30 | ||
|
31 | using OperationsPool = std::set<std::shared_ptr<IFuzzingOperation> >; | |
|
32 | using VariablesPool = std::map<VariableId, std::shared_ptr<Variable> >; | |
|
33 | ||
|
34 | // ///////// // | |
|
35 | // Constants // | |
|
36 | // ///////// // | |
|
37 | ||
|
38 | // Defaults values used when the associated properties have not been set for the test | |
|
39 | const auto NB_MAX_OPERATIONS_DEFAULT_VALUE = 100; | |
|
40 | const auto NB_MAX_VARIABLES_DEFAULT_VALUE = 1; | |
|
41 | const auto AVAILABLE_OPERATIONS_DEFAULT_VALUE | |
|
42 | = QVariant::fromValue(OperationsTypes{FuzzingOperationType::CREATE}); | |
|
43 | ||
|
44 | // /////// // | |
|
45 | // Methods // | |
|
46 | // /////// // | |
|
47 | ||
|
48 | /// Goes through the variables pool and operations pool to determine the set of {variable/operation} | |
|
49 | /// pairs that are valid (i.e. operation that can be executed on variable) | |
|
50 | VariablesOperations availableOperations(const VariablesPool &variablesPool, | |
|
51 | const OperationsPool &operationsPool) | |
|
52 | { | |
|
53 | VariablesOperations result{}; | |
|
54 | ||
|
55 | for (const auto &variablesPoolEntry : variablesPool) { | |
|
56 | auto variableId = variablesPoolEntry.first; | |
|
57 | auto variable = variablesPoolEntry.second; | |
|
58 | ||
|
59 | for (const auto &operation : operationsPool) { | |
|
60 | // A pair is valid if the current operation can be executed on the current variable | |
|
61 | if (operation->canExecute(variable)) { | |
|
62 | result.push_back({variableId, operation}); | |
|
63 | } | |
|
64 | } | |
|
65 | } | |
|
66 | ||
|
67 | return result; | |
|
68 | } | |
|
69 | ||
|
70 | OperationsPool createOperationsPool(const OperationsTypes &types) | |
|
71 | { | |
|
72 | OperationsPool result{}; | |
|
73 | ||
|
74 | std::transform(types.cbegin(), types.cend(), std::inserter(result, result.end()), | |
|
75 | [](const auto &type) { return FuzzingOperationFactory::create(type); }); | |
|
76 | ||
|
77 | return result; | |
|
78 | } | |
|
79 | ||
|
80 | /** | |
|
81 | * Class to run random tests | |
|
82 | */ | |
|
83 | class FuzzingTest { | |
|
84 | public: | |
|
85 | explicit FuzzingTest(VariableController &variableController, Properties properties) | |
|
86 | : m_VariableController{variableController}, | |
|
87 | m_Properties{std::move(properties)}, | |
|
88 | m_VariablesPool{} | |
|
89 | { | |
|
90 | // Inits variables pool: at init, all variables are null | |
|
91 | for (auto variableId = 0; variableId < nbMaxVariables(); ++variableId) { | |
|
92 | m_VariablesPool[variableId] = nullptr; | |
|
93 | } | |
|
94 | } | |
|
95 | ||
|
96 | void execute() | |
|
97 | { | |
|
98 | qCInfo(LOG_TestAmdaFuzzing()) << "Running" << nbMaxOperations() << "operations on" | |
|
99 | << nbMaxVariables() << "variable(s)..."; | |
|
100 | ||
|
101 | auto canExecute = true; | |
|
102 | for (auto i = 0; i < nbMaxOperations() && canExecute; ++i) { | |
|
103 | // Retrieves all operations that can be executed in the current context | |
|
104 | auto variableOperations = availableOperations(m_VariablesPool, operationsPool()); | |
|
105 | ||
|
106 | canExecute = !variableOperations.empty(); | |
|
107 | if (canExecute) { | |
|
108 | // Of the operations available, chooses a random operation and executes it | |
|
109 | auto variableOperation | |
|
110 | = RandomGenerator::instance().randomChoice(variableOperations); | |
|
111 | ||
|
112 | auto variableId = variableOperation.first; | |
|
113 | auto variable = m_VariablesPool.at(variableId); | |
|
114 | auto fuzzingOperation = variableOperation.second; | |
|
115 | ||
|
116 | fuzzingOperation->execute(variable, m_VariableController, m_Properties); | |
|
117 | ||
|
118 | // Updates variable pool with the new state of the variable after operation | |
|
119 | m_VariablesPool[variableId] = variable; | |
|
120 | } | |
|
121 | else { | |
|
122 | qCInfo(LOG_TestAmdaFuzzing()) | |
|
123 | << "No more operations are available, the execution of the test will stop..."; | |
|
124 | } | |
|
125 | } | |
|
126 | ||
|
127 | qCInfo(LOG_TestAmdaFuzzing()) << "Execution of the test completed."; | |
|
128 | } | |
|
129 | ||
|
130 | private: | |
|
131 | int nbMaxOperations() const | |
|
132 | { | |
|
133 | static auto result | |
|
134 | = m_Properties.value(NB_MAX_OPERATIONS_PROPERTY, NB_MAX_OPERATIONS_DEFAULT_VALUE) | |
|
135 | .toInt(); | |
|
136 | return result; | |
|
137 | } | |
|
138 | ||
|
139 | int nbMaxVariables() const | |
|
140 | { | |
|
141 | static auto result | |
|
142 | = m_Properties.value(NB_MAX_VARIABLES_PROPERTY, NB_MAX_VARIABLES_DEFAULT_VALUE).toInt(); | |
|
143 | return result; | |
|
144 | } | |
|
145 | ||
|
146 | OperationsPool operationsPool() const | |
|
147 | { | |
|
148 | static auto result = createOperationsPool( | |
|
149 | m_Properties.value(AVAILABLE_OPERATIONS_PROPERTY, AVAILABLE_OPERATIONS_DEFAULT_VALUE) | |
|
150 | .value<OperationsTypes>()); | |
|
151 | return result; | |
|
152 | } | |
|
153 | ||
|
154 | VariableController &m_VariableController; | |
|
155 | Properties m_Properties; | |
|
156 | VariablesPool m_VariablesPool; | |
|
157 | }; | |
|
158 | ||
|
159 | } // namespace | |
|
160 | ||
|
161 | class TestAmdaFuzzing : public QObject { | |
|
162 | Q_OBJECT | |
|
163 | ||
|
164 | private slots: | |
|
165 | /// Input data for @sa testFuzzing() | |
|
166 | void testFuzzing_data(); | |
|
167 | void testFuzzing(); | |
|
168 | }; | |
|
169 | ||
|
170 | void TestAmdaFuzzing::testFuzzing_data() | |
|
171 | { | |
|
172 | // ////////////// // | |
|
173 | // Test structure // | |
|
174 | // ////////////// // | |
|
175 | ||
|
176 | QTest::addColumn<Properties>("properties"); // Properties for random test | |
|
177 | ||
|
178 | // ////////// // | |
|
179 | // Test cases // | |
|
180 | // ////////// // | |
|
181 | ||
|
182 | auto maxRange = SqpRange::fromDateTime({2017, 1, 1}, {0, 0}, {2017, 1, 5}, {0, 0}); | |
|
183 | MetadataPool metadataPool{{{"dataType", "vector"}, {"xml:id", "imf"}}}; | |
|
184 | ||
|
185 | // Note: we don't use auto here as we want to pass std::shared_ptr<IDataProvider> as is in the | |
|
186 | // QVariant | |
|
187 | std::shared_ptr<IDataProvider> provider = std::make_shared<AmdaProvider>(); | |
|
188 | ||
|
189 | QTest::newRow("fuzzingTest") << Properties{ | |
|
190 | {MAX_RANGE_PROPERTY, QVariant::fromValue(maxRange)}, | |
|
191 | {METADATA_POOL_PROPERTY, QVariant::fromValue(metadataPool)}, | |
|
192 | {PROVIDER_PROPERTY, QVariant::fromValue(provider)}}; | |
|
193 | } | |
|
194 | ||
|
195 | void TestAmdaFuzzing::testFuzzing() | |
|
196 | { | |
|
197 | QFETCH(Properties, properties); | |
|
198 | ||
|
199 | auto &variableController = sqpApp->variableController(); | |
|
200 | auto &timeController = sqpApp->timeController(); | |
|
201 | ||
|
202 | // Generates random initial range (bounded to max range) | |
|
203 | auto maxRange = properties.value(MAX_RANGE_PROPERTY, QVariant::fromValue(INVALID_RANGE)) | |
|
204 | .value<SqpRange>(); | |
|
205 | ||
|
206 | QVERIFY(maxRange != INVALID_RANGE); | |
|
207 | ||
|
208 | auto initialRangeStart | |
|
209 | = RandomGenerator::instance().generateDouble(maxRange.m_TStart, maxRange.m_TEnd); | |
|
210 | auto initialRangeEnd | |
|
211 | = RandomGenerator::instance().generateDouble(maxRange.m_TStart, maxRange.m_TEnd); | |
|
212 | if (initialRangeStart > initialRangeEnd) { | |
|
213 | std::swap(initialRangeStart, initialRangeEnd); | |
|
214 | } | |
|
215 | ||
|
216 | // Sets initial range on time controller | |
|
217 | SqpRange initialRange{initialRangeStart, initialRangeEnd}; | |
|
218 | qCInfo(LOG_TestAmdaFuzzing()) << "Setting initial range to" << initialRange << "..."; | |
|
219 | timeController.onTimeToUpdate(initialRange); | |
|
220 | ||
|
221 | FuzzingTest test{variableController, properties}; | |
|
222 | test.execute(); | |
|
223 | } | |
|
224 | ||
|
225 | int main(int argc, char *argv[]) | |
|
226 | { | |
|
227 | QLoggingCategory::setFilterRules( | |
|
228 | "*.warning=false\n" | |
|
229 | "*.info=false\n" | |
|
230 | "*.debug=false\n" | |
|
231 | "FuzzingOperations.info=true\n" | |
|
232 | "TestAmdaFuzzing.info=true\n"); | |
|
233 | ||
|
234 | SqpApplication app{argc, argv}; | |
|
235 | app.setAttribute(Qt::AA_Use96Dpi, true); | |
|
236 | TestAmdaFuzzing testObject{}; | |
|
237 | QTEST_SET_MAIN_SOURCE_PATH | |
|
238 | return QTest::qExec(&testObject, argc, argv); | |
|
239 | } | |
|
240 | ||
|
241 | #include "TestAmdaFuzzing.moc" |
@@ -14,6 +14,14 | |||
|
14 | 14 | * @brief The SqpRange struct holds the information of time parameters |
|
15 | 15 | */ |
|
16 | 16 | struct SqpRange { |
|
17 | /// Creates SqpRange from dates and times | |
|
18 | static SqpRange fromDateTime(const QDate &startDate, const QTime &startTime, | |
|
19 | const QDate &endDate, const QTime &endTime) | |
|
20 | { | |
|
21 | return {DateUtils::secondsSinceEpoch(QDateTime{startDate, startTime}), | |
|
22 | DateUtils::secondsSinceEpoch(QDateTime{endDate, endTime})}; | |
|
23 | } | |
|
24 | ||
|
17 | 25 | /// Start time (UTC) |
|
18 | 26 | double m_TStart; |
|
19 | 27 | /// End time (UTC) |
@@ -115,6 +115,7 IF(BUILD_TESTS) | |||
|
115 | 115 | ${testDirectory}/*.cpp |
|
116 | 116 | ${testDirectory}/*.h) |
|
117 | 117 | LIST (REMOVE_ITEM currentTestSources ${TESTS_SOURCES}) |
|
118 | LIST(APPEND testFilesToFormat ${currentTestSources}) | |
|
118 | 119 | # LIST (REMOVE_ITEM currentTestSources ${TESTS_HEADERS}) |
|
119 | 120 | |
|
120 | 121 | ADD_EXECUTABLE(${testName} ${testFile} ${currentTestSources}) |
@@ -62,7 +62,17 sciqlop_amdaplugin = library('amdaplugin', | |||
|
62 | 62 | tests = [ |
|
63 | 63 | [['tests/TestAmdaParser.cpp'],'test_amda_parser','AMDA parser test'], |
|
64 | 64 | [['tests/TestAmdaResultParser.cpp'],'test_amda_result_parser','AMDA result parser test'], |
|
65 | [['tests/TestAmdaAcquisition.cpp'],'test_amda_acquisition','AMDA Acquisition test'] | |
|
65 | [['tests/TestAmdaAcquisition.cpp'],'test_amda_acquisition','AMDA Acquisition test'], | |
|
66 | [['tests/TestAmdaFuzzing.cpp'],'test_amda_fuzzing','AMDA fuzzing test'] | |
|
67 | ] | |
|
68 | ||
|
69 | tests_sources = [ | |
|
70 | 'tests/FuzzingDefs.h', | |
|
71 | 'tests/FuzzingDefs.cpp', | |
|
72 | 'tests/FuzzingOperations.h', | |
|
73 | 'tests/FuzzingOperations.cpp', | |
|
74 | 'tests/FuzzingUtils.h', | |
|
75 | 'tests/FuzzingUtils.cpp' | |
|
66 | 76 | ] |
|
67 | 77 | |
|
68 | 78 | foreach unit_test : tests |
@@ -71,6 +81,7 foreach unit_test : tests | |||
|
71 | 81 | link_with : [sciqlop_amdaplugin], |
|
72 | 82 | include_directories : [amdaplugin_inc], |
|
73 | 83 | cpp_args : ['-DAMDA_TESTS_RESOURCES_DIR="'+meson.current_source_dir()+'/tests-resources"'], |
|
84 | sources : [tests_sources], | |
|
74 | 85 | dependencies : [sciqlop_core, sciqlop_gui, qt5test]) |
|
75 | 86 | test(unit_test[2], test_exe, args: ['-teamcity', '-o', '@0@.teamcity.txt'.format(unit_test[1])], timeout: 3 * 60) |
|
76 | 87 | endforeach |
General Comments 0
You need to be logged in to leave comments.
Login now