2022-10-19 16:42:08 +00:00
|
|
|
// This file Copyright (C) 2013-2022 Mnemosyne LLC.
|
|
|
|
// It may be used under GPLv2 (SPDX: GPL-2.0-only), GPLv3 (SPDX: GPL-3.0-only),
|
|
|
|
// or any future license endorsed by Mnemosyne LLC.
|
|
|
|
// License text can be found in the licenses/ folder.
|
|
|
|
|
2023-01-02 16:23:51 +00:00
|
|
|
#include <libtransmission/transmission.h>
|
2022-10-19 16:42:08 +00:00
|
|
|
|
2023-01-02 16:23:51 +00:00
|
|
|
#include <libtransmission/tr-buffer.h>
|
2022-10-19 16:42:08 +00:00
|
|
|
|
|
|
|
#include "test-fixtures.h"
|
|
|
|
|
|
|
|
using BufferTest = ::testing::Test;
|
|
|
|
using namespace std::literals;
|
|
|
|
using Buffer = libtransmission::Buffer;
|
|
|
|
|
|
|
|
TEST_F(BufferTest, startsWithInSingleSegment)
|
|
|
|
{
|
|
|
|
auto constexpr Hello = "Hello, "sv;
|
|
|
|
auto constexpr World = "World"sv;
|
|
|
|
auto constexpr Bang = "!"sv;
|
|
|
|
|
|
|
|
auto buf = Buffer{};
|
|
|
|
buf.add(Hello);
|
2023-01-28 02:12:09 +00:00
|
|
|
EXPECT_TRUE(buf.starts_with(Hello));
|
2022-10-19 16:42:08 +00:00
|
|
|
|
|
|
|
buf.add(World);
|
2023-01-28 02:12:09 +00:00
|
|
|
EXPECT_TRUE(buf.starts_with(Hello));
|
|
|
|
EXPECT_TRUE(buf.starts_with("Hello, Worl"sv));
|
|
|
|
EXPECT_TRUE(buf.starts_with("Hello, World"sv));
|
|
|
|
EXPECT_FALSE(buf.starts_with("Hello, World!"sv));
|
|
|
|
EXPECT_FALSE(buf.starts_with("Hello!"sv));
|
2022-10-19 16:42:08 +00:00
|
|
|
|
|
|
|
buf.add(Bang);
|
2023-01-28 02:12:09 +00:00
|
|
|
EXPECT_FALSE(buf.starts_with("Hello!"));
|
|
|
|
EXPECT_TRUE(buf.starts_with(Hello));
|
|
|
|
EXPECT_TRUE(buf.starts_with("Hello, Worl"sv));
|
|
|
|
EXPECT_TRUE(buf.starts_with("Hello, World"sv));
|
|
|
|
EXPECT_TRUE(buf.starts_with("Hello, World!"sv));
|
2022-10-19 16:42:08 +00:00
|
|
|
}
|
|
|
|
TEST_F(BufferTest, startsWithInMultiSegment)
|
|
|
|
{
|
|
|
|
auto constexpr Hello = "Hello, "sv;
|
|
|
|
auto constexpr World = "World"sv;
|
|
|
|
auto constexpr Bang = "!"sv;
|
|
|
|
|
|
|
|
auto buf = std::make_unique<Buffer>();
|
|
|
|
buf->add(Buffer{ Hello });
|
2023-01-28 02:12:09 +00:00
|
|
|
EXPECT_TRUE(buf->starts_with(Hello));
|
2022-10-19 16:42:08 +00:00
|
|
|
|
|
|
|
buf->add(Buffer{ World });
|
2023-01-28 02:12:09 +00:00
|
|
|
EXPECT_TRUE(buf->starts_with(Hello));
|
|
|
|
EXPECT_TRUE(buf->starts_with("Hello, Worl"sv));
|
|
|
|
EXPECT_TRUE(buf->starts_with("Hello, World"sv));
|
|
|
|
EXPECT_FALSE(buf->starts_with("Hello, World!"sv));
|
|
|
|
EXPECT_FALSE(buf->starts_with("Hello!"sv));
|
2022-10-19 16:42:08 +00:00
|
|
|
|
|
|
|
buf->add(Buffer{ Bang });
|
2023-01-28 02:12:09 +00:00
|
|
|
EXPECT_FALSE(buf->starts_with("Hello!"));
|
|
|
|
EXPECT_TRUE(buf->starts_with(Hello));
|
|
|
|
EXPECT_TRUE(buf->starts_with("Hello, Worl"sv));
|
|
|
|
EXPECT_TRUE(buf->starts_with("Hello, World"sv));
|
|
|
|
EXPECT_TRUE(buf->starts_with("Hello, World!"sv));
|
2022-10-19 16:42:08 +00:00
|
|
|
}
|
2023-04-14 22:08:01 +00:00
|
|
|
|
2023-04-22 21:10:09 +00:00
|
|
|
TEST_F(BufferTest, Move)
|
|
|
|
{
|
|
|
|
auto constexpr TwoChars = "12"sv;
|
|
|
|
auto constexpr SixChars = "123456"sv;
|
|
|
|
auto constexpr TenChars = "1234567890"sv;
|
|
|
|
|
|
|
|
auto a = Buffer{ TwoChars };
|
|
|
|
auto b = Buffer{ SixChars };
|
|
|
|
auto c = Buffer{ TenChars };
|
|
|
|
|
|
|
|
auto lens = std::array<size_t, 3>{ std::size(TwoChars), std::size(SixChars), std::size(TenChars) };
|
|
|
|
|
|
|
|
EXPECT_EQ(lens[0], std::size(a));
|
|
|
|
EXPECT_EQ(lens[1], std::size(b));
|
|
|
|
EXPECT_EQ(lens[2], std::size(c));
|
|
|
|
|
|
|
|
std::swap(a, b);
|
|
|
|
EXPECT_EQ(lens[0], std::size(b));
|
|
|
|
EXPECT_EQ(lens[1], std::size(a));
|
|
|
|
EXPECT_EQ(lens[2], std::size(c));
|
|
|
|
|
|
|
|
std::swap(a, c);
|
|
|
|
EXPECT_EQ(lens[0], std::size(b));
|
|
|
|
EXPECT_EQ(lens[1], std::size(c));
|
|
|
|
EXPECT_EQ(lens[2], std::size(a));
|
|
|
|
|
|
|
|
std::swap(b, c);
|
|
|
|
EXPECT_EQ(lens[0], std::size(c));
|
|
|
|
EXPECT_EQ(lens[1], std::size(b));
|
|
|
|
EXPECT_EQ(lens[2], std::size(a));
|
|
|
|
|
|
|
|
a.add(std::data(TwoChars), std::size(TwoChars));
|
|
|
|
|
|
|
|
{
|
|
|
|
auto constexpr OneChar = "1"sv;
|
|
|
|
auto d = Buffer{ OneChar };
|
|
|
|
|
|
|
|
std::swap(a, d);
|
|
|
|
EXPECT_EQ(1U, std::size(a));
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_EQ(1U, std::size(a));
|
|
|
|
a.add(std::data(TwoChars), std::size(TwoChars));
|
|
|
|
EXPECT_EQ(3U, std::size(a));
|
|
|
|
}
|
|
|
|
|
2023-05-17 02:46:41 +00:00
|
|
|
TEST_F(BufferTest, Numbers)
|
|
|
|
{
|
|
|
|
for (auto i = 0; i < 100; ++i)
|
|
|
|
{
|
|
|
|
auto const expected_u8 = tr_rand_obj<uint8_t>();
|
|
|
|
auto const expected_u16 = tr_rand_obj<uint16_t>();
|
|
|
|
auto const expected_u32 = tr_rand_obj<uint32_t>();
|
|
|
|
auto const expected_u64 = tr_rand_obj<uint64_t>();
|
|
|
|
|
|
|
|
auto buf = Buffer{};
|
|
|
|
|
|
|
|
buf.add_uint8(expected_u8);
|
|
|
|
buf.add_uint16(expected_u16);
|
|
|
|
buf.add_uint32(expected_u32);
|
|
|
|
buf.add_uint64(expected_u64);
|
|
|
|
|
|
|
|
EXPECT_EQ(expected_u8, buf.to_uint8());
|
|
|
|
EXPECT_EQ(expected_u16, buf.to_uint16());
|
|
|
|
EXPECT_EQ(expected_u32, buf.to_uint32());
|
|
|
|
EXPECT_EQ(expected_u64, buf.to_uint64());
|
|
|
|
|
|
|
|
buf.add_uint64(expected_u64);
|
|
|
|
buf.add_uint32(expected_u32);
|
|
|
|
buf.add_uint16(expected_u16);
|
|
|
|
buf.add_uint8(expected_u8);
|
|
|
|
|
|
|
|
EXPECT_EQ(expected_u64, buf.to_uint64());
|
|
|
|
EXPECT_EQ(expected_u32, buf.to_uint32());
|
|
|
|
EXPECT_EQ(expected_u16, buf.to_uint16());
|
|
|
|
EXPECT_EQ(expected_u8, buf.to_uint8());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#if 0
|
2023-04-14 22:08:01 +00:00
|
|
|
TEST_F(BufferTest, NonBufferWriter)
|
|
|
|
{
|
|
|
|
auto constexpr Hello = "Hello, "sv;
|
|
|
|
auto constexpr World = "World"sv;
|
|
|
|
auto constexpr Bang = "!"sv;
|
|
|
|
|
|
|
|
auto out1 = Buffer{};
|
|
|
|
|
|
|
|
auto out2_vec = std::vector<std::byte>{};
|
|
|
|
auto out2 = libtransmission::BufferWriter<std::vector<std::byte>, std::byte>{ &out2_vec };
|
|
|
|
|
|
|
|
out1.add_uint8(1);
|
|
|
|
out2.add_uint8(1);
|
|
|
|
|
|
|
|
out1.add_uint16(1);
|
|
|
|
out2.add_uint16(1);
|
|
|
|
|
|
|
|
out1.add_uint32(1);
|
|
|
|
out2.add_uint32(1);
|
|
|
|
|
|
|
|
out1.add(Hello);
|
|
|
|
out2.add(Hello);
|
|
|
|
|
|
|
|
out1.add(World);
|
|
|
|
out2.add(World);
|
|
|
|
|
|
|
|
out1.add(Bang);
|
|
|
|
out2.add(Bang);
|
|
|
|
|
2023-05-17 02:46:41 +00:00
|
|
|
auto const result1 = out1.to_string_view();
|
2023-04-14 22:08:01 +00:00
|
|
|
auto const result2 = std::string_view{ reinterpret_cast<char const*>(std::data(out2_vec)), std::size(out2_vec) };
|
|
|
|
EXPECT_EQ(result1, result2);
|
|
|
|
}
|
2023-05-17 02:46:41 +00:00
|
|
|
#endif
|