From 975ef2e4a5fd5e4892fa5aefe074c18d3dc08af9 Mon Sep 17 00:00:00 2001 From: ado Date: Sun, 6 Aug 2023 17:39:09 +0200 Subject: [PATCH] Add invalid multiline parser tests --- test/test_parser.cpp | 163 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 161 insertions(+), 2 deletions(-) diff --git a/test/test_parser.cpp b/test/test_parser.cpp index 9e29a90..94e6c4c 100644 --- a/test/test_parser.cpp +++ b/test/test_parser.cpp @@ -965,6 +965,7 @@ void test_unterminated_line_impl(const std::vector& lines, expect_error_on_command(p, command); break; } else { + command(); CHECK(p.valid()); ++line; } @@ -979,8 +980,7 @@ void test_unterminated_line(const std::vector& lines, test_unterminated_line_impl(lines, bad_line); } -// TODO add more cases -TEST_CASE("parser test csv on multiple with errors") { +TEST_CASE("parser test csv on multiline with errors") { using multiline = ss::multiline_restricted<3>; using escape = ss::escape<'\\'>; using quote = ss::quote<'"'>; @@ -992,6 +992,47 @@ TEST_CASE("parser test csv on multiple with errors") { test_unterminated_line(lines, 0); } + { + const std::vector lines{"1,2,just\\", "9,8,second"}; + test_unterminated_line(lines, 0); + test_unterminated_line(lines, 0); + } + + { + const std::vector lines{"9,8,first", "1,2,just\\"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", "1,2,just\\", + "3,4,third"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", + "1,2,just\\\nstrings\\", + "3,4,th\\\nird"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", "3,4,second", + "1,2,just\\"}; + test_unterminated_line(lines, 2); + test_unterminated_line(lines, 2); + } + + { + const std::vector lines{"9,8,\\first", "3,4,second", + "1,2,jus\\t\\"}; + test_unterminated_line(lines, 2); + test_unterminated_line(lines, 2); + } + // unterminated quote { const std::vector lines{"1,2,\"just"}; @@ -999,10 +1040,45 @@ TEST_CASE("parser test csv on multiple with errors") { test_unterminated_line(lines, 0); } + { + const std::vector lines{"1,2,\"just", "9,8,second"}; + test_unterminated_line(lines, 0); + test_unterminated_line(lines, 0); + } + + { + const std::vector lines{"9,8,first", "1,2,\"just"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", "1,2,\"just", + "3,4,th\\,ird"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", "3,4,second", + "1,2,\"just"}; + test_unterminated_line(lines, 2); + test_unterminated_line(lines, 2); + } + + { + const std::vector lines{"9,8,\"first\"", + "\"3\",4,\"sec,ond\"", + "1,2,\"ju\"\"st"}; + test_unterminated_line(lines, 2); + test_unterminated_line(lines, 2); + } + // unterminated quote and escape { const std::vector lines{"1,2,\"just\\"}; test_unterminated_line(lines, 0); + test_unterminated_line(lines, 0); } { @@ -1015,6 +1091,29 @@ TEST_CASE("parser test csv on multiple with errors") { test_unterminated_line(lines, 0); } + { + const std::vector lines{"9,8,first", "1,2,\"just\n\\"}; + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", "1,2,\"just\n\\", + "4,3,thrid"}; + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,f\\\nirst", "1,2,\"just\n\\", + "4,3,thrid"}; + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,\"f\ni\nrst\"", + "1,2,\"just\n\\", "4,3,thrid"}; + test_unterminated_line(lines, 1); + } + // multiline limmit reached escape { const std::vector lines{"1,2,\\\n\\\n\\\n\\\njust"}; @@ -1022,6 +1121,28 @@ TEST_CASE("parser test csv on multiple with errors") { test_unterminated_line(lines, 0); } + { + const std::vector lines{"9,8,first", + "1,2,\\\n\\\n\\\n\\\njust"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,fi\\\nrs\\\nt", + "1,2,\\\n\\\n\\\n\\\njust"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,first", + "1,2,\\\n\\\n\\\n\\\njust", + "4,3,third"}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + // multiline limmit reached quote { const std::vector lines{"1,2,\"\n\n\n\n\njust\""}; @@ -1029,11 +1150,49 @@ TEST_CASE("parser test csv on multiple with errors") { test_unterminated_line(lines, 0); } + { + const std::vector lines{"9,8,first", + "1,2,\"\n\n\n\n\njust\""}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,\"fir\nst\"", + "1,2,\"\n\n\n\n\njust\""}; + test_unterminated_line(lines, 1); + test_unterminated_line(lines, 1); + } + // multiline limmit reached quote and escape { const std::vector lines{"1,2,\"\\\n\n\\\n\\\n\\\njust"}; test_unterminated_line(lines, 0); } + + { + const std::vector lines{"9,8,first", + "1,2,\"\\\n\n\\\n\\\n\\\njust"}; + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,fi\\\nrst", + "1,2,\"\\\n\n\\\n\\\n\\\njust"}; + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,\"fi\nrst\"", + "1,2,\"\\\n\n\\\n\\\n\\\njust"}; + test_unterminated_line(lines, 1); + } + + { + const std::vector lines{"9,8,\"fi\nr\\\nst\"", + "1,2,\"\\\n\n\\\n\\\n\\\njust"}; + test_unterminated_line(lines, 1); + } } template