Commit 0e2f6264 authored by unknown's avatar unknown

fixed string parameter assugnment (coping instead of asigning pointer to buffer) (BUG#1115)

fixed test_field_misc (UTF variable value)


sql/item.cc:
  added debug informetion
  fixed string parameter assugnment (coping instead of asigning pointer to buffer)
tests/client_test.c:
  test for BUG#1115
  fixed test_field_misc (UTF variable value)
parent 651898ad
...@@ -490,26 +490,37 @@ String *Item_null::val_str(String *str) ...@@ -490,26 +490,37 @@ String *Item_null::val_str(String *str)
/* Item_param related */ /* Item_param related */
void Item_param::set_null() void Item_param::set_null()
{ {
maybe_null=null_value=1; DBUG_ENTER("Item_param::set_null");
maybe_null= null_value= 1;
DBUG_VOID_RETURN;
} }
void Item_param::set_int(longlong i) void Item_param::set_int(longlong i)
{ {
int_value=(longlong)i; DBUG_ENTER("Item_param::set_int");
item_type = INT_ITEM; int_value= (longlong)i;
item_type= INT_ITEM;
DBUG_PRINT("info", ("integer: %lld", int_value));
DBUG_VOID_RETURN;
} }
void Item_param::set_double(double value) void Item_param::set_double(double value)
{ {
DBUG_ENTER("Item_param::set_double");
real_value=value; real_value=value;
item_type = REAL_ITEM; item_type= REAL_ITEM;
DBUG_PRINT("info", ("double: %lg", real_value));
DBUG_VOID_RETURN;
} }
void Item_param::set_value(const char *str, uint length) void Item_param::set_value(const char *str, uint length)
{ {
str_value.set(str,length,default_charset()); DBUG_ENTER("Item_param::set_value");
item_type = STRING_ITEM; str_value.copy(str,length,default_charset());
item_type= STRING_ITEM;
DBUG_PRINT("info", ("string: %s", str_value.ptr()));
DBUG_VOID_RETURN;
} }
......
...@@ -1755,6 +1755,89 @@ static void test_select() ...@@ -1755,6 +1755,89 @@ static void test_select()
mysql_stmt_close(stmt); mysql_stmt_close(stmt);
} }
/*
test BUG#1115 (incorrect string parameter value allocation)
*/
static void test_bug1115()
{
MYSQL_STMT *stmt;
int rc;
MYSQL_BIND bind[1];
ulong length[1];
char szData[11];
int nData=1;
myheader("test_bug1115");
rc = mysql_query(mysql,"DROP TABLE IF EXISTS test_select");
myquery(rc);
rc = mysql_query(mysql,"CREATE TABLE test_select(\
session_id char(9) NOT NULL, \
a int(8) unsigned NOT NULL, \
b int(5) NOT NULL, \
c int(5) NOT NULL, \
d datetime NOT NULL)");
myquery(rc);
rc = mysql_query(mysql,"INSERT INTO test_select VALUES (\"abc\",1,2,3,2003-08-30), (\"abd\",1,2,3,2003-08-30), (\"abf\",1,2,3,2003-08-30), (\"abg\",1,2,3,2003-08-30), (\"abh\",1,2,3,2003-08-30), (\"abj\",1,2,3,2003-08-30), (\"abk\",1,2,3,2003-08-30), (\"abl\",1,2,3,2003-08-30), (\"abq\",1,2,3,2003-08-30), (\"abw\",1,2,3,2003-08-30), (\"abe\",1,2,3,2003-08-30), (\"abr\",1,2,3,2003-08-30), (\"abt\",1,2,3,2003-08-30), (\"aby\",1,2,3,2003-08-30), (\"abu\",1,2,3,2003-08-30), (\"abi\",1,2,3,2003-08-30), (\"abo\",1,2,3,2003-08-30), (\"abp\",1,2,3,2003-08-30), (\"abz\",1,2,3,2003-08-30), (\"abx\",1,2,3,2003-08-30)");
myquery(rc);
strmov(query,"SELECT * FROM test_select WHERE session_id = ?");
stmt = mysql_prepare(mysql, query, strlen(query));
mystmt_init(stmt);
verify_param_count(stmt,1);
strmov(szData,(char *)"abc");
bind[0].buffer_type=FIELD_TYPE_STRING;
bind[0].buffer=(char *)szData;
bind[0].buffer_length= 10;
bind[0].length= &length[0];
length[0]= 3;
bind[0].is_null=0;
rc = mysql_bind_param(stmt,bind);
mystmt(stmt, rc);
rc = mysql_execute(stmt);
mystmt(stmt, rc);
myassert(my_process_stmt_result(stmt) == 1);
strmov(szData,(char *)"venu");
bind[0].buffer_type=FIELD_TYPE_STRING;
bind[0].buffer=(char *)szData;
bind[0].buffer_length= 10;
bind[0].length= &length[0];
length[0]= 4;
bind[0].is_null=0;
rc = mysql_bind_param(stmt,bind);
mystmt(stmt, rc);
rc = mysql_execute(stmt);
mystmt(stmt, rc);
myassert(my_process_stmt_result(stmt) == 0);
strmov(szData,(char *)"abc");
bind[0].buffer_type=FIELD_TYPE_STRING;
bind[0].buffer=(char *)szData;
bind[0].buffer_length= 10;
bind[0].length= &length[0];
length[0]= 3;
bind[0].is_null=0;
rc = mysql_bind_param(stmt,bind);
mystmt(stmt, rc);
rc = mysql_execute(stmt);
mystmt(stmt, rc);
myassert(my_process_stmt_result(stmt) == 1);
mysql_stmt_close(stmt);
}
/******************************************************** /********************************************************
* to test simple select show * * to test simple select show *
...@@ -5896,7 +5979,7 @@ static void test_field_misc() ...@@ -5896,7 +5979,7 @@ static void test_field_misc()
"@@table_type","", /* field and its org name */ "@@table_type","", /* field and its org name */
MYSQL_TYPE_STRING, /* field type */ MYSQL_TYPE_STRING, /* field type */
"", "", /* table and its org name */ "", "", /* table and its org name */
"",type_length,0); /* db name, length */ "",type_length*3,0); /* db name, length */
mysql_free_result(result); mysql_free_result(result);
mysql_stmt_close(stmt); mysql_stmt_close(stmt);
...@@ -7814,6 +7897,7 @@ int main(int argc, char **argv) ...@@ -7814,6 +7897,7 @@ int main(int argc, char **argv)
test_fetch_column(); /* to test mysql_fetch_column */ test_fetch_column(); /* to test mysql_fetch_column */
test_sqlmode(); /* test for SQL_MODE */ test_sqlmode(); /* test for SQL_MODE */
test_ts(); /* test for timestamp BR#819 */ test_ts(); /* test for timestamp BR#819 */
test_bug1115(); /* BUG#1115 */
end_time= time((time_t *)0); end_time= time((time_t *)0);
total_time+= difftime(end_time, start_time); total_time+= difftime(end_time, start_time);
......
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