mirror of
https://github.com/MariaDB/server.git
synced 2025-08-01 03:47:19 +03:00
unit test for dynstr_append_os_quoted()
and a trivial cleanup to avoid manually-specified lengths
This commit is contained in:
@ -142,16 +142,14 @@ my_bool dynstr_trunc(DYNAMIC_STRING *str, size_t n)
|
|||||||
my_bool dynstr_append_os_quoted(DYNAMIC_STRING *str, const char *append, ...)
|
my_bool dynstr_append_os_quoted(DYNAMIC_STRING *str, const char *append, ...)
|
||||||
{
|
{
|
||||||
#ifdef __WIN__
|
#ifdef __WIN__
|
||||||
const char *quote_str= "\"";
|
LEX_CSTRING quote= { C_STRING_WITH_LEN("\"") };
|
||||||
const uint quote_len= 1;
|
|
||||||
#else
|
#else
|
||||||
const char *quote_str= "\'";
|
LEX_CSTRING quote= { C_STRING_WITH_LEN("\'") };
|
||||||
const uint quote_len= 1;
|
|
||||||
#endif /* __WIN__ */
|
#endif /* __WIN__ */
|
||||||
my_bool ret= TRUE;
|
my_bool ret= TRUE;
|
||||||
va_list dirty_text;
|
va_list dirty_text;
|
||||||
|
|
||||||
ret&= dynstr_append_mem(str, quote_str, quote_len); /* Leading quote */
|
ret&= dynstr_append_mem(str, quote.str, quote.length); /* Leading quote */
|
||||||
va_start(dirty_text, append);
|
va_start(dirty_text, append);
|
||||||
while (append != NullS)
|
while (append != NullS)
|
||||||
{
|
{
|
||||||
@ -159,18 +157,18 @@ my_bool dynstr_append_os_quoted(DYNAMIC_STRING *str, const char *append, ...)
|
|||||||
const char *next_pos= cur_pos;
|
const char *next_pos= cur_pos;
|
||||||
|
|
||||||
/* Search for quote in each string and replace with escaped quote */
|
/* Search for quote in each string and replace with escaped quote */
|
||||||
while(*(next_pos= strcend(cur_pos, quote_str[0])) != '\0')
|
while(*(next_pos= strcend(cur_pos, quote.str[0])) != '\0')
|
||||||
{
|
{
|
||||||
ret&= dynstr_append_mem(str, cur_pos, (uint) (next_pos - cur_pos));
|
ret&= dynstr_append_mem(str, cur_pos, (uint) (next_pos - cur_pos));
|
||||||
ret&= dynstr_append_mem(str ,"\\", 1);
|
ret&= dynstr_append_mem(str, STRING_WITH_LEN("\\"));
|
||||||
ret&= dynstr_append_mem(str, quote_str, quote_len);
|
ret&= dynstr_append_mem(str, quote.str, quote.length);
|
||||||
cur_pos= next_pos + 1;
|
cur_pos= next_pos + 1;
|
||||||
}
|
}
|
||||||
ret&= dynstr_append_mem(str, cur_pos, (uint) (next_pos - cur_pos));
|
ret&= dynstr_append_mem(str, cur_pos, (uint) (next_pos - cur_pos));
|
||||||
append= va_arg(dirty_text, char *);
|
append= va_arg(dirty_text, char *);
|
||||||
}
|
}
|
||||||
va_end(dirty_text);
|
va_end(dirty_text);
|
||||||
ret&= dynstr_append_mem(str, quote_str, quote_len); /* Trailing quote */
|
ret&= dynstr_append_mem(str, quote.str, quote.length); /* Trailing quote */
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
MY_ADD_TESTS(bitmap base64 my_vsnprintf my_atomic my_rdtsc lf my_malloc
|
MY_ADD_TESTS(bitmap base64 my_vsnprintf my_atomic my_rdtsc lf my_malloc
|
||||||
my_getopt
|
my_getopt dynstring
|
||||||
LINK_LIBRARIES mysys)
|
LINK_LIBRARIES mysys)
|
||||||
|
|
||||||
IF(WIN32)
|
IF(WIN32)
|
||||||
|
74
unittest/mysys/dynstring-t.c
Normal file
74
unittest/mysys/dynstring-t.c
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
/* Copyright (c) 2016, MariaDB
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU General Public License as
|
||||||
|
published by the Free Software Foundation; version 2 of the License.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
|
||||||
|
|
||||||
|
//#include <my_global.h>
|
||||||
|
#include <m_string.h>
|
||||||
|
#include <my_sys.h>
|
||||||
|
#include <tap.h>
|
||||||
|
|
||||||
|
DYNAMIC_STRING str1;
|
||||||
|
|
||||||
|
static void check(const char *res)
|
||||||
|
{
|
||||||
|
ok(strcmp(str1.str, res) == 0, "strcmp: %s", str1.str);
|
||||||
|
str1.length= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
plan(23);
|
||||||
|
|
||||||
|
IF_WIN(skip_all("Test of POSIX shell escaping rules, not for CMD.EXE\n"), );
|
||||||
|
|
||||||
|
ok(init_dynamic_string(&str1, NULL, 0, 32) == 0, "init");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "test1", NULL) == 0, "append");
|
||||||
|
check("'test1'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "con", "cat", NULL) == 0, "append");
|
||||||
|
check("'concat'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "", NULL) == 0, "append");
|
||||||
|
check("''");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "space inside", NULL) == 0, "append");
|
||||||
|
check("'space inside'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "single'quote", NULL) == 0, "append");
|
||||||
|
check("'single\\'quote'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "many'single'quotes", NULL) == 0, "append");
|
||||||
|
check("'many\\'single\\'quotes'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "'single quoted'", NULL) == 0, "append");
|
||||||
|
check("'\\'single quoted\\''");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "double\"quote", NULL) == 0, "append");
|
||||||
|
check("'double\"quote'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "mixed\"single'and\"double'quotes", NULL) == 0, "append");
|
||||||
|
check("'mixed\"single\\'and\"double\\'quotes'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "back\\space", NULL) == 0, "append");
|
||||||
|
check("'back\\space'");
|
||||||
|
|
||||||
|
ok(dynstr_append_os_quoted(&str1, "backspace\\'and\\\"quote", NULL) == 0, "append");
|
||||||
|
check("'backspace\\\\'and\\\"quote'");
|
||||||
|
|
||||||
|
dynstr_free(&str1);
|
||||||
|
|
||||||
|
return exit_status();
|
||||||
|
}
|
||||||
|
|
Reference in New Issue
Block a user