mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 08:44:33 +01:00
5ebe0dd231
added client_test.dsp in project added CHARACTER SET in tables added 5th time zone included lstat in if() expanded ignore list for windows added directory slave1 and slave2 added options for mysqld and mysqltest fixed error in read_option() fixed and added enviroment variables for Linux and Windows rewrote str_tok() added replacment 3th column New BitKeeper file ``VC++Files/tests/client_test.dsp'' VC++Files/mysql.dsw: added client_test.dsp in project mysql-test/my_create_tables.c: added CHARACTER SET in tables added 5th time zone mysql-test/my_manage.c: included lstat in if() mysql-test/mysql_test_run_new.c: expanded ignore list for windows added directory slave1 and slave2 added options for mysqld and mysqltest fixed error in read_option() fixed and added enviroment variables for Linux and Windows rewrote str_tok() mysql-test/t/ps_1general.test: added replacment 3th column
1051 lines
31 KiB
Text
1051 lines
31 KiB
Text
###################### ps_general.test #######################
|
|
# #
|
|
# basic and miscellaneous tests for prepared statements #
|
|
# #
|
|
##############################################################
|
|
|
|
#
|
|
# NOTE: PLEASE SEE THE DETAILED DESCRIPTION AT THE BOTTOM OF THIS FILE
|
|
# BEFORE ADDING NEW TEST CASES HERE !!!
|
|
|
|
--disable_warnings
|
|
drop table if exists t5, t6, t7, t8;
|
|
drop database if exists mysqltest ;
|
|
--enable_warnings
|
|
|
|
--disable_query_log
|
|
select '------ basic tests ------' as test_sequence ;
|
|
--enable_query_log
|
|
|
|
let $type= 'MYISAM' ;
|
|
# create the tables (t1 and t9) used in many tests
|
|
--source include/ps_create.inc
|
|
# insert data into these tables
|
|
--source include/ps_renew.inc
|
|
|
|
|
|
################ The basic functions ################
|
|
|
|
# 1. PREPARE stmt_name FROM <preparable statement>;
|
|
# <preparable statement> ::=
|
|
# 'literal_stmt' |
|
|
# @variable_ref_stmt.
|
|
# The statement may contain question marks as placeholders for parameters.
|
|
#
|
|
# Bind a statement name to a string containing a SQL statement and
|
|
# send it to the server. The server will parse the statement and
|
|
# reply with "Query Ok" or an error message.
|
|
#
|
|
PREPARE stmt FROM ' select * from t1 where a = ? ' ;
|
|
|
|
# 2. EXECUTE stmt_name [USING @var [, @var ]];
|
|
# Current values of supplied variables are used as parameters.
|
|
#
|
|
# Send the server the order to execute the statement and supply values
|
|
# for the input parameters needed.
|
|
# If no error occurs the server reply will be identical to the reply for
|
|
# the query used in PREPARE with question marks replaced with values of
|
|
# the input variables.
|
|
#
|
|
SET @var= 2 ;
|
|
EXECUTE stmt USING @var ;
|
|
# The non prepared statement with the same server reply would be:
|
|
select * from t1 where a = @var ;
|
|
|
|
# 3. DEALLOCATE PREPARE stmt_name;
|
|
#
|
|
# Send the server the order to drop the parse informations.
|
|
# The server will reply with "Query Ok" or an error message.
|
|
DEALLOCATE PREPARE stmt ;
|
|
|
|
################ PREPARE ################
|
|
# prepare without parameter
|
|
prepare stmt1 from ' select 1 as my_col ' ;
|
|
# prepare with parameter
|
|
prepare stmt1 from ' select ? as my_col ' ;
|
|
# prepare must fail (incomplete statements/wrong syntax)
|
|
--error 1064
|
|
prepare ;
|
|
--error 1064
|
|
prepare stmt1 ;
|
|
--error 1064
|
|
prepare stmt1 from ;
|
|
--error 1064
|
|
prepare_garbage stmt1 from ' select 1 ' ;
|
|
--error 1064
|
|
prepare stmt1 from_garbage ' select 1 ' ;
|
|
--error 1064
|
|
prepare stmt1 from ' select_garbage 1 ' ;
|
|
--error 1064
|
|
prepare from ' select 1 ' ;
|
|
--error 1064
|
|
prepare stmt1 ' select 1 ' ;
|
|
--error 1064
|
|
prepare ? from ' select ? as my_col ' ;
|
|
# statement in variable
|
|
set @arg00='select 1 as my_col';
|
|
prepare stmt1 from @arg00;
|
|
# prepare must fail (query variable is empty)
|
|
set @arg00='';
|
|
--error 1065
|
|
prepare stmt1 from @arg00;
|
|
set @arg00=NULL;
|
|
# prepare must fail (query variable is NULL)
|
|
--error 1064
|
|
prepare stmt1 from @arg01;
|
|
|
|
prepare stmt1 from ' select * from t1 where a <= 2 ' ;
|
|
# prepare must fail (column x does not exist)
|
|
--error 1054
|
|
prepare stmt1 from ' select * from t1 where x <= 2 ' ;
|
|
# cases derived from client_test.c: test_null()
|
|
# prepare must fail (column x does not exist)
|
|
--error 1054
|
|
prepare stmt1 from ' insert into t1(a,x) values(?,?) ' ;
|
|
--error 1054
|
|
prepare stmt1 from ' insert into t1(x,a) values(?,?) ' ;
|
|
--disable_warnings
|
|
drop table if exists not_exist ;
|
|
--enable_warnings
|
|
# prepare must fail (table does not exist)
|
|
--error 1146
|
|
prepare stmt1 from ' select * from not_exist where a <= 2 ' ;
|
|
|
|
# case derived from client_test.c: test_prepare_syntax()
|
|
# prepare must fail (incomplete statement)
|
|
--error 1064
|
|
prepare stmt1 from ' insert into t1 values(? ' ;
|
|
--error 1064
|
|
prepare stmt1 from ' select a, b from t1
|
|
where a=? and where ' ;
|
|
|
|
################ EXECUTE ################
|
|
# execute must fail (statement never_prepared never prepared)
|
|
--error 1243
|
|
execute never_prepared ;
|
|
# execute must fail (prepare stmt1 just failed,
|
|
# but there was a successful prepare of stmt1 before)
|
|
prepare stmt1 from ' select * from t1 where a <= 2 ' ;
|
|
--error 1146
|
|
prepare stmt1 from ' select * from not_exist where a <= 2 ' ;
|
|
--error 1243
|
|
execute stmt1 ;
|
|
|
|
# drop the table between prepare and execute
|
|
create table t5
|
|
(
|
|
a int primary key,
|
|
b char(30),
|
|
c int
|
|
);
|
|
insert into t5( a, b, c) values( 1, 'original table', 1);
|
|
prepare stmt2 from ' select * from t5 ' ;
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
# execute must fail (table was dropped after prepare)
|
|
--error 1146
|
|
execute stmt2 ;
|
|
# cases derived from client_test.c: test_select_prepare()
|
|
# 1. drop + create table (same column names/types/order)
|
|
# between prepare and execute
|
|
create table t5
|
|
(
|
|
a int primary key,
|
|
b char(30),
|
|
c int
|
|
);
|
|
insert into t5( a, b, c) values( 9, 'recreated table', 9);
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
# 2. drop + create table (same column names/types but different order)
|
|
# between prepare and execute
|
|
create table t5
|
|
(
|
|
a int primary key,
|
|
c int,
|
|
b char(30)
|
|
);
|
|
insert into t5( a, b, c) values( 9, 'recreated table', 9);
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
# 3. drop + create table (same column names/types/order+extra column)
|
|
# between prepare and execute
|
|
create table t5
|
|
(
|
|
a int primary key,
|
|
b char(30),
|
|
c int,
|
|
d timestamp default current_timestamp
|
|
);
|
|
insert into t5( a, b, c) values( 9, 'recreated table', 9);
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
# 4. drop + create table (same column names/types, different order +
|
|
# additional column) between prepare and execute
|
|
create table t5
|
|
(
|
|
a int primary key,
|
|
d timestamp default current_timestamp,
|
|
b char(30),
|
|
c int
|
|
);
|
|
insert into t5( a, b, c) values( 9, 'recreated table', 9);
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
# 5. drop + create table (same column names/order, different types)
|
|
# between prepare and execute
|
|
create table t5
|
|
(
|
|
a timestamp default '2004-02-29 18:01:59',
|
|
b char(30),
|
|
c int
|
|
);
|
|
insert into t5( b, c) values( 'recreated table', 9);
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
# 6. drop + create table (same column types/order, different names)
|
|
# between prepare and execute
|
|
create table t5
|
|
(
|
|
f1 int primary key,
|
|
f2 char(30),
|
|
f3 int
|
|
);
|
|
insert into t5( f1, f2, f3) values( 9, 'recreated table', 9);
|
|
--error 1054
|
|
execute stmt2 ;
|
|
drop table t5 ;
|
|
|
|
# execute without parameter
|
|
prepare stmt1 from ' select * from t1 where a <= 2 ' ;
|
|
execute stmt1 ;
|
|
# execute with parameter
|
|
set @arg00=1 ;
|
|
set @arg01='two' ;
|
|
prepare stmt1 from ' select * from t1 where a <= ? ' ;
|
|
execute stmt1 using @arg00;
|
|
# execute must fail (too small number of parameters)
|
|
--error 1210
|
|
execute stmt1 ;
|
|
# execute must fail (too big number of parameters)
|
|
--error 1210
|
|
execute stmt1 using @arg00, @arg01;
|
|
# execute must fail (parameter is not set)
|
|
execute stmt1 using @not_set;
|
|
|
|
################ DEALLOCATE ################
|
|
# deallocate must fail (the statement 'never_prepared' was never prepared)
|
|
--error 1243
|
|
deallocate prepare never_prepared ;
|
|
# deallocate must fail (prepare stmt1 just failed,
|
|
# but there was a successful prepare before)
|
|
prepare stmt1 from ' select * from t1 where a <= 2 ' ;
|
|
--error 1146
|
|
prepare stmt1 from ' select * from not_exist where a <= 2 ' ;
|
|
--error 1243
|
|
deallocate prepare stmt1;
|
|
create table t5
|
|
(
|
|
a int primary key,
|
|
b char(10)
|
|
);
|
|
prepare stmt2 from ' select a,b from t5 where a <= 2 ' ;
|
|
drop table t5 ;
|
|
# deallocate prepared statement where the table was dropped after prepare
|
|
deallocate prepare stmt2;
|
|
|
|
## parallel use of more than one prepared statement handlers
|
|
# switch between different queries
|
|
prepare stmt1 from ' select a from t1 where a <= 2 ' ;
|
|
prepare stmt2 from ' select b from t1 where a <= 2 ' ;
|
|
execute stmt2 ;
|
|
execute stmt1 ;
|
|
# switch between statement handlers of the same query
|
|
prepare stmt1 from ' select a from t1 where a <= 2 ' ;
|
|
prepare stmt2 from ' select a from t1 where a <= 2 ' ;
|
|
execute stmt2 ;
|
|
execute stmt1 ;
|
|
deallocate prepare stmt1 ;
|
|
# Will the deallocate of stmt1 with the same query affect stmt2 ?
|
|
execute stmt2 ;
|
|
|
|
--disable_query_log
|
|
select '------ show and misc tests ------' as test_sequence ;
|
|
--enable_query_log
|
|
|
|
--disable_warnings
|
|
drop table if exists t2;
|
|
--enable_warnings
|
|
create table t2
|
|
(
|
|
a int primary key, b char(10)
|
|
);
|
|
|
|
################ SHOW COMMANDS ################
|
|
prepare stmt4 from ' show databases ';
|
|
execute stmt4;
|
|
prepare stmt4 from ' show tables from test like ''t2%'' ';
|
|
execute stmt4;
|
|
prepare stmt4 from ' show columns from t2 from test like ''a%'' ';
|
|
execute stmt4;
|
|
create index t2_idx on t2(b);
|
|
prepare stmt4 from ' show index from t2 from test ';
|
|
execute stmt4;
|
|
prepare stmt4 from ' show table status from test like ''t2%'' ';
|
|
# egalize date and time values
|
|
--replace_column 12 # 13 # 14 #
|
|
--replace_result 2147483647 64424509439
|
|
# Bug#4288 : prepared statement 'show table status ..', wrong output on execute
|
|
execute stmt4;
|
|
# try the same with the big table
|
|
prepare stmt4 from ' show table status from test like ''t9%'' ';
|
|
# egalize date and time values
|
|
--replace_column 12 # 13 # 14 #
|
|
--replace_result 2147483647 4294967295
|
|
# Bug#4288
|
|
execute stmt4;
|
|
prepare stmt4 from ' show status like ''Threads_running'' ';
|
|
execute stmt4;
|
|
prepare stmt4 from ' show variables like ''sql_mode'' ';
|
|
execute stmt4;
|
|
prepare stmt4 from ' show engine bdb logs ';
|
|
# The output depends on the history (actions of the bdb engine).
|
|
# That is the reason why, we switch the output here off.
|
|
# (The real output will be tested in ps_6bdb.test)
|
|
# --replace_result $MYSQL_TEST_DIR TEST_DIR
|
|
--disable_result_log
|
|
execute stmt4;
|
|
--enable_result_log
|
|
prepare stmt4 from ' show full processlist ';
|
|
--replace_column 1 number 6 time 3 localhost
|
|
execute stmt4;
|
|
prepare stmt4 from ' show grants for user ';
|
|
--error 1295
|
|
prepare stmt4 from ' show create table t2 ';
|
|
--error 1295
|
|
prepare stmt4 from ' show master status ';
|
|
--error 1295
|
|
prepare stmt4 from ' show master logs ';
|
|
--error 1295
|
|
prepare stmt4 from ' show slave status ';
|
|
--error 1295
|
|
prepare stmt4 from ' show warnings limit 20 ';
|
|
--error 1295
|
|
prepare stmt4 from ' show errors limit 20 ';
|
|
prepare stmt4 from ' show storage engines ';
|
|
--replace_column 2 YES/NO
|
|
execute stmt4;
|
|
|
|
################ MISC STUFF ################
|
|
## get a warning and an error
|
|
# cases derived from client_test.c: test_warnings(), test_errors()
|
|
--disable_warnings
|
|
drop table if exists t5;
|
|
--enable_warnings
|
|
prepare stmt1 from ' drop table if exists t5 ' ;
|
|
execute stmt1 ;
|
|
prepare stmt1 from ' drop table t5 ' ;
|
|
--error 1051
|
|
execute stmt1 ;
|
|
|
|
## SELECT @@version
|
|
# cases derived from client_test.c: test_select_version()
|
|
#
|
|
# TODO: Metadata check is temporary disabled here, because metadata of
|
|
# this statement also depends on @@version contents and you can't apply
|
|
# replace_column and replace_result to it. It will be enabled again when
|
|
# support of replace_column and replace_result on metadata will be
|
|
# implemented.
|
|
#
|
|
#--enable_metadata
|
|
prepare stmt1 from ' SELECT @@version ' ;
|
|
# egalize the version
|
|
--replace_column 1 <version>
|
|
execute stmt1 ;
|
|
#--disable_metadata
|
|
|
|
## do @var:= and set @var=
|
|
# cases derived from client_test.c: test_do_set()
|
|
prepare stmt_do from ' do @var:= (1 in (select a from t1)) ' ;
|
|
prepare stmt_set from ' set @var= (1 in (select a from t1)) ' ;
|
|
let $1= 3 ;
|
|
while ($1)
|
|
{
|
|
execute stmt_do ;
|
|
--disable_query_log
|
|
select @var as 'content of @var is:' ;
|
|
--enable_query_log
|
|
execute stmt_set ;
|
|
--disable_query_log
|
|
select @var as 'content of @var is:' ;
|
|
--enable_query_log
|
|
dec $1 ;
|
|
}
|
|
# the same test with a table containing one column and 'select *'
|
|
--disable_warnings
|
|
drop table if exists t5 ;
|
|
--enable_warnings
|
|
create table t5 (a int) ;
|
|
prepare stmt_do from ' do @var:= (1 in (select a from t5)) ' ;
|
|
prepare stmt_set from ' set @var= (1 in (select a from t5)) ' ;
|
|
let $1= 3 ;
|
|
while ($1)
|
|
{
|
|
execute stmt_do ;
|
|
--disable_query_log
|
|
select @var as 'content of @var is:' ;
|
|
--enable_query_log
|
|
execute stmt_set ;
|
|
--disable_query_log
|
|
select @var as 'content of @var is:' ;
|
|
--enable_query_log
|
|
dec $1 ;
|
|
}
|
|
drop table t5 ;
|
|
deallocate prepare stmt_do ;
|
|
deallocate prepare stmt_set ;
|
|
|
|
## nonsense like prepare of prepare,execute or deallocate
|
|
--error 1064
|
|
prepare stmt1 from ' prepare stmt2 from '' select 1 '' ' ;
|
|
--error 1064
|
|
prepare stmt1 from ' execute stmt2 ' ;
|
|
--error 1064
|
|
prepare stmt1 from ' deallocate prepare never_prepared ' ;
|
|
|
|
## switch the database connection
|
|
--error 1295
|
|
prepare stmt4 from ' use test ' ;
|
|
|
|
## create/drop database
|
|
--error 1295
|
|
prepare stmt3 from ' create database mysqltest ';
|
|
create database mysqltest ;
|
|
--error 1295
|
|
prepare stmt3 from ' drop database mysqltest ';
|
|
drop database mysqltest ;
|
|
|
|
## grant/revoke + drop user
|
|
--error 1295
|
|
prepare stmt3 from ' grant all on test.t1 to drop_user@localhost
|
|
identified by ''looser'' ';
|
|
grant all on test.t1 to drop_user@localhost
|
|
identified by 'looser' ;
|
|
--error 1295
|
|
prepare stmt3 from ' revoke all privileges on test.t1 from
|
|
drop_user@localhost ';
|
|
revoke all privileges on test.t1 from drop_user@localhost ;
|
|
--error 1295
|
|
prepare stmt3 from ' drop user drop_user@localhost ';
|
|
drop user drop_user@localhost;
|
|
|
|
#### table related commands
|
|
## describe
|
|
prepare stmt3 from ' describe t2 ';
|
|
execute stmt3;
|
|
drop table t2 ;
|
|
--error 1146
|
|
execute stmt3;
|
|
## lock/unlock
|
|
--error 1295
|
|
prepare stmt3 from ' lock tables t1 read ' ;
|
|
--error 1295
|
|
prepare stmt3 from ' unlock tables ' ;
|
|
## Load/Unload table contents
|
|
--error 1295
|
|
prepare stmt1 from ' load data infile ''data.txt''
|
|
into table t1 fields terminated by ''\t'' ';
|
|
prepare stmt1 from ' select * into outfile ''data.txt'' from t1 ';
|
|
execute stmt1 ;
|
|
##
|
|
--error 1295
|
|
prepare stmt1 from ' optimize table t1 ' ;
|
|
--error 1295
|
|
prepare stmt1 from ' analyze table t1 ' ;
|
|
--error 1295
|
|
prepare stmt1 from ' checksum table t1 ' ;
|
|
--error 1295
|
|
prepare stmt1 from ' repair table t1 ' ;
|
|
--error 1295
|
|
prepare stmt1 from ' restore table t1 from ''data.txt'' ' ;
|
|
## handler
|
|
--error 1295
|
|
prepare stmt1 from ' handler t1 open ';
|
|
|
|
|
|
## commit/rollback
|
|
--error 1295
|
|
prepare stmt3 from ' commit ' ;
|
|
--error 1295
|
|
prepare stmt3 from ' rollback ' ;
|
|
|
|
|
|
## switch the sql_mode
|
|
prepare stmt4 from ' SET sql_mode=ansi ';
|
|
execute stmt4;
|
|
# check if the sql_mode is now ansi
|
|
select 'a' || 'b' ;
|
|
prepare stmt4 from ' SET sql_mode="" ';
|
|
execute stmt4;
|
|
# check if the sql_mode is not ansi
|
|
select 'a' || 'b' ;
|
|
# Will a switch of the sqlmode affect the execution of already prepared
|
|
# statements ?
|
|
prepare stmt5 from ' select ''a'' || ''b'' ' ;
|
|
execute stmt5;
|
|
SET sql_mode=ansi;
|
|
execute stmt5;
|
|
SET sql_mode="";
|
|
|
|
--error 1295
|
|
prepare stmt1 from ' flush local privileges ' ;
|
|
--error 1295
|
|
prepare stmt1 from ' reset query cache ' ;
|
|
--error 1295
|
|
prepare stmt1 from ' KILL 0 ';
|
|
|
|
## simple explain
|
|
# cases derived from client_test.c: test_explain_bug()
|
|
prepare stmt1 from ' explain select a from t1 order by b ';
|
|
# PS protocol gives slightly different metadata
|
|
--disable_ps_protocol
|
|
--enable_metadata
|
|
execute stmt1;
|
|
--disable_metadata
|
|
SET @arg00=1 ;
|
|
prepare stmt1 from ' explain select a from t1 where a > ? order by b ';
|
|
--enable_metadata
|
|
execute stmt1 using @arg00;
|
|
--disable_metadata
|
|
--enable_ps_protocol
|
|
|
|
## parameters with probably problematic characters (quote, double quote)
|
|
# cases derived from client_test.c: test_logs()
|
|
# try if
|
|
--disable_warnings
|
|
drop table if exists t2;
|
|
--enable_warnings
|
|
create table t2 (id smallint, name varchar(20)) ;
|
|
prepare stmt1 from ' insert into t2 values(?, ?) ' ;
|
|
set @id= 9876 ;
|
|
set @arg00= 'MySQL - Open Source Database' ;
|
|
set @arg01= "'" ;
|
|
set @arg02= '"' ;
|
|
set @arg03= "my'sql'" ;
|
|
set @arg04= 'my"sql"' ;
|
|
insert into t2 values ( @id , @arg00 );
|
|
insert into t2 values ( @id , @arg01 );
|
|
insert into t2 values ( @id , @arg02 );
|
|
insert into t2 values ( @id , @arg03 );
|
|
insert into t2 values ( @id , @arg04 );
|
|
prepare stmt1 from ' select * from t2 where id= ? and name= ? ';
|
|
execute stmt1 using @id, @arg00 ;
|
|
execute stmt1 using @id, @arg01 ;
|
|
execute stmt1 using @id, @arg02 ;
|
|
execute stmt1 using @id, @arg03 ;
|
|
execute stmt1 using @id, @arg04 ;
|
|
drop table t2;
|
|
|
|
################ CREATE/DROP/ALTER/RENAME TESTS ################
|
|
--disable_query_log
|
|
select '------ create/drop/alter/rename tests ------' as test_sequence ;
|
|
--enable_query_log
|
|
|
|
--disable_warnings
|
|
drop table if exists t2, t3;
|
|
--enable_warnings
|
|
|
|
## DROP TABLE
|
|
prepare stmt_drop from ' drop table if exists t2 ' ;
|
|
--disable_warnings
|
|
execute stmt_drop;
|
|
--enable_warnings
|
|
|
|
## CREATE TABLE
|
|
prepare stmt_create from ' create table t2 (
|
|
a int primary key, b char(10)) ';
|
|
execute stmt_create;
|
|
prepare stmt3 from ' create table t3 like t2 ';
|
|
execute stmt3;
|
|
drop table t3;
|
|
|
|
## CREATE TABLE .. SELECT
|
|
set @arg00=1;
|
|
prepare stmt3 from ' create table t3 (m int) select ? as m ' ;
|
|
# Bug#4280 server hangs, prepared "create table .. as select ? .."
|
|
execute stmt3 using @arg00;
|
|
select m from t3;
|
|
drop table t3;
|
|
|
|
--error 1295
|
|
prepare stmt3 from ' create index t2_idx on t2(b) ';
|
|
--error 1295
|
|
prepare stmt3 from ' drop index t2_idx on t2 ' ;
|
|
--error 1295
|
|
prepare stmt3 from ' alter table t2 drop primary key ';
|
|
|
|
## RENAME TABLE
|
|
--disable_warnings
|
|
drop table if exists new_t2;
|
|
--enable_warnings
|
|
prepare stmt3 from ' rename table t2 to new_t2 ';
|
|
execute stmt3;
|
|
--error 1050
|
|
execute stmt3;
|
|
rename table new_t2 to t2;
|
|
drop table t2;
|
|
## RENAME more than on TABLE within one statement
|
|
# cases derived from client_test.c: test_rename()
|
|
prepare stmt1 from ' rename table t5 to t6, t7 to t8 ' ;
|
|
create table t5 (a int) ;
|
|
# rename must fail, t7 does not exist
|
|
--error 1017
|
|
execute stmt1 ;
|
|
create table t7 (a int) ;
|
|
# rename, t5 -> t6 and t7 -> t8
|
|
execute stmt1 ;
|
|
# rename must fail, t5 and t7 does not exist t6 and t8 already exist
|
|
--error 1050
|
|
execute stmt1 ;
|
|
rename table t6 to t5, t8 to t7 ;
|
|
# rename, t5 -> t6 and t7 -> t8
|
|
execute stmt1 ;
|
|
drop table t6, t8 ;
|
|
|
|
|
|
################ BIG STATEMENT TESTS ################
|
|
--disable_query_log
|
|
select '------ big statement tests ------' as test_sequence ;
|
|
--enable_query_log
|
|
# The following tests use huge numbers of lines, characters or parameters
|
|
# per prepared statement.
|
|
# I assume the server and also the client (mysqltest) are stressed.
|
|
#
|
|
# Attention: The limits used are NOT derived from the manual
|
|
# or other sources.
|
|
|
|
## many lines ( 50 )
|
|
let $my_stmt= select 'ABC' as my_const_col from t1 where
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 AND
|
|
1 = 1 ;
|
|
eval ($my_stmt) ;
|
|
eval prepare stmt1 from "$my_stmt" ;
|
|
execute stmt1 ;
|
|
execute stmt1 ;
|
|
|
|
## many characters ( about 1400 )
|
|
|
|
let $my_stmt= select 'ABC' as my_const_col FROM t1 WHERE
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' AND
|
|
'1234567890123456789012345678901234567890123456789012345678901234567890'
|
|
= '1234567890123456789012345678901234567890123456789012345678901234567890' ;
|
|
eval ($my_stmt) ;
|
|
eval prepare stmt1 from "$my_stmt" ;
|
|
execute stmt1 ;
|
|
execute stmt1 ;
|
|
|
|
|
|
## many parameters ( 50 )
|
|
--disable_query_log
|
|
set @arg00= 1;
|
|
set @arg01= 1;
|
|
set @arg02= 1;
|
|
set @arg03= 1;
|
|
set @arg04= 1;
|
|
set @arg05= 1;
|
|
set @arg06= 1;
|
|
set @arg07= 1;
|
|
set @arg10= 1;
|
|
set @arg11= 1;
|
|
set @arg12= 1;
|
|
set @arg13= 1;
|
|
set @arg14= 1;
|
|
set @arg15= 1;
|
|
set @arg16= 1;
|
|
set @arg17= 1;
|
|
set @arg20= 1;
|
|
set @arg21= 1;
|
|
set @arg22= 1;
|
|
set @arg23= 1;
|
|
set @arg24= 1;
|
|
set @arg25= 1;
|
|
set @arg26= 1;
|
|
set @arg27= 1;
|
|
set @arg30= 1;
|
|
set @arg31= 1;
|
|
set @arg32= 1;
|
|
set @arg33= 1;
|
|
set @arg34= 1;
|
|
set @arg35= 1;
|
|
set @arg36= 1;
|
|
set @arg37= 1;
|
|
set @arg40= 1;
|
|
set @arg41= 1;
|
|
set @arg42= 1;
|
|
set @arg43= 1;
|
|
set @arg44= 1;
|
|
set @arg45= 1;
|
|
set @arg46= 1;
|
|
set @arg47= 1;
|
|
set @arg50= 1;
|
|
set @arg51= 1;
|
|
set @arg52= 1;
|
|
set @arg53= 1;
|
|
set @arg54= 1;
|
|
set @arg55= 1;
|
|
set @arg56= 1;
|
|
set @arg57= 1;
|
|
set @arg60= 1;
|
|
set @arg61= 1;
|
|
--enable_query_log
|
|
|
|
select 'ABC' as my_const_col FROM t1 WHERE
|
|
@arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and
|
|
@arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and
|
|
@arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and
|
|
@arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and
|
|
@arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and
|
|
@arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and @arg00=@arg00 and
|
|
@arg00=@arg00 ;
|
|
prepare stmt1 from ' select ''ABC'' as my_const_col FROM t1 WHERE
|
|
? = ? and ? = ? and ? = ? and ? = ? and
|
|
? = ? and ? = ? and ? = ? and ? = ? and
|
|
? = ? and ? = ? and ? = ? and ? = ? and
|
|
? = ? and ? = ? and ? = ? and ? = ? and
|
|
? = ? and ? = ? and ? = ? and ? = ? and
|
|
? = ? and ? = ? and ? = ? and ? = ? and
|
|
? = ? ' ;
|
|
execute stmt1 using
|
|
@arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00,
|
|
@arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00,
|
|
@arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00,
|
|
@arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00,
|
|
@arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00,
|
|
@arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00, @arg00,
|
|
@arg00, @arg00;
|
|
execute stmt1 using
|
|
@arg00, @arg01, @arg02, @arg03, @arg04, @arg05, @arg06, @arg07,
|
|
@arg10, @arg11, @arg12, @arg13, @arg14, @arg15, @arg16, @arg17,
|
|
@arg20, @arg21, @arg22, @arg23, @arg24, @arg25, @arg26, @arg27,
|
|
@arg30, @arg31, @arg32, @arg33, @arg34, @arg35, @arg36, @arg37,
|
|
@arg40, @arg41, @arg42, @arg43, @arg44, @arg45, @arg46, @arg47,
|
|
@arg50, @arg51, @arg52, @arg53, @arg54, @arg55, @arg56, @arg57,
|
|
@arg60, @arg61 ;
|
|
|
|
# cases derived from client_test.c: test_mem_overun()
|
|
--disable_warnings
|
|
drop table if exists t5 ;
|
|
--enable_warnings
|
|
|
|
set @col_num= 1000 ;
|
|
|
|
--disable_query_log
|
|
set @string= 'create table t5( ' ;
|
|
let $1=`select @col_num - 1` ;
|
|
while ($1)
|
|
{
|
|
eval set @string= concat(@string, 'c$1 int,') ;
|
|
dec $1 ;
|
|
}
|
|
set @string= concat(@string, 'c0 int)' );
|
|
--enable_query_log
|
|
select @string as "" ;
|
|
prepare stmt1 from @string ;
|
|
execute stmt1 ;
|
|
|
|
--disable_query_log
|
|
set @string= 'insert into t5 values(' ;
|
|
let $1=`select @col_num - 1` ;
|
|
while ($1)
|
|
{
|
|
eval set @string= concat(@string, '1 ,') ;
|
|
dec $1 ;
|
|
}
|
|
eval set @string= concat(@string, '1 )') ;
|
|
--enable_query_log
|
|
select @string as "" ;
|
|
prepare stmt1 from @string ;
|
|
execute stmt1 ;
|
|
|
|
prepare stmt1 from ' select * from t5 ' ;
|
|
--enable_metadata
|
|
# prevent too long lines
|
|
--vertical_results
|
|
--disable_result_log
|
|
execute stmt1 ;
|
|
--enable_result_log
|
|
--disable_metadata
|
|
--horizontal_results
|
|
|
|
drop table t5 ;
|
|
|
|
|
|
################ GRANT/REVOKE/DROP affecting a parallel session ################
|
|
--disable_query_log
|
|
select '------ grant/revoke/drop affects a parallel session test ------'
|
|
as test_sequence ;
|
|
--enable_query_log
|
|
|
|
#---------------------------------------------------------------------#
|
|
# Here we test that:
|
|
# 1. A new GRANT will be visible within another sessions. #
|
|
# #
|
|
# Let's assume there is a parallel session with an already prepared #
|
|
# statement for a table. #
|
|
# A DROP TABLE will affect the EXECUTE properties. #
|
|
# A REVOKE will affect the EXECUTE properties. #
|
|
#---------------------------------------------------------------------#
|
|
|
|
# Who am I ?
|
|
# this is different across different systems:
|
|
# select current_user(), user() ;
|
|
|
|
#### create a new user account ####
|
|
## There should be no grants for that non existing user
|
|
--error 1141
|
|
show grants for second_user@localhost ;
|
|
## create a new user account by using GRANT statements on t9
|
|
create database mysqltest;
|
|
# create the tables (t1 and t9) used in many tests
|
|
use mysqltest;
|
|
--disable_query_log
|
|
--source include/ps_create.inc
|
|
--source include/ps_renew.inc
|
|
--enable_query_log
|
|
eval use $DB;
|
|
grant usage on mysqltest.* to second_user@localhost
|
|
identified by 'looser' ;
|
|
grant select on mysqltest.t9 to second_user@localhost
|
|
identified by 'looser' ;
|
|
show grants for second_user@localhost ;
|
|
|
|
|
|
#### establish a second session to the new user account
|
|
connect (con3,localhost,second_user,looser,mysqltest);
|
|
## switch to the second session
|
|
connection con3;
|
|
# Who am I ?
|
|
select current_user();
|
|
## check the access rights
|
|
show grants for current_user();
|
|
prepare s_t9 from 'select c1 as my_col
|
|
from t9 where c1= 1' ;
|
|
execute s_t9 ;
|
|
# check that we cannot do a SELECT on the table t1;
|
|
--error 1142
|
|
select a as my_col from t1;
|
|
|
|
|
|
#### give access rights to t1 and drop table t9
|
|
## switch back to the first session
|
|
connection default;
|
|
grant select on mysqltest.t1 to second_user@localhost
|
|
identified by 'looser' ;
|
|
show grants for second_user@localhost ;
|
|
drop table mysqltest.t9 ;
|
|
show grants for second_user@localhost ;
|
|
|
|
|
|
#### check the access as new user
|
|
## switch to the second session
|
|
connection con3;
|
|
######## Question 1: The table t1 should be now accessible. ########
|
|
show grants for second_user@localhost ;
|
|
prepare s_t1 from 'select a as my_col from t1' ;
|
|
execute s_t1 ;
|
|
######## Question 2: The table t9 does not exist. ########
|
|
--error 1146
|
|
execute s_t9 ;
|
|
|
|
|
|
#### revoke the access rights to t1
|
|
## switch back to the first session
|
|
connection default;
|
|
revoke all privileges on mysqltest.t1 from second_user@localhost
|
|
identified by 'looser' ;
|
|
show grants for second_user@localhost ;
|
|
|
|
#### check the access as new user
|
|
## switch to the second session
|
|
connection con3;
|
|
show grants for second_user@localhost ;
|
|
######## Question 2: The table t1 should be now not accessible. ########
|
|
--error 1142
|
|
execute s_t1 ;
|
|
|
|
## cleanup
|
|
## switch back to the first session
|
|
connection default;
|
|
## disconnect the second session
|
|
disconnect con3 ;
|
|
## remove all rights of second_user@localhost
|
|
revoke all privileges, grant option from second_user@localhost ;
|
|
show grants for second_user@localhost ;
|
|
drop user second_user@localhost ;
|
|
commit ;
|
|
--error 1141
|
|
show grants for second_user@localhost ;
|
|
|
|
drop table t1,t9 ;
|
|
drop database mysqltest;
|
|
|
|
|
|
##### RULES OF THUMB TO PRESERVE THE SYSTEMATICS OF THE PS TEST CASES #####
|
|
#
|
|
# 0. You don't have the time to
|
|
# - read and pay attention to these rules of thumb
|
|
# - accept that QA may move your test case to a different place
|
|
# (I will not change your code!!) .
|
|
# Please append your test case to
|
|
# t/ps.test
|
|
#
|
|
# 1. You have more time and want to get as much value from you test case as
|
|
# possible. Please try to make the following decisions:
|
|
#
|
|
# Will the execution or result of the sub test case depend on the
|
|
# properties of a storage engine ?
|
|
#
|
|
# NO --> alter t/ps_1general.test (Example: Command with syntax error)
|
|
# If you need a table, please try to use
|
|
# t1 - very simple table
|
|
# t9 - table with nearly all available column types
|
|
# whenever possible.
|
|
#
|
|
# The structure and the content of these tables can be found in
|
|
# include/ps_create.inc CREATE TABLE ...
|
|
# include/ps_renew.inc DELETE all rows and INSERT some rows
|
|
#
|
|
# Both tables are managed by the same storage engine.
|
|
# The type of the storage engine is stored in the variable
|
|
# '$type' . In ps_1general.test $type is set to 'MYISAM'.
|
|
#
|
|
# Please feel free to source ps_create.inc or ps_renew.inc
|
|
# whenever you think it helps. But please restore the original
|
|
# state of these tables after your tests, because the following
|
|
# statements may depend on it.
|
|
#
|
|
# YES
|
|
# |
|
|
# |
|
|
# Is it possible to apply the sub test case to all table types ?
|
|
# YES --> alter include/ps_query.inc (for SELECTs)
|
|
# include/ps_modify.inc (for INSERT/UPDATE/DELETE)
|
|
# include/ps_modify1.inc (also for INSERT/UPDATE/DELETE,
|
|
# but t/ps_5merge.test will not source that file)
|
|
# Please try to find an appropriate place within the file.
|
|
# It would be nice if we have some systematics in the
|
|
# order of the sub test cases (if possible).
|
|
#
|
|
# Please be aware, that
|
|
# include: ps_query.inc, ps_modify.inc, ps_modify1.inc
|
|
# will be sourced by several test case files stored within the
|
|
# subdirectory 't'. So every change here will affect several test
|
|
# cases.
|
|
#
|
|
# NO
|
|
# |
|
|
# |
|
|
# Append the sub test case to the appropriate
|
|
# ps_<number><table type>.test .
|
|
#
|
|
# 2. The current structure of the PS tests
|
|
#
|
|
# t/ps_1general.test Check of basic PS features, SHOW commands and DDL
|
|
# The tests should not depend on the table type.
|
|
#
|
|
# t/ps_2myisam Check of PS on tables of type MYISAM .
|
|
# t/ps_3innodb Check of PS on tables of type InnoDB .
|
|
# ...
|
|
# t/ps_6bdb Check of PS on tables of type BDB .
|
|
# All storage engine related tests use the variable $type to hold the
|
|
# name of the storage engine.
|
|
#
|
|
# include/ps_query.inc test cases with SELECT/...
|
|
# These test cases should not modify the content or
|
|
# the structure (DROP/ALTER..) of the tables
|
|
# 't1' and 't9'.
|
|
# include/ps_modify.inc test cases with INSERT/UPDATE/...
|
|
# These test cases should not modify the structure
|
|
# (DROP/ALTER..) of the tables
|
|
# 't1' and 't9'.
|
|
# These two test sequences will be applied to all table types .
|
|
#
|
|
# include/ps_modify1.inc test cases with INSERT/UPDATE/...
|
|
# This test sequences will be applied to all table types
|
|
# except MERGE tables.
|
|
#
|
|
# include/ps_create.inc DROP and CREATE of the tables
|
|
# 't1' and 't9' .
|
|
# include/ps_renew.inc DELETE all rows and INSERT some rows, that means
|
|
# recreate the original content of these tables.
|
|
# Please do not alter the commands concerning these two tables.
|
|
#
|
|
# Please feel free and encouraged to exploit the current code sharing
|
|
# mechanism of the 'ps_<number><table type>' test cases. It is an convenient
|
|
# way to check all storage engines.
|
|
#
|
|
# Thank you for reading these rules of thumb.
|
|
#
|
|
# Matthias
|