updated build system
All checks were successful
BlockStorage/repertory/pipeline/head This commit looks good

This commit is contained in:
2024-08-04 09:55:01 -05:00
parent 6d152181d3
commit 15cc7b0b87
6 changed files with 208 additions and 27 deletions

View File

@ -20,18 +20,47 @@
SOFTWARE.
*/
#include "gtest/gtest.h"
#include <utils/collection.hpp>
#include "utils/common.hpp"
namespace repertory {
TEST(utils_common, calculate_read_size) {
auto read_size = utils::calculate_read_size(0U, 0U, 0U);
EXPECT_EQ(0U, read_size);
read_size = utils::calculate_read_size(5U, 0U, 0U);
EXPECT_EQ(0U, read_size);
read_size = utils::calculate_read_size(0U, 6U, 7U);
EXPECT_EQ(0U, read_size);
read_size = utils::calculate_read_size(7U, 1U, 7U);
EXPECT_EQ(0U, read_size);
read_size = utils::calculate_read_size(5U, 5U, 0U);
EXPECT_EQ(5U, read_size);
read_size = utils::calculate_read_size(5U, 5U, 1U);
EXPECT_EQ(4U, read_size);
}
TEST(utils_common, version_equal) {
EXPECT_EQ(0, utils::compare_version_strings("", ""));
EXPECT_EQ(0, utils::compare_version_strings("1.0", "1.0"));
EXPECT_EQ(0, utils::compare_version_strings("1.0.0", "1.0"));
EXPECT_EQ(0, utils::compare_version_strings("1.0.0.0", "1.0"));
EXPECT_EQ(0, utils::compare_version_strings("1.0.0.0", "1.0.0"));
EXPECT_EQ(0, utils::compare_version_strings(L"", L""));
EXPECT_EQ(0, utils::compare_version_strings(L"1.0", L"1.0"));
EXPECT_EQ(0, utils::compare_version_strings(L"1.0.0", L"1.0"));
EXPECT_EQ(0, utils::compare_version_strings(L"1.0.0.0", L"1.0"));
EXPECT_EQ(0, utils::compare_version_strings(L"1.0.0.0", L"1.0.0"));
}
TEST(utils_common, version_greater) {
EXPECT_EQ(1, utils::compare_version_strings("1.0.1", ""));
EXPECT_EQ(1, utils::compare_version_strings("1.0.1", "1.0"));
EXPECT_EQ(1, utils::compare_version_strings("1.0.1", "1.0.0"));
EXPECT_EQ(1, utils::compare_version_strings("1.0.1", "1.0.0.0"));
@ -41,9 +70,21 @@ TEST(utils_common, version_greater) {
EXPECT_EQ(1, utils::compare_version_strings("1.0", "0.9.9"));
EXPECT_EQ(1, utils::compare_version_strings("1.0.1", "0.9.9"));
EXPECT_EQ(1, utils::compare_version_strings("1.0.1.0", "0.9.9"));
EXPECT_EQ(1, utils::compare_version_strings("1.0.1", ""));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1", L"1.0"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1", L"1.0.0"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1", L"1.0.0.0"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1.0", L"1.0"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1.0", L"1.0.0"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1.0", L"1.0.0.0"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0", L"0.9.9"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1", L"0.9.9"));
EXPECT_EQ(1, utils::compare_version_strings(L"1.0.1.0", L"0.9.9"));
}
TEST(utils_common, version_less) {
EXPECT_EQ(-1, utils::compare_version_strings("", "1.0"));
EXPECT_EQ(-1, utils::compare_version_strings("0.9.9", "1.0"));
EXPECT_EQ(-1, utils::compare_version_strings("0.9.9", "1.0.1"));
EXPECT_EQ(-1, utils::compare_version_strings("0.9.9", "1.0.1.0"));
@ -53,15 +94,94 @@ TEST(utils_common, version_less) {
EXPECT_EQ(-1, utils::compare_version_strings("1.0.0", "1.0.1.0"));
EXPECT_EQ(-1, utils::compare_version_strings("1.0.0.0", "1.0.1"));
EXPECT_EQ(-1, utils::compare_version_strings("1.0.0.0", "1.0.1.0"));
EXPECT_EQ(-1, utils::compare_version_strings(L"", L"1.0"));
EXPECT_EQ(-1, utils::compare_version_strings(L"0.9.9", L"1.0"));
EXPECT_EQ(-1, utils::compare_version_strings(L"0.9.9", L"1.0.1"));
EXPECT_EQ(-1, utils::compare_version_strings(L"0.9.9", L"1.0.1.0"));
EXPECT_EQ(-1, utils::compare_version_strings(L"1.0", L"1.0.1"));
EXPECT_EQ(-1, utils::compare_version_strings(L"1.0", L"1.0.1.0"));
EXPECT_EQ(-1, utils::compare_version_strings(L"1.0.0", L"1.0.1"));
EXPECT_EQ(-1, utils::compare_version_strings(L"1.0.0", L"1.0.1.0"));
EXPECT_EQ(-1, utils::compare_version_strings(L"1.0.0.0", L"1.0.1"));
EXPECT_EQ(-1, utils::compare_version_strings(L"1.0.0.0", L"1.0.1.0"));
}
#if defined(PROJECT_ENABLE_STDUUID)
TEST(utils_common, create_uuid_string) {
const auto uuid1 = utils::create_uuid_string();
const auto uuid2 = utils::create_uuid_string();
ASSERT_EQ(36U, uuid1.size());
ASSERT_EQ(36U, uuid2.size());
ASSERT_STRNE(uuid1.c_str(), uuid2.c_str());
{
const auto uuid1 = utils::create_uuid_string();
const auto uuid2 = utils::create_uuid_string();
ASSERT_EQ(36U, uuid1.size());
ASSERT_EQ(36U, uuid2.size());
ASSERT_STRNE(uuid1.c_str(), uuid2.c_str());
}
{
const auto uuid1 = utils::create_uuid_wstring();
const auto uuid2 = utils::create_uuid_wstring();
ASSERT_EQ(36U, uuid1.size());
ASSERT_EQ(36U, uuid2.size());
ASSERT_STRNE(uuid1.c_str(), uuid2.c_str());
}
}
#endif // defined(PROJECT_ENABLE_STDUUID)
#if defined(PROJECT_ENABLE_LIBSODIUM)
TEST(utils_common, generate_random) {
{
auto r1 = utils::generate_random<std::size_t>();
auto r2 = utils::generate_random<std::size_t>();
EXPECT_NE(r1, r2);
}
{
auto r1 = utils::generate_random<std::vector<std::uint8_t>>(6U);
auto r2 = utils::generate_random<std::vector<std::uint8_t>>(6U);
EXPECT_EQ(6U, r1.size());
EXPECT_EQ(r1.size(), r2.size());
EXPECT_NE(r1, r2);
}
{
auto r1 = utils::generate_random<std::array<std::uint8_t, 4U>>();
auto r2 = utils::generate_random<std::array<std::uint8_t, 4U>>();
EXPECT_EQ(4U, r1.size());
EXPECT_EQ(r1.size(), r2.size());
EXPECT_NE(0, std::memcmp(r1.data(), r2.data(), r1.size()));
}
{
auto r1 = utils::generate_random<std::string>(6U);
auto r2 = utils::generate_random<std::string>(6U);
EXPECT_EQ(6U, r1.size());
EXPECT_EQ(r1.size(), r2.size());
EXPECT_NE(0, std::memcmp(r1.data(), r2.data(), r1.size()));
}
{
auto r1 = utils::generate_random<std::wstring>(6U);
auto r2 = utils::generate_random<std::wstring>(6U);
EXPECT_EQ(6U, r1.size());
EXPECT_EQ(r1.size(), r2.size());
EXPECT_NE(0, std::memcmp(r1.data(), r2.data(), r1.size()));
}
}
#endif // defined(PROJECT_ENABLE_LIBSODIUM)
TEST(utils_common, divide_with_ceiling) {
auto r = utils::divide_with_ceiling(12, 5);
EXPECT_EQ(3, r);
r = utils::divide_with_ceiling(12, 4);
EXPECT_EQ(3, r);
r = utils::divide_with_ceiling(1, 2);
EXPECT_EQ(1, r);
r = utils::divide_with_ceiling(2, 2);
EXPECT_EQ(1, r);
r = utils::divide_with_ceiling(0, 2);
EXPECT_EQ(0, r);
}
} // namespace repertory