ArrayParser doesn't require the string to be null terminated anymore,
instead the length of the string can be passed in. This is first step in process to allow Value to work without null terminator.
This commit is contained in:
parent
93c8b49f61
commit
b210c570fc
4 changed files with 26 additions and 13 deletions
|
|
@ -9,7 +9,7 @@ using namespace Pgsql;
|
|||
TEST(ArrayParser, emptyInput)
|
||||
{
|
||||
const char * input = "";
|
||||
ArrayParser parser(input);
|
||||
ArrayParser parser(input, -1);
|
||||
auto res = parser.GetNextElem();
|
||||
ASSERT_FALSE(res.ok);
|
||||
}
|
||||
|
|
@ -17,7 +17,7 @@ TEST(ArrayParser, emptyInput)
|
|||
TEST(ArrayParser, emptyArray)
|
||||
{
|
||||
const char * input = "{}";
|
||||
ArrayParser parser(input);
|
||||
ArrayParser parser(input, -1);
|
||||
auto res = parser.GetNextElem();
|
||||
ASSERT_FALSE(res.ok);
|
||||
}
|
||||
|
|
@ -25,7 +25,7 @@ TEST(ArrayParser, emptyArray)
|
|||
TEST(ArrayParser, oneInt)
|
||||
{
|
||||
const char * input = "{1}";
|
||||
ArrayParser parser(input);
|
||||
ArrayParser parser(input, -1);
|
||||
auto res = parser.GetNextElem();
|
||||
ASSERT_TRUE(res.ok);
|
||||
ASSERT_EQ(res.value, "1");
|
||||
|
|
@ -37,7 +37,7 @@ TEST(ArrayParser, oneInt)
|
|||
TEST(ArrayParser, twoElems)
|
||||
{
|
||||
const char * input = "{1,2.3}";
|
||||
ArrayParser parser(input);
|
||||
ArrayParser parser(input, -1);
|
||||
|
||||
auto res = parser.GetNextElem();
|
||||
ASSERT_TRUE(res.ok);
|
||||
|
|
@ -54,7 +54,7 @@ TEST(ArrayParser, twoElems)
|
|||
TEST(ArrayParser, nullElem)
|
||||
{
|
||||
const char * input = "{NULL}";
|
||||
ArrayParser parser(input);
|
||||
ArrayParser parser(input, -1);
|
||||
auto res = parser.GetNextElem();
|
||||
ASSERT_TRUE(res.ok);
|
||||
ASSERT_EQ(res.value, std::nullopt);
|
||||
|
|
@ -71,7 +71,7 @@ TEST(ArrayParser, nullElem)
|
|||
TEST(ArrayParser, quotedValues)
|
||||
{
|
||||
const char * input = R"_({"ab c","de\"f"})_";
|
||||
ArrayParser parser(input);
|
||||
ArrayParser parser(input, -1);
|
||||
auto res = parser.GetNextElem();
|
||||
ASSERT_TRUE(res.ok);
|
||||
ASSERT_EQ(res.value, "ab c");
|
||||
|
|
@ -84,6 +84,19 @@ TEST(ArrayParser, quotedValues)
|
|||
ASSERT_FALSE(res.ok);
|
||||
}
|
||||
|
||||
TEST(ArrayParser, unexpectedEndWithNullTerminator)
|
||||
{
|
||||
const char * input = "{abc";
|
||||
ArrayParser parser(input, -1);
|
||||
ASSERT_THROW(parser.GetNextElem(), std::runtime_error);
|
||||
}
|
||||
|
||||
TEST(ArrayParser, unexpectedEndWithoutNullTerminator)
|
||||
{
|
||||
const char * input = "{abc";
|
||||
ArrayParser parser(input, 3); // 3 will put c past the end
|
||||
ASSERT_THROW(parser.GetNextElem(), std::runtime_error);
|
||||
}
|
||||
|
||||
// ARRAY['2017-12-11'::date, NULL]
|
||||
// {2017-12-11,NULL}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue