/** * \file * \brief PDS HW2 tests * * \author * Christos Choutouridis AEM:8997 * */ #include #include // rand/srand #include // rand/srand #include "distsort.hpp" /* ================================== ascending ================================== */ /* * bool ascending(mpi_id_t node, size_t depth); */ TEST(TdistBubbletonic_UT, ascending_Bubbletonic_test1) { EXPECT_EQ(ascending(0, 0), true); EXPECT_EQ(ascending(1, 0), false); EXPECT_EQ(ascending(2, 0), true); EXPECT_EQ(ascending(3, 0), false); EXPECT_EQ(ascending(4, 0), true); EXPECT_EQ(ascending(5, 0), false); EXPECT_EQ(ascending(6, 0), true); EXPECT_EQ(ascending(7, 0), false); for (mpi_id_t node = 0 ; node < 256 ; ++node) { EXPECT_EQ(ascending(node, 7), ((node % 2) ? false : true) ); } } /* ================================== partner ================================== */ /* * mpi_id_t partner(mpi_id_t node, size_t step); * step = 0 */ TEST(TdistBubbletonic_UT, partner_Bubbletonic_test1) { size_t ts_step = 0; mpi_id_t ts_expected[] = {1, 0, 3, 2, 5, 4, 7, 6}; for (mpi_id_t node = 0 ; node < 8 ; ++node) { EXPECT_EQ(partner(node, ts_step), ts_expected[node]); } } /* * mpi_id_t partner(mpi_id_t node, size_t step); * step = 1 */ TEST(TdistBubbletonic_UT, partner_Bubbletonic_test2) { size_t ts_step = 1; mpi_id_t ts_expected[] = {(mpi_id_t)-1, 2, 1, 4, 3, 6, 5, 8}; for (mpi_id_t node = 0 ; node < 8 ; ++node) { EXPECT_EQ(partner(node, ts_step), ts_expected[node]); } } /* * mpi_id_t partner(mpi_id_t node, size_t step); * various steps */ TEST(TdistBubbletonic_UT, partner_Bubbletonic_test3) { mpi_id_t ts_even_expected[] = { 1, 0, 3, 2, 5, 4, 7, 6, 9, 8, 11, 10, 13, 12, 15, 14 }; mpi_id_t ts_odd_expected[] = { (mpi_id_t)-1, 2, 1, 4, 3, 6, 5, 8, 7, 10, 9, 12, 11, 14, 13, 16 }; for (size_t step = 0 ; step < 32 ; ++step) { if (step % 2) { for (mpi_id_t node = 0; node < 16; ++node) { EXPECT_EQ(partner(node, step), ts_odd_expected[node]); } } else { for (mpi_id_t node = 0; node < 16; ++node) { EXPECT_EQ(partner(node, step), ts_even_expected[node]); } } } } /* ================================== keepSmall ================================== */ /* * bool keepSmall(mpi_id_t node, mpi_id_t partner, size_t depth); * Throw check (Not assert - ASSERT_DEATH) */ TEST(TdistBubbletonic_UT, keepsmall_test1) { // node and partner must differ or else ... EXPECT_THROW(keepSmall(0, 0, 0), std::runtime_error); EXPECT_THROW(keepSmall(1, 1, 42), std::runtime_error); EXPECT_THROW(keepSmall(7, 7, 42), std::runtime_error); } /* * bool keepSmall(mpi_id_t node, mpi_id_t partner, size_t depth); */ TEST(TdistBubbletonic_UT, keepsmall_test2) { // Check various combinations EXPECT_EQ(keepSmall(0, 1, 42), true); EXPECT_EQ(keepSmall(0, 3, 42), true); EXPECT_EQ(keepSmall(2, 1, 42), false); EXPECT_EQ(keepSmall(7, 1, 42), false); EXPECT_EQ(keepSmall(0, 1, 42), true); EXPECT_EQ(keepSmall(7, 32, 42), true); EXPECT_EQ(keepSmall(7, 1, 42), false); EXPECT_EQ(keepSmall(4, 0, 42), false); EXPECT_EQ(keepSmall(4, 9, 42), true); } /* ================================== isActive ================================== */ /* * bool isActive(mpi_id_t node, size_t nodes); * Throw check */ TEST(TdistBubbletonic_UT, isActive_test1) { EXPECT_THROW(isActive(0, 0), std::runtime_error); EXPECT_THROW(isActive(0, static_cast(std::numeric_limits::max()) + 1), std::runtime_error); } /* * bool isActive(mpi_id_t node, size_t nodes); * Boundary 3 BVA */ TEST(TdistBubbletonic_UT, isActive_test2) { EXPECT_EQ(isActive(-1, 8), false); EXPECT_EQ(isActive(0, 8), true); EXPECT_EQ(isActive(1, 8), true); EXPECT_EQ(isActive(7, 8), true); EXPECT_EQ(isActive(8, 8), false); EXPECT_EQ(isActive(9, 8), false); } #if 0 TEST(TdistBubbletonic_UT, distBubbletonic_test1) { AllData_t ts_Data { ShadowedVec_t (8), ShadowedVec_t (8) }; std::srand(unsigned(std::time(nullptr))); for (auto& v : ts_Data) { std::generate(v.begin(), v.end(), std::rand); } distBubbletonic(2, ts_Data); auto max = std::numeric_limits::min(); for (auto& v : ts_Data) { EXPECT_EQ((max <= v[0]), true); EXPECT_EQ(std::is_sorted(v.begin(), v.end()), true); max = v.back(); } } TEST(TdistBubbletonic_UT, distBubbletonic_test2) { AllData_t ts_Data { ShadowedVec_t (8), ShadowedVec_t (8), ShadowedVec_t (8), ShadowedVec_t (8) }; std::srand(unsigned(std::time(nullptr))); for (auto& v : ts_Data) { std::generate(v.begin(), v.end(), std::rand); } distBubbletonic(4, ts_Data); auto max = std::numeric_limits::min(); for (auto& v : ts_Data) { EXPECT_EQ((max <= v[0]), true); EXPECT_EQ(std::is_sorted(v.begin(), v.end()), true); max = v.back(); } } TEST(TdistBubbletonic_UT, distBubbletonic_test3) { AllData_t ts_Data { ShadowedVec_t (32), ShadowedVec_t (32), ShadowedVec_t (32), ShadowedVec_t (32), ShadowedVec_t (32), ShadowedVec_t (32), ShadowedVec_t (32), ShadowedVec_t (32) }; std::srand(unsigned(std::time(nullptr))); for (auto& v : ts_Data) { std::generate(v.begin(), v.end(), std::rand); } distBubbletonic(8, ts_Data); auto max = std::numeric_limits::min(); for (auto& v : ts_Data) { EXPECT_EQ((max <= v[0]), true); EXPECT_EQ(std::is_sorted(v.begin(), v.end()), true); max = v.back(); } } #endif