|
11 | 11 | #include "core/util/include/util.hpp" |
12 | 12 | #include "seq/example/include/ops_seq.hpp" |
13 | 13 |
|
14 | | -TEST(nesterov_a_test_task_seq, test_matmul_50) { |
15 | | - constexpr size_t kCount = 50; |
16 | | - |
17 | | - // Create data |
18 | | - std::vector<int> in(kCount * kCount, 0); |
19 | | - |
20 | | - for (size_t i = 0; i < kCount; i++) { |
21 | | - in[(i * kCount) + i] = 1; |
| 14 | +class NesterovATestTaskSeq : public ::testing::TestWithParam<double> { |
| 15 | + protected: |
| 16 | + void SetUp() override { |
| 17 | + std::ifstream test_file(ppc::util::GetAbsolutePath("seq/example/data/test.txt")); |
| 18 | + ASSERT_TRUE(test_file.is_open()) << "Failed to open input file"; |
| 19 | + std::string line; |
| 20 | + std::getline(test_file, line); |
| 21 | + test_file.close(); |
| 22 | + base_count = std::stoi(line); |
22 | 23 | } |
23 | 24 |
|
24 | | - // Create Task |
25 | | - nesterov_a_test_task_seq::TestTaskSequential test_task_sequential(in); |
26 | | - ASSERT_EQ(test_task_sequential.Validation(), true); |
27 | | - test_task_sequential.PreProcessing(); |
28 | | - test_task_sequential.Run(); |
29 | | - test_task_sequential.PostProcessing(); |
30 | | - EXPECT_EQ(in, test_task_sequential.Get()); |
31 | | -} |
32 | | - |
33 | | -TEST(nesterov_a_test_task_seq, test_matmul_100_from_file) { |
34 | | - std::string line; |
35 | | - std::ifstream test_file(ppc::util::GetAbsolutePath("seq/example/data/test.txt")); |
36 | | - if (test_file.is_open()) { |
37 | | - getline(test_file, line); |
| 25 | + [[nodiscard]] size_t GetCount() const { |
| 26 | + return static_cast<size_t>(base_count * GetParam()); |
38 | 27 | } |
39 | | - test_file.close(); |
40 | 28 |
|
41 | | - const size_t count = std::stoi(line); |
| 29 | + int base_count = 0; |
| 30 | +}; |
42 | 31 |
|
43 | | - // Create data |
44 | | - std::vector<int> in(count * count, 0); |
| 32 | +TEST_P(NesterovATestTaskSeq, MatmulFromFile) { |
| 33 | + const size_t count = GetCount(); |
45 | 34 |
|
| 35 | + std::vector<int> in(count * count, 0); |
46 | 36 | for (size_t i = 0; i < count; i++) { |
47 | 37 | in[(i * count) + i] = 1; |
48 | 38 | } |
49 | 39 |
|
50 | | - // Create Task |
51 | 40 | nesterov_a_test_task_seq::TestTaskSequential test_task_sequential(in); |
52 | | - ASSERT_EQ(test_task_sequential.Validation(), true); |
| 41 | + ASSERT_TRUE(test_task_sequential.Validation()); |
53 | 42 | test_task_sequential.PreProcessing(); |
54 | 43 | test_task_sequential.Run(); |
55 | 44 | test_task_sequential.PostProcessing(); |
56 | 45 | EXPECT_EQ(in, test_task_sequential.Get()); |
57 | 46 | } |
| 47 | + |
| 48 | +INSTANTIATE_TEST_SUITE_P( |
| 49 | + FileMatrixTests, |
| 50 | + NesterovATestTaskSeq, |
| 51 | + ::testing::Values(0.5, 1.0)); |
0 commit comments