Commit 256912ad authored by unknown's avatar unknown

Fix alloc_stmt_fields for non-select statements

Add tests for show commands + MYSQL_TYPE_NULL coverage


tests/client_test.c:
  Add tests for show commands + MYSQL_TYPE_NULL coverage
libmysql/libmysql.c:
  Fix alloc_stmt_fields for non-select statements
parent d6a9713b
...@@ -3932,19 +3932,40 @@ mysql_prepare(MYSQL *mysql, const char *query, ulong length) ...@@ -3932,19 +3932,40 @@ mysql_prepare(MYSQL *mysql, const char *query, ulong length)
unsigned int alloc_stmt_fields(MYSQL_STMT *stmt) unsigned int alloc_stmt_fields(MYSQL_STMT *stmt)
{ {
MYSQL_FIELD *fields; MYSQL_FIELD *fields, *field, *end;
MEM_ROOT *alloc= &stmt->mem_root;
if (!stmt->mysql->field_count) if (!stmt->mysql->field_count)
return 0; return 0;
stmt->field_count= stmt->mysql->field_count; stmt->field_count= stmt->mysql->field_count;
fields= stmt->mysql->fields;
if (!(stmt->fields= (MYSQL_FIELD *) alloc_root(&stmt->mem_root, /*
sizeof(fields))) || Get the field information for non-select statements
!(stmt->bind= (MYSQL_BIND *) alloc_root(&stmt->mem_root, like SHOW and DESCRIBE commands
*/
if (!(stmt->fields= (MYSQL_FIELD *) alloc_root(alloc,
sizeof(MYSQL_FIELD) * stmt->field_count)) ||
!(stmt->bind= (MYSQL_BIND *) alloc_root(alloc,
sizeof(MYSQL_BIND ) * stmt->field_count))) sizeof(MYSQL_BIND ) * stmt->field_count)))
return 0; return 0;
memcpy((char *)stmt->fields, (char *)fields, sizeof(fields));
for (fields= stmt->mysql->fields, end= fields+stmt->field_count,
field= stmt->fields;
field && fields < end; fields++, field++)
{
field->db = strdup_root(alloc,fields->db);
field->table = strdup_root(alloc,fields->table);
field->org_table= strdup_root(alloc,fields->org_table);
field->name = strdup_root(alloc,fields->name);
field->org_name = strdup_root(alloc,fields->org_name);
field->length = fields->length;
field->type = fields->type;
field->flags = fields->flags;
field->decimals = fields->decimals;
field->def = fields->def ? strdup_root(alloc,fields->def): 0;
field->max_length= 0;
}
return stmt->field_count; return stmt->field_count;
} }
......
...@@ -50,6 +50,9 @@ static unsigned int test_count= 0; ...@@ -50,6 +50,9 @@ static unsigned int test_count= 0;
static unsigned int opt_count= 0; static unsigned int opt_count= 0;
static unsigned int iter_count= 0; static unsigned int iter_count= 0;
static time_t start_time, end_time;
static double total_time;
#define myheader(str) \ #define myheader(str) \
{ \ { \
fprintf(stdout,"\n\n#####################################\n"); \ fprintf(stdout,"\n\n#####################################\n"); \
...@@ -438,7 +441,7 @@ uint my_stmt_result(const char *query, unsigned long length) ...@@ -438,7 +441,7 @@ uint my_stmt_result(const char *query, unsigned long length)
uint row_count; uint row_count;
int rc; int rc;
fprintf(stdout,"\n\n %s \n", query); fprintf(stdout,"\n\n %s", query);
stmt= mysql_prepare(mysql,query,length); stmt= mysql_prepare(mysql,query,length);
mystmt_init(stmt); mystmt_init(stmt);
...@@ -1072,7 +1075,7 @@ static void test_prepare() ...@@ -1072,7 +1075,7 @@ static void test_prepare()
myquery(rc); myquery(rc);
/* test the results now, only one row should exists */ /* test the results now, only one row should exists */
myassert(tiny_data == (int) my_stmt_result("SELECT * FROM my_prepare",50)); myassert(tiny_data == (char) my_stmt_result("SELECT * FROM my_prepare",50));
stmt = mysql_prepare(mysql,"SELECT * FROM my_prepare",50); stmt = mysql_prepare(mysql,"SELECT * FROM my_prepare",50);
mystmt_init(stmt); mystmt_init(stmt);
...@@ -1238,8 +1241,7 @@ static void test_null() ...@@ -1238,8 +1241,7 @@ static void test_null()
{ {
MYSQL_STMT *stmt; MYSQL_STMT *stmt;
int rc; int rc;
int nData=1; uint nData;
MYSQL_RES *result;
MYSQL_BIND bind[2]; MYSQL_BIND bind[2];
my_bool is_null[2]; my_bool is_null[2];
...@@ -1268,33 +1270,69 @@ static void test_null() ...@@ -1268,33 +1270,69 @@ static void test_null()
bind[0].buffer_type=MYSQL_TYPE_LONG; bind[0].buffer_type=MYSQL_TYPE_LONG;
bind[0].is_null= &is_null[0]; bind[0].is_null= &is_null[0];
is_null[0]= 1; is_null[0]= 1;
bind[1]=bind[0]; /* string data */ bind[1]=bind[0];
rc = mysql_bind_param(stmt,bind); rc = mysql_bind_param(stmt,bind);
mystmt(stmt, rc); mystmt(stmt, rc);
/* now, execute the prepared statement to insert 10 records.. */ /* now, execute the prepared statement to insert 10 records.. */
for (nData=0; nData<9; nData++) for (nData=0; nData<10; nData++)
{
rc = mysql_execute(stmt);
mystmt(stmt, rc);
}
/* Re-bind with MYSQL_TYPE_NULL */
bind[0].buffer_type= MYSQL_TYPE_NULL;
is_null[0]= 0; /* reset */
bind[1]= bind[0];
rc = mysql_bind_param(stmt,bind);
mystmt(stmt,rc);
for (nData=0; nData<10; nData++)
{ {
rc = mysql_execute(stmt); rc = mysql_execute(stmt);
mystmt(stmt, rc); mystmt(stmt, rc);
} }
mysql_stmt_close(stmt); mysql_stmt_close(stmt);
/* now fetch the results ..*/ /* now fetch the results ..*/
rc = mysql_commit(mysql); rc = mysql_commit(mysql);
myquery(rc); myquery(rc);
/* test the results now, only one row should exists */ nData*= 2;
rc = mysql_query(mysql,"SELECT * FROM test_null"); myassert(nData == my_stmt_result("SELECT * FROM test_null", 30));
myquery(rc);
/* get the result */ /* Fetch results */
result = mysql_store_result(mysql); bind[0].buffer_type= MYSQL_TYPE_LONG;
mytest(result); bind[0].buffer= (char *)&nData; /* this buffer won't be altered */
bind[0].length= 0;
bind[1]= bind[0];
bind[0].is_null= &is_null[0];
bind[1].is_null= &is_null[1];
myassert(nData == my_process_result_set(result)); stmt = mysql_prepare(mysql,"SELECT * FROM test_null",30);
mysql_free_result(result); mystmt_init(stmt);
rc = mysql_execute(stmt);
mystmt(stmt,rc);
rc = mysql_bind_result(stmt,bind);
mystmt(stmt,rc);
rc= 0;
is_null[0]= is_null[1]= 0;
while (mysql_fetch(stmt) != MYSQL_NO_DATA)
{
myassert(is_null[0]);
myassert(is_null[1]);
rc++;
is_null[0]= is_null[1]= 0;
}
myassert(rc == (int)nData);
mysql_stmt_close(stmt);
} }
...@@ -1636,8 +1674,13 @@ static void test_select_show() ...@@ -1636,8 +1674,13 @@ static void test_select_show()
mysql_autocommit(mysql,TRUE); mysql_autocommit(mysql,TRUE);
strmov(query,"SELECT * FROM mysql.host"); rc = mysql_query(mysql, "DROP TABLE IF EXISTS test_show");
stmt = mysql_prepare(mysql, query, strlen(query)); myquery(rc);
rc = mysql_query(mysql, "CREATE TABLE test_show(id int(4) NOT NULL, name char(2))");
myquery(rc);
stmt = mysql_prepare(mysql, "show columns from test_show", 30);
mystmt_init(stmt); mystmt_init(stmt);
verify_param_count(stmt,0); verify_param_count(stmt,0);
...@@ -1646,7 +1689,28 @@ static void test_select_show() ...@@ -1646,7 +1689,28 @@ static void test_select_show()
mystmt(stmt, rc); mystmt(stmt, rc);
my_process_stmt_result(stmt); my_process_stmt_result(stmt);
mysql_stmt_close(stmt);
stmt = mysql_prepare(mysql, "show tables from mysql like ?", 50);
mystmt_init_r(stmt);
strxmov(query,"show tables from ", current_db, " like \'test_show\'", NullS);
stmt = mysql_prepare(mysql, query, strlen(query));
mystmt_init(stmt);
rc = mysql_execute(stmt);
mystmt(stmt, rc);
my_process_stmt_result(stmt);
mysql_stmt_close(stmt);
stmt = mysql_prepare(mysql, "describe test_show", 30);
mystmt_init(stmt);
rc = mysql_execute(stmt);
mystmt(stmt, rc);
my_process_stmt_result(stmt);
mysql_stmt_close(stmt); mysql_stmt_close(stmt);
} }
...@@ -4378,6 +4442,9 @@ static void test_multi_query() ...@@ -4378,6 +4442,9 @@ static void test_multi_query()
rc = mysql_query(mysql, query); /* syntax error */ rc = mysql_query(mysql, query); /* syntax error */
myquery_r(rc); myquery_r(rc);
myassert(0 == mysql_next_result(mysql));
myassert(0 == mysql_more_results(mysql));
if (!(l_mysql = mysql_init(NULL))) if (!(l_mysql = mysql_init(NULL)))
{ {
fprintf(stdout,"\n mysql_init() failed"); fprintf(stdout,"\n mysql_init() failed");
...@@ -5300,19 +5367,33 @@ static void get_options(int argc, char **argv) ...@@ -5300,19 +5367,33 @@ static void get_options(int argc, char **argv)
return; return;
} }
/*
Print the test output on successful execution before exiting
*/
static void print_test_output()
{
fprintf(stdout,"\n\n");
fprintf(stdout,"All '%d' tests were successful (in '%d' iterations)",
test_count-1, opt_count);
fprintf(stdout,"\n Total execution time: %g SECS", total_time);
if (opt_count > 1)
fprintf(stdout," (Avg: %g SECS)", total_time/opt_count);
fprintf(stdout,"\n\n!!! SUCCESS !!!\n");
}
/******************************************************** /********************************************************
* main routine * * main routine *
*********************************************************/ *********************************************************/
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
time_t start_time, end_time;
double total_time= 0;
MY_INIT(argv[0]); MY_INIT(argv[0]);
get_options(argc,argv); get_options(argc,argv);
client_connect(); /* connect to server */ client_connect(); /* connect to server */
total_time= 0;
for (iter_count=1; iter_count <= opt_count; iter_count++) for (iter_count=1; iter_count <= opt_count; iter_count++)
{ {
/* Start of tests */ /* Start of tests */
...@@ -5399,13 +5480,8 @@ int main(int argc, char **argv) ...@@ -5399,13 +5480,8 @@ int main(int argc, char **argv)
} }
client_disconnect(); /* disconnect from server */ client_disconnect(); /* disconnect from server */
fprintf(stdout,"\n\nAll '%d' tests were successful (in '%d' iterations)", print_test_output();
test_count-1, opt_count);
fprintf(stdout,"\n Total execution time: %g SECS", total_time);
if (opt_count > 1)
fprintf(stdout," (Avg: %g SECS)", total_time/opt_count);
fprintf(stdout,"\n\nSUCCESS !!!\n");
return(0); return(0);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment