summaryrefslogtreecommitdiffstats
path: root/util/folder/path_ut.cpp
diff options
context:
space:
mode:
authordimdim11 <[email protected]>2023-06-08 19:08:24 +0300
committerdimdim11 <[email protected]>2023-06-08 19:08:24 +0300
commit8642bc755ab5b51752619694224388b2d247c737 (patch)
tree92308ad5dc9d264b67a817a6eb2ab83050a0d36e /util/folder/path_ut.cpp
parentbb56a84dcf62e1f592b6be5a8fbc8298ee9478b0 (diff)
Refactor and fix constructors TString as std::string
Fix move constructors when used std::string instead of TString
Diffstat (limited to 'util/folder/path_ut.cpp')
-rw-r--r--util/folder/path_ut.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/util/folder/path_ut.cpp b/util/folder/path_ut.cpp
index f06fec78ee6..3c0e875a078 100644
--- a/util/folder/path_ut.cpp
+++ b/util/folder/path_ut.cpp
@@ -830,4 +830,80 @@ Y_UNIT_TEST_SUITE(TFsPathTests) {
path1 = path2;
UNIT_ASSERT_VALUES_EQUAL(path1.PathSplit().at(1), "file_in_folder_2");
}
+
+ static constexpr TStringBuf a("a");
+ static constexpr TStringBuf b("b");
+ static constexpr TStringBuf c("c");
+ static constexpr size_t n = 64;
+ static const TString an(n, 'a');
+ static const TString bn(n, 'b');
+ static const TString cn(n, 'c');
+
+ Y_UNIT_TEST(TestCopySplitSSOSupport) {
+ TFsPath path1 = TFsPath(a) / TFsPath(b);
+ const auto& split1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(split1.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(0), a);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(1), b);
+ TFsPath path2(static_cast<const TFsPath&>(path1)); // copy constructor
+ const auto& split2 = path2.PathSplit();
+ path1 = TFsPath(c); // invalidate previous Path_ in path1
+ const auto& newsplit1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.size(), 1);
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.at(0), c);
+ UNIT_ASSERT_VALUES_EQUAL(split2.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(0), a);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(1), b);
+ }
+
+ Y_UNIT_TEST(TestMoveSplitSSOSupport) {
+ TFsPath path1 = TFsPath(a) / TFsPath(b);
+ const auto& split1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(split1.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(0), a);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(1), b);
+ TFsPath path2(std::move(path1)); // move constructor
+ const auto& split2 = path2.PathSplit();
+ path1 = TFsPath(c); // invalidate previous Path_ in path1
+ const auto& newsplit1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.size(), 1);
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.at(0), c);
+ UNIT_ASSERT_VALUES_EQUAL(split2.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(0), a);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(1), b);
+ }
+
+ Y_UNIT_TEST(TestCopySplitNoneSSO) {
+ TFsPath path1 = TFsPath(an) / TFsPath(bn);
+ const auto& split1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(split1.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(0), an);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(1), bn);
+ TFsPath path2(static_cast<const TFsPath&>(path1)); // copy constructor
+ const auto& split2 = path2.PathSplit();
+ path1 = TFsPath(cn); // invalidate previous Path_ in path1
+ const auto& newsplit1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.size(), 1);
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.at(0), cn);
+ UNIT_ASSERT_VALUES_EQUAL(split2.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(0), an);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(1), bn);
+ }
+
+ Y_UNIT_TEST(TestMoveSplitNoneSSO) {
+ TFsPath path1 = TFsPath(an) / TFsPath(bn);
+ const auto& split1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(split1.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(0), an);
+ UNIT_ASSERT_VALUES_EQUAL(split1.at(1), bn);
+ TFsPath path2(std::move(path1)); // move constructor
+ const auto& split2 = path2.PathSplit();
+ path1 = TFsPath(cn); // invalidate previous Path_ in path1
+ const auto& newsplit1 = path1.PathSplit();
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.size(), 1);
+ UNIT_ASSERT_VALUES_EQUAL(newsplit1.at(0), cn);
+ UNIT_ASSERT_VALUES_EQUAL(split2.size(), 2);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(0), an);
+ UNIT_ASSERT_VALUES_EQUAL(split2.at(1), bn);
+ }
}