mirror of
https://github.com/boostorg/mysql.git
synced 2026-01-29 07:42:25 +00:00
133 lines
3.7 KiB
C++
133 lines
3.7 KiB
C++
/*
|
|
* value.cpp
|
|
*
|
|
* Created on: Dec 7, 2019
|
|
* Author: ruben
|
|
*/
|
|
|
|
#include <gtest/gtest.h>
|
|
#include <sstream>
|
|
#include "mysql/value.hpp"
|
|
#include "test_common.hpp"
|
|
|
|
using namespace mysql::test;
|
|
using namespace testing;
|
|
using namespace ::date::literals;
|
|
using namespace std::chrono;
|
|
|
|
namespace
|
|
{
|
|
|
|
// Required because value is a typedef for a specific std::variant and operator<<
|
|
// is defined in namespace mysql - ADL does not find it
|
|
using mysql::operator<<;
|
|
|
|
// tests for operator== and operator!=
|
|
struct ValueEqualityTest : public Test
|
|
{
|
|
std::vector<mysql::value> values = makevalues(
|
|
std::int32_t(20),
|
|
std::int64_t(-1),
|
|
std::uint32_t(0xffffffff),
|
|
std::uint64_t(0x100000000),
|
|
3.14f,
|
|
8.89,
|
|
mysql::date(1_d/10/2019_y),
|
|
mysql::date(1_d/10/2019_y) + std::chrono::hours(10),
|
|
mysql::time(std::chrono::seconds(-10)),
|
|
mysql::year(2010),
|
|
nullptr
|
|
);
|
|
std::vector<mysql::value> values_copy = values;
|
|
std::vector<mysql::value> other_values = makevalues(
|
|
std::int32_t(10),
|
|
std::int64_t(-22),
|
|
std::uint32_t(0xff6723),
|
|
std::uint64_t(222),
|
|
-3.0f,
|
|
8e24,
|
|
mysql::date(1_d/9/2019_y),
|
|
mysql::date(1_d/9/2019_y) + std::chrono::hours(10),
|
|
mysql::time(std::chrono::seconds(10)),
|
|
mysql::year(1900),
|
|
nullptr
|
|
);
|
|
};
|
|
|
|
TEST_F(ValueEqualityTest, OperatorsEqNe_DifferentType_ReturnNotEquals)
|
|
{
|
|
for (int i = 0; i < values.size(); ++i)
|
|
{
|
|
for (int j = 0; j < i; ++j)
|
|
{
|
|
EXPECT_FALSE(values.at(i) == values.at(j)) << "i=" << i << ", j=" << j;
|
|
EXPECT_TRUE(values.at(i) != values.at(j)) << "i=" << i << ", j=" << j;
|
|
}
|
|
}
|
|
}
|
|
|
|
TEST_F(ValueEqualityTest, OperatorsEqNe_SameTypeDifferentValue_ReturnNotEquals)
|
|
{
|
|
// Note: nullptr_t (the last value) can't have other value than nullptr
|
|
// so it is excluded from this test
|
|
for (int i = 0; i < values.size() - 1; ++i)
|
|
{
|
|
EXPECT_FALSE(values.at(i) == other_values.at(i)) << "i=" << i;
|
|
EXPECT_TRUE(values.at(i) != other_values.at(i)) << "i=" << i;
|
|
}
|
|
}
|
|
|
|
TEST_F(ValueEqualityTest, OperatorsEqNe_SameTypeSameValue_ReturnEquals)
|
|
{
|
|
for (int i = 0; i < values.size(); ++i)
|
|
{
|
|
EXPECT_TRUE(values.at(i) == values_copy.at(i)) << "i=" << i;
|
|
EXPECT_FALSE(values.at(i) != values_copy.at(i)) << "i=" << i;
|
|
}
|
|
}
|
|
|
|
// Tests for operator<<
|
|
struct ValueStreamParams
|
|
{
|
|
mysql::value input;
|
|
std::string expected;
|
|
|
|
template <typename T>
|
|
ValueStreamParams(T input, std::string expected): input(input), expected(std::move(expected)) {}
|
|
};
|
|
std::ostream& operator<<(std::ostream& os, const ValueStreamParams& v) { return os << v.expected; }
|
|
|
|
struct ValueStreamTest : TestWithParam<ValueStreamParams>
|
|
{
|
|
};
|
|
|
|
TEST_P(ValueStreamTest, OutputStream_Trivial_ProducesExpectedString)
|
|
{
|
|
std::ostringstream ss;
|
|
ss << GetParam().input;
|
|
EXPECT_EQ(ss.str(), GetParam().expected);
|
|
}
|
|
|
|
INSTANTIATE_TEST_SUITE_P(Default, ValueStreamTest, Values(
|
|
ValueStreamParams(std::int32_t(42), "42"),
|
|
ValueStreamParams(std::int32_t(-90), "-90"),
|
|
ValueStreamParams(std::uint32_t(42), "42"),
|
|
ValueStreamParams(std::int64_t(42), "42"),
|
|
ValueStreamParams(std::int64_t(-90), "-90"),
|
|
ValueStreamParams(std::uint64_t(42), "42"),
|
|
ValueStreamParams("a_string", "a_string"),
|
|
ValueStreamParams(2.43f, "2.43"),
|
|
ValueStreamParams(8.12, "8.12"),
|
|
ValueStreamParams(mysql::date(1_d/9/2019_y), "2019-09-01"),
|
|
ValueStreamParams(mysql::time(0), "00:00:00:000000"),
|
|
ValueStreamParams(mysql::time(hours(24)), "24:00:00:000000"),
|
|
ValueStreamParams(mysql::time(hours(210) + minutes(59) + seconds(59) + microseconds(100)), "210:59:59:000100"),
|
|
ValueStreamParams(mysql::time(hours(-839) - minutes(20) - seconds(35) - microseconds(999999)), "-839:20:35:999999"),
|
|
ValueStreamParams(makedt(2019, 1, 8, 9, 20, 11, 123), "2019-01-08 09:20:11.000123"),
|
|
ValueStreamParams(makedt(2019, 1, 8), "2019-01-08 00:00:00.000000"),
|
|
ValueStreamParams(mysql::year(2019), "2019"),
|
|
ValueStreamParams(nullptr, "<NULL>")
|
|
));
|
|
|
|
}
|