#include #include using namespace DB; TEST(Common, PODArrayInsert) { std::string str = "test_string_abacaba"; PODArray chars; chars.insert(chars.end(), str.begin(), str.end()); EXPECT_EQ(str, std::string(chars.data(), chars.size())); std::string insert_in_the_middle = "insert_in_the_middle"; auto pos = str.size() / 2; str.insert(str.begin() + pos, insert_in_the_middle.begin(), insert_in_the_middle.end()); chars.insert(chars.begin() + pos, insert_in_the_middle.begin(), insert_in_the_middle.end()); EXPECT_EQ(str, std::string(chars.data(), chars.size())); std::string insert_with_resize; insert_with_resize.reserve(chars.capacity() * 2); char cur_char = 'a'; while (insert_with_resize.size() < insert_with_resize.capacity()) { insert_with_resize += cur_char; if (cur_char == 'z') cur_char = 'a'; else ++cur_char; } str.insert(str.begin(), insert_with_resize.begin(), insert_with_resize.end()); chars.insert(chars.begin(), insert_with_resize.begin(), insert_with_resize.end()); EXPECT_EQ(str, std::string(chars.data(), chars.size())); } TEST(Common, PODPushBackRawMany) { PODArray chars; chars.push_back_raw_many(5, "first"); EXPECT_EQ(std::string("first"), std::string(chars.data(), chars.size())); EXPECT_EQ(5, chars.size()); EXPECT_LE(chars.capacity() - chars.size(), 10); chars.push_back_raw_many(10, "0123456789"); EXPECT_EQ(15, chars.size()); EXPECT_EQ(std::string("first0123456789"), std::string(chars.data(), chars.size())); } TEST(Common, PODNoOverallocation) { /// Check that PaddedPODArray allocates for smaller number of elements than the power of two due to padding. /// NOTE: It's Ok to change these numbers if you will modify initial size or padding. PaddedPODArray chars; std::vector capacities; size_t prev_capacity = 0; for (size_t i = 0; i < 1000000; ++i) { chars.emplace_back(); if (chars.capacity() != prev_capacity) { prev_capacity = chars.capacity(); capacities.emplace_back(prev_capacity); } } EXPECT_EQ(capacities, (std::vector{4065, 8161, 16353, 32737, 65505, 131041, 262113, 524257, 1048545})); }