diff options
author | Devtools Arcadia <[email protected]> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <[email protected]> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /util/generic/mem_copy_ut.cpp |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'util/generic/mem_copy_ut.cpp')
-rw-r--r-- | util/generic/mem_copy_ut.cpp | 113 |
1 files changed, 113 insertions, 0 deletions
diff --git a/util/generic/mem_copy_ut.cpp b/util/generic/mem_copy_ut.cpp new file mode 100644 index 00000000000..8b55a11cf68 --- /dev/null +++ b/util/generic/mem_copy_ut.cpp @@ -0,0 +1,113 @@ +#include "mem_copy.h" + +#include <library/cpp/testing/unittest/registar.h> + +namespace { + class TAssignBCalled: public yexception { + }; + + struct TB { + inline TB& operator=(const TB&) { + throw TAssignBCalled(); + + return *this; + } + }; + + struct TC: public TB { + }; +} + +Y_DECLARE_PODTYPE(TB); + +Y_UNIT_TEST_SUITE(TestMemCopy) { + Y_UNIT_TEST(Test1) { + char buf[] = "123"; + char buf1[sizeof(buf)]; + + UNIT_ASSERT_EQUAL(MemCopy(buf1, buf, sizeof(buf)), buf1); + + for (size_t i = 0; i < sizeof(buf); ++i) { + UNIT_ASSERT_VALUES_EQUAL(buf[i], buf1[i]); + } + } + + static int x = 0; + + struct TA { + inline TA() { + X = ++x; + } + + int X; + }; + + Y_UNIT_TEST(Test2) { + x = 0; + + TA a1[5]; + TA a2[5]; + + UNIT_ASSERT_VALUES_EQUAL(a1[0].X, 1); + UNIT_ASSERT_VALUES_EQUAL(a2[0].X, 6); + + MemCopy(a2, a1, 5); + + for (size_t i = 0; i < 5; ++i) { + UNIT_ASSERT_VALUES_EQUAL(a1[i].X, a2[i].X); + } + } + + Y_UNIT_TEST(Test3) { + TB b1[5]; + TB b2[5]; + + MemCopy(b2, b1, 5); + } + + Y_UNIT_TEST(Test4) { + TC c1[5]; + TC c2[5]; + + UNIT_ASSERT_EXCEPTION(MemCopy(c2, c1, 5), TAssignBCalled); + } + + template <class T> + inline void FillX(T* b, T* e) { + int tmp = 0; + + while (b != e) { + (b++)->X = ++tmp; + } + } + + Y_UNIT_TEST(Test5) { + struct TD { + int X; + }; + + TD orig[50]; + + for (ssize_t i = -15; i < 15; ++i) { + TD* b = orig + 20; + TD* e = b + 10; + + FillX(b, e); + + TD* to = b + i; + + MemMove(to, b, e - b - 1); + + for (size_t j = 0; j < (e - b) - (size_t)1; ++j) { + UNIT_ASSERT_VALUES_EQUAL(to[j].X, j + 1); + } + } + } + + Y_UNIT_TEST(TestEmpty) { + char* tmp = nullptr; + + UNIT_ASSERT(MemCopy(tmp, tmp, 0) == nullptr); + UNIT_ASSERT(MemMove(tmp, tmp, 0) == nullptr); + } +} |