mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-22 15:54:04 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			776 lines
		
	
	
	
		
			26 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			776 lines
		
	
	
	
		
			26 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| -- source include/have_working_dns.inc
 | |
| # This test should work in embedded server after we fix mysqltest
 | |
| -- source include/not_embedded.inc
 | |
| #
 | |
| # Testing the MySQL command line client(mysql)
 | |
| #
 | |
| set GLOBAL sql_mode="";
 | |
| set LOCAL sql_mode="";
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists t1,t2,t3;
 | |
| --enable_warnings
 | |
| 
 | |
| #
 | |
| # Test the "delimiter" functionality
 | |
| # Bug#9879
 | |
| #
 | |
| create table t1(a int);
 | |
| insert into t1 values(1);
 | |
| 
 | |
| # Test delimiters
 | |
| --exec $MYSQL test 2>&1 < "./main/mysql_delimiter.sql"
 | |
| 
 | |
| --disable_query_log
 | |
| # Test delimiter : supplied on the command line
 | |
| select "Test delimiter : from command line" as "_";
 | |
| --exec $MYSQL test --delimiter=":" -e "select * from t1:"
 | |
| # Test delimiter :; supplied on the command line
 | |
| select "Test delimiter :; from command line" as "_";
 | |
| --exec $MYSQL test --delimiter=":;" -e "select * from t1:;"
 | |
| # Test 'go' command (vertical output) \G
 | |
| select "Test 'go' command(vertical output) \G" as "_";
 | |
| --exec $MYSQL test -e "select * from t1\G"
 | |
| # Test 'go' command \g
 | |
| select "Test  'go' command \g" as "_";
 | |
| --exec $MYSQL test -e "select * from t1\g"
 | |
| --enable_query_log
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # BUG9998 - MySQL client hangs on USE "database"
 | |
| #
 | |
| create table t1(a int);
 | |
| lock tables t1 write;
 | |
| --exec $MYSQL -e "use test; select database();"
 | |
| unlock tables;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Bug#16859 -- NULLs in columns must not truncate data as if a C-language "string".
 | |
| #
 | |
| --exec $MYSQL -t test -e "create table t1 (col1 binary(4), col2 varchar(10), col3 int); insert into t1 values ('a', 'b', 123421),('a ', '0123456789', 4), ('abcd', '', 4); select concat('>',col1,'<'), col2, col3 from t1; drop table t1;" 2>&1
 | |
| 
 | |
| #
 | |
| # Bug#17939 Wrong table format when using UTF8 strings
 | |
| write_file $MYSQL_TMP_DIR/mysql_in;
 | |
| SELECT 'John Doe' as '__tañgè Ñãmé';
 | |
| SELECT '__tañgè Ñãmé' as 'John Doe';
 | |
| EOF
 | |
| --exec $MYSQL --default-character-set=utf8 --table < $MYSQL_TMP_DIR/mysql_in 2>&1
 | |
| remove_file $MYSQL_TMP_DIR/mysql_in;
 | |
| 
 | |
| #
 | |
| # Bug#18265 -- mysql client: No longer right-justifies numeric columns
 | |
| #
 | |
| write_file $MYSQL_TMP_DIR/mysql_in;
 | |
| create table t1 (i int, j int, k char(25) charset utf8); insert into t1 (i) values (1); insert into t1 (k) values ('<----------------------->'); insert into t1 (k) values ('<-----'); insert into t1 (k) values ('Τη γλώσσα'); insert into t1 (k) values ('ᛖᚴ ᚷᛖᛏ'); select * from t1; DROP TABLE t1;
 | |
| EOF
 | |
| --exec $MYSQL -t --default-character-set utf8 test < $MYSQL_TMP_DIR/mysql_in
 | |
| remove_file $MYSQL_TMP_DIR/mysql_in;
 | |
| 
 | |
| 
 | |
| #
 | |
| # "DESCRIBE" commands may return strange NULLness flags.
 | |
| #
 | |
| --exec $MYSQL --default-character-set utf8 test -e "create table t1 (i int, j int not null, k int); insert into t1 values (null, 1, null); select * from t1; describe t1; drop table t1;"
 | |
| --exec $MYSQL -t --default-character-set utf8 test -e "create table t1 (i int, j int not null, k int); insert into t1 values (null, 1, null); select * from t1; describe t1; drop table t1;"
 | |
| 
 | |
| #
 | |
| # Bug#19564: mysql displays NULL instead of space
 | |
| #
 | |
| --exec $MYSQL test -e "create table b19564 (i int, s1 char(1)); insert into b19564 values (1, 'x'); insert into b19564 values (2, NULL); insert into b19564 values (3, ' '); select * from b19564 order by i; drop table b19564;" 
 | |
| --exec $MYSQL -t test -e "create table b19564 (i int, s1 char(1)); insert into b19564 values (1, 'x'); insert into b19564 values (2, NULL); insert into b19564 values (3, ' '); select * from b19564 order by i; drop table b19564;" 
 | |
| 
 | |
| #
 | |
| # Bug#21618: NULL shown as empty string in client
 | |
| #
 | |
| --exec $MYSQL test -e "select unhex('zz');" 
 | |
| --exec $MYSQL -t test -e "select unhex('zz');" 
 | |
| 
 | |
| # Bug#19265 describe command does not work from mysql prompt
 | |
| #
 | |
| 
 | |
| create table t1(a int, b varchar(255), c int);
 | |
| --exec $MYSQL test -e "desc t1"
 | |
| --exec $MYSQL test -e "desc t1\g"
 | |
| drop table t1;
 | |
| 
 | |
| --disable_parsing
 | |
| #
 | |
| # Bug#21042  	mysql client segfaults on importing a mysqldump export
 | |
| #
 | |
| --error 1
 | |
| --exec $MYSQL test -e "connect verylongdatabasenamethatshouldblowthe256byteslongbufferincom_connectfunctionxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxkxendcccccccdxxxxxxxxxxxxxxxxxkskskskskkskskskskskskskskskskkskskskskkskskskskskskskskskend" 2>&1
 | |
| --enable_parsing
 | |
| 
 | |
| 
 | |
| #
 | |
| # Bug #20432: mysql client interprets commands in comments
 | |
| #
 | |
| 
 | |
| --let $file = $MYSQLTEST_VARDIR/tmp/bug20432.sql
 | |
| 
 | |
| # if the client sees the 'use' within the comment, we haven't fixed
 | |
| --exec echo "/*"          >  $file
 | |
| --exec echo "use"         >> $file
 | |
| --exec echo "*/"          >> $file
 | |
| --exec $MYSQL              < $file 2>&1
 | |
| 
 | |
| # SQL can have embedded comments => workie
 | |
| --exec echo "select /*"   >  $file
 | |
| --exec echo "use"         >> $file
 | |
| --exec echo "*/ 1"        >> $file
 | |
| --exec $MYSQL              < $file 2>&1
 | |
| 
 | |
| # client commands on the other hand must be at BOL => error
 | |
| --exec echo "/*"          >  $file
 | |
| --exec echo "xxx"         >> $file
 | |
| --exec echo "*/ use"      >> $file
 | |
| --error 1
 | |
| --exec $MYSQL              < $file 2>&1
 | |
| 
 | |
| # client comment recognized, but parameter missing => error
 | |
| --exec echo "use"         >  $file
 | |
| --exec $MYSQL              < $file 2>&1
 | |
| 
 | |
| # Test exceutable comments
 | |
| --exec echo "SELECT 1 /*! +1 */;"       > $file
 | |
| --exec echo "SELECT 1 /*M! +1 */;"      >> $file
 | |
| --exec echo "SELECT 1 /*!00000 +1 */;"  >> $file
 | |
| --exec echo "SELECT 1 /*M!00000 +1 */" >> $file
 | |
| --exec $MYSQL                           < $file 2>&1
 | |
| 
 | |
| --remove_file $file
 | |
| 
 | |
| #
 | |
| # Bug #20328: mysql client interprets commands in comments
 | |
| #
 | |
| --let $file1 = $MYSQLTEST_VARDIR/tmp/bug20328_1.result
 | |
| --let $file2 = $MYSQLTEST_VARDIR/tmp/bug20328_2.result
 | |
| --exec $MYSQL -e "help" > $file1
 | |
| --exec $MYSQL -e "help " > $file2
 | |
| --diff_files $file1 $file2
 | |
| --remove_file $file1
 | |
| --remove_file $file2
 | |
| 
 | |
| #
 | |
| # Bug #19216: Client crashes on long SELECT
 | |
| #
 | |
| # Create large SELECT
 | |
| # - 3400 * 20 makes 68000 columns that is more than the
 | |
| #   max number that can fit in a 16 bit number.
 | |
| 
 | |
| --perl
 | |
| open(FILE,">","$ENV{'MYSQLTEST_VARDIR'}/tmp/b19216.tmp") or die;
 | |
| print FILE "select\n";
 | |
| print FILE "'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a',\n" x 3400;
 | |
| print FILE "'b';\n";
 | |
| close FILE;
 | |
| EOF
 | |
| 
 | |
| --disable_query_log
 | |
| --exec $MYSQL < $MYSQLTEST_VARDIR/tmp/b19216.tmp >/dev/null
 | |
| --enable_query_log
 | |
| 
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/b19216.tmp
 | |
| 
 | |
| #
 | |
| # Bug #20103: Escaping with backslash does not work
 | |
| #
 | |
| --let $file = $MYSQLTEST_VARDIR/tmp/bug20103.sql
 | |
| --exec echo "SET SQL_MODE = 'NO_BACKSLASH_ESCAPES';"  > $file
 | |
| --exec echo "SELECT '\';" >> $file
 | |
| --exec $MYSQL < $file 2>&1
 | |
| 
 | |
| --exec echo "SET SQL_MODE = '';"  > $file
 | |
| --exec echo "SELECT '\';';" >> $file
 | |
| --exec $MYSQL              < $file 2>&1
 | |
| --remove_file $file
 | |
| 
 | |
| #
 | |
| # Bug#17583: mysql drops connection when stdout is not writable
 | |
| #
 | |
| create table t17583 (a int);
 | |
| insert into t17583 (a) values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
 | |
| insert into t17583 select a from t17583;
 | |
| insert into t17583 select a from t17583;
 | |
| insert into t17583 select a from t17583;
 | |
| insert into t17583 select a from t17583;
 | |
| insert into t17583 select a from t17583;
 | |
| insert into t17583 select a from t17583;
 | |
| insert into t17583 select a from t17583;
 | |
| # Close to the minimal data needed to exercise bug.
 | |
| select count(*) from t17583;
 | |
| --exec echo "select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; select count(*) from t17583; " |$MYSQL test >&-
 | |
| drop table t17583;
 | |
| 
 | |
| #
 | |
| # Bug#20984: Reproducible MySQL client segmentation fault
 | |
| #  + additional tests for the "com_connect" function in mysql
 | |
| #
 | |
| #
 | |
| --echo Test connect without db- or host-name => reconnect
 | |
| --exec $MYSQL test -e "\r" 2>&1
 | |
| --exec $MYSQL test -e "connect" 2>&1
 | |
| 
 | |
| --echo Test connect with dbname only => new dbname, old hostname
 | |
| --exec $MYSQL test -e "\r test" 2>&1
 | |
| --exec $MYSQL test -e "connect test" 2>&1
 | |
| --exec $MYSQL test -e "\rtest" 2>&1
 | |
| --error 1
 | |
| --exec $MYSQL test -e "connecttest" 2>&1
 | |
| 
 | |
| --echo Test connect with _invalid_ dbname only => new invalid dbname, old hostname
 | |
| --error 1
 | |
| --exec $MYSQL test -e "\r invalid" 2>&1
 | |
| --error 1
 | |
| --exec $MYSQL test -e "connect invalid" 2>&1
 | |
| 
 | |
| --echo Test connect with dbname + hostname
 | |
| --exec $MYSQL test -e "\r test localhost" 2>&1
 | |
| --exec $MYSQL test -e "connect test localhost" 2>&1
 | |
| 
 | |
| --echo Test connect with dbname + _invalid_ hostname
 | |
| # Mask the errno of the error message
 | |
| --replace_regex /\([0-9|-]*\)/(errno)/
 | |
| --error 1
 | |
| --exec $MYSQL test -e "\r test invalid_hostname" 2>&1
 | |
| --replace_regex /\([0-9|-]*\)/(errno)/
 | |
| --error 1
 | |
| --exec $MYSQL test -e "connect test invalid_hostname" 2>&1
 | |
| 
 | |
| --echo The commands reported in the bug report
 | |
| --replace_regex /\([0-9|-]*\)/(errno)/
 | |
| --error 1
 | |
| --exec $MYSQL test -e "\r\r\n\r\n cyril\ has\ found\ a\ bug\ :)XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" 2>&1
 | |
| 
 | |
| #--replace_regex /\([0-9|-]*\)/(errno)/
 | |
| #--error 1
 | |
| #--exec echo '\r\r\n\r\n cyril\ has\ found\ a\ bug\ :)XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX' | $MYSQL 2>&1
 | |
| 
 | |
| --echo Too long dbname
 | |
| --error 1
 | |
| --exec $MYSQL test -e "\r test_really_long_dbnamexxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx localhost" 2>&1
 | |
| 
 | |
| --echo Too long hostname
 | |
| --replace_regex /\([0-9|-]*\)/(errno)/
 | |
| --error 1
 | |
| --exec $MYSQL test -e "\r  test cyrils_superlonghostnameXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" 2>&1
 | |
| 
 | |
| 
 | |
| #
 | |
| # Bug #21412: mysql cmdline client allows backslash(es) 
 | |
| # as delimiter but can't recognize them
 | |
| #
 | |
| 
 | |
| # This should work just fine...
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug21412.sql
 | |
| DELIMITER /
 | |
| SELECT 1/
 | |
| EOF
 | |
| --exec $MYSQL             < $MYSQLTEST_VARDIR/tmp/bug21412.sql 2>&1
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug21412.sql;
 | |
| 
 | |
| # This should give an error...
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug21412.sql
 | |
| DELIMITER \
 | |
| EOF
 | |
| --exec $MYSQL             < $MYSQLTEST_VARDIR/tmp/bug21412.sql 2>&1
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug21412.sql;
 | |
| 
 | |
| # As should this...
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug21412.sql
 | |
| DELIMITER \\
 | |
| EOF
 | |
| --exec $MYSQL             < $MYSQLTEST_VARDIR/tmp/bug21412.sql 2>&1
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug21412.sql;
 | |
| 
 | |
| #
 | |
| # Some coverage of not normally used parts
 | |
| #
 | |
| 
 | |
| --disable_query_log
 | |
| --exec $MYSQL test -e "show status" 2>&1 > /dev/null
 | |
| --exec $MYSQL --help 2>&1 > /dev/null
 | |
| --exec $MYSQL --version 2>&1 > /dev/null
 | |
| --enable_query_log
 | |
| 
 | |
| #
 | |
| # bug #26851: Mysql Client --pager Buffer Overflow
 | |
| #
 | |
| 
 | |
| # allow error 7(invalid argument) since --pager does not always exist in mysql
 | |
| --error 0,7
 | |
| --exec $MYSQL --pager="540bytelengthstringxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" -e "select 1" > /dev/null 2>&1
 | |
| --exec $MYSQL --character-sets-dir="540bytelengthstringxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" -e "select 1" 2>&1
 | |
| 
 | |
| #
 | |
| # bug #30164: Using client side macro inside server side comments generates broken queries
 | |
| #
 | |
| --exec $MYSQL test -e "/*! \C latin1 */ select 1;"
 | |
| 
 | |
| #
 | |
| # Bug#29323 mysql client only accetps ANSI encoded files
 | |
| #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug29323.sql
 | |
| select "This is a file starting with UTF8 BOM 0xEFBBBF";
 | |
| EOF
 | |
| --exec $MYSQL < $MYSQLTEST_VARDIR/tmp/bug29323.sql 2>&1
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug29323.sql;
 | |
| 
 | |
| #
 | |
| # Bug #33812: mysql client incorrectly parsing DELIMITER
 | |
| #
 | |
| # The space and ; after delimiter are important
 | |
| --exec $MYSQL -e "select 1 delimiter ;"
 | |
| 
 | |
| #
 | |
| # Bug #38158: mysql client regression, can't read dump files
 | |
| #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug38158.sql
 | |
| -- Testing
 | |
| --
 | |
| delimiter ||
 | |
| select 2 ||
 | |
| EOF
 | |
| --exec $MYSQL < $MYSQLTEST_VARDIR/tmp/bug38158.sql 2>&1
 | |
| --exec $MYSQL -c < $MYSQLTEST_VARDIR/tmp/bug38158.sql 2>&1
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug38158.sql;
 | |
| 
 | |
| #
 | |
| # Bug #41437: Value stored in 'case' lacks charset, causees segfault
 | |
| #
 | |
| --exec $MYSQL -e "select @z:='1',@z=database()"
 | |
| 
 | |
| 
 | |
| #
 | |
| # Bug #31060: MySQL CLI parser bug 2
 | |
| #
 | |
| 
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug31060.sql
 | |
| ;DELIMITER DELIMITER
 | |
| ;
 | |
| SELECT 1DELIMITER
 | |
| DELIMITER ;
 | |
| SELECT 1;
 | |
| EOF
 | |
| 
 | |
| --exec $MYSQL < $MYSQLTEST_VARDIR/tmp/bug31060.sql 2>&1
 | |
| 
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug31060.sql;
 | |
| 
 | |
| #
 | |
| # Bug #39101: client -i (--ignore-spaces) option does not seem to work
 | |
| #
 | |
| --exec $MYSQL -i -e "SELECT COUNT (*)"
 | |
| --exec $MYSQL --ignore-spaces -e "SELECT COUNT (*)"
 | |
| --exec $MYSQL -b -i -e "SELECT COUNT (*)"
 | |
| 
 | |
| #
 | |
| # Bug#37268 'binary' character set makes CLI-internal commands case sensitive
 | |
| #
 | |
| --replace_regex /\([0-9|-]*\)/(errno)/
 | |
| --error 1
 | |
| --exec $MYSQL --default-character-set=binary test -e "CONNECT test invalid_hostname" 2>&1
 | |
| --exec $MYSQL --default-character-set=binary test -e "DELIMITER //" 2>&1
 | |
| 
 | |
| --echo End of 5.0 tests
 | |
| 
 | |
| #
 | |
| # Bug #29903: The CMake build method does not produce the embedded library.
 | |
| #
 | |
| --disable_query_log
 | |
| --exec $MYSQL --server-arg=no-defaults test -e "quit"
 | |
| --enable_query_log
 | |
| 
 | |
| #
 | |
| # Bug#26780: patch to add auto vertical output option to the cli.
 | |
| #
 | |
| # Make this wide enough that it will wrap almost everywhere.
 | |
| --exec $MYSQL test --auto-vertical-output --table -e "SELECT 1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0;"
 | |
| # Too short to wrap.
 | |
| --exec $MYSQL test --auto-vertical-output --table -e "SELECT 1;"
 | |
| 
 | |
| #
 | |
| # Bug #25146: Some warnings/errors not shown when using --show-warnings
 | |
| #
 | |
| 
 | |
| # This one should succeed with no warnings
 | |
| --exec $MYSQL --show-warnings test -e "create table t1 (id int)"
 | |
| 
 | |
| # This should succeed, with warnings about conversion from nonexistent engine
 | |
| --exec $MYSQL --show-warnings test -e "create table t2 (id int) engine=nonexistent"
 | |
| 
 | |
| # This should fail, with warnings as well
 | |
| --error 1
 | |
| --exec $MYSQL --show-warnings test -e "create table t2 (id int) engine=nonexistent2"
 | |
| 
 | |
| drop tables t1, t2;
 | |
| 
 | |
| #
 | |
| # mysql client with 'init-command' option
 | |
| #
 | |
| --exec $MYSQL --init-command="SET lc_messages=ru_RU" -e "SHOW VARIABLES LIKE 'lc_messages';"
 | |
| 
 | |
| #
 | |
| # Bug #27884: mysql --html does not quote HTML special characters in output
 | |
| # 
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug27884.sql
 | |
| SELECT '< & >' AS `<`;
 | |
| EOF
 | |
| --exec $MYSQL --html test < $MYSQLTEST_VARDIR/tmp/bug27884.sql
 | |
| 
 | |
| remove_file $MYSQLTEST_VARDIR/tmp/bug27884.sql;
 | |
| 
 | |
| 
 | |
| #
 | |
| # Bug #28203: mysql client + null byte
 | |
| # 
 | |
| create table t1 (a char(5));
 | |
| insert into t1 values ('\0b\0');
 | |
| --exec $MYSQL test -e "select a from t1"
 | |
| --exec $MYSQL -r test -e "select a from t1"
 | |
| --exec $MYSQL -s test -e "select a from t1"
 | |
| --exec $MYSQL --table test -e "select a from t1"
 | |
| --exec $MYSQL --vertical test -e "select a from t1"
 | |
| --exec $MYSQL --html test -e "select a from t1"
 | |
| --exec $MYSQL --xml test -e "select a from t1"
 | |
| drop table t1;
 | |
| 
 | |
| --echo
 | |
| --echo Bug #47147: mysql client option --skip-column-names does not apply to vertical output
 | |
| --echo
 | |
| --exec $MYSQL --skip-column-names --vertical test -e "select 1 as a"
 | |
| 
 | |
| #
 | |
| # Bug#57450: mysql client enter in an infinite loop if the standard input is a directory
 | |
| #
 | |
| --error 1
 | |
| --exec $MYSQL < .
 | |
| 
 | |
| --echo
 | |
| 
 | |
| --echo #
 | |
| --echo # Bug #54899: --one-database option cannot handle DROP/CREATE DATABASE 
 | |
| --echo #             commands.
 | |
| --echo #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/bug54899.sql
 | |
| DROP DATABASE connected_db;
 | |
| CREATE DATABASE connected_db;
 | |
| USE connected_db;
 | |
| CREATE TABLE `table_in_connected_db`(a INT);
 | |
| EOF
 | |
| 
 | |
| CREATE DATABASE connected_db;
 | |
| --exec $MYSQL --one-database connected_db < $MYSQLTEST_VARDIR/tmp/bug54899.sql
 | |
| USE connected_db;
 | |
| SHOW TABLES;
 | |
| DROP DATABASE connected_db;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/bug54899.sql
 | |
| 
 | |
| --echo
 | |
| 
 | |
| --echo #
 | |
| --echo # Testing --one-database option
 | |
| --echo #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| CREATE TABLE t1 (i INT);
 | |
| CREATE TABLE test.t1 (i INT);
 | |
| USE test;
 | |
| # Following statements should be filtered.
 | |
| CREATE TABLE connected_db.t2 (i INT);
 | |
| CREATE TABLE t2 (i INT);
 | |
| EOF
 | |
| 
 | |
| CREATE DATABASE connected_db;
 | |
| --exec $MYSQL --one-database connected_db < $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| SHOW TABLES IN connected_db;
 | |
| SHOW TABLES IN test;
 | |
| USE test;
 | |
| DROP TABLE t1;
 | |
| DROP DATABASE connected_db;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| 
 | |
| --echo
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| CREATE DATABASE test1;
 | |
| USE test1;
 | |
| USE test1;
 | |
| # Following statements should be filtered.
 | |
| CREATE TABLE connected_db.t1 (i INT);
 | |
| EOF
 | |
| 
 | |
| --exec $MYSQL --one-database test < $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| SHOW TABLES IN test;
 | |
| SHOW TABLES IN test1;
 | |
| DROP DATABASE test1;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| 
 | |
| --echo
 | |
| 
 | |
| --echo #
 | |
| --echo # Checking --one-database option followed by the execution of 
 | |
| --echo # connect command.
 | |
| --echo #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| CREATE TABLE t1 (i INT);
 | |
| CREATE TABLE test.t1 (i INT);
 | |
| CONNECT test;
 | |
| CREATE TABLE connected_db.t2 (i INT);
 | |
| CREATE TABLE t2 (i INT);
 | |
| USE connected_db;
 | |
| # Following statements should be filtered.
 | |
| CREATE TABLE connected_db.t3 (i INT);
 | |
| CREATE TABLE t3 (i INT);
 | |
| EOF
 | |
| 
 | |
| CREATE DATABASE connected_db;
 | |
| --exec $MYSQL --one-database connected_db < $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| SHOW TABLES IN connected_db;
 | |
| SHOW TABLES IN test;
 | |
| DROP TABLE test.t1;
 | |
| DROP TABLE test.t2;
 | |
| DROP DATABASE connected_db;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| 
 | |
| --echo
 | |
| 
 | |
| --echo #
 | |
| --echo # Checking --one-database option with no database specified
 | |
| --echo # at command-line.
 | |
| --echo #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| # All following statements should be filtered.
 | |
| CREATE TABLE t1 (i INT);
 | |
| CREATE TABLE test.t1 (i INT);
 | |
| USE test;
 | |
| CREATE TABLE test.t2 (i INT);
 | |
| CREATE TABLE t2 (i INT);
 | |
| EOF
 | |
| 
 | |
| --exec $MYSQL --one-database < $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| SHOW TABLES IN test;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/one_db.sql
 | |
| 
 | |
| --echo
 | |
| 
 | |
| --echo #
 | |
| --echo # Checking --one-database option with non_existent_db 
 | |
| --echo # specified with USE command
 | |
| --echo #
 | |
| 
 | |
| # CASE 1 : When 'connected_db' database exists and passed at commandline.
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/one_db_1.sql
 | |
| CREATE TABLE `table_in_connected_db`(i INT);
 | |
| USE non_existent_db;
 | |
| # Following statement should be filtered out.
 | |
| CREATE TABLE `table_in_non_existent_db`(i INT);
 | |
| EOF
 | |
| 
 | |
| # CASE 2 : When 'connected_db' database exists but dropped and recreated in
 | |
| # load file.
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/one_db_2.sql
 | |
| DROP DATABASE connected_db;
 | |
| CREATE DATABASE connected_db;
 | |
| USE non_existent_db;
 | |
| # Following statements should be filtered out.
 | |
| CREATE TABLE `table_in_non_existent_db`(i INT);
 | |
| USE connected_db;
 | |
| # Following statements should not be filtered out.
 | |
| CREATE TABLE `table_in_connected_db`(i INT);
 | |
| EOF
 | |
| 
 | |
| CREATE DATABASE connected_db;
 | |
| --exec $MYSQL --one-database connected_db < $MYSQLTEST_VARDIR/tmp/one_db_1.sql
 | |
| SHOW TABLES IN connected_db;
 | |
| --echo
 | |
| --exec $MYSQL --one-database connected_db < $MYSQLTEST_VARDIR/tmp/one_db_2.sql
 | |
| SHOW TABLES IN connected_db;
 | |
| DROP DATABASE connected_db;
 | |
| 
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/one_db_1.sql
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/one_db_2.sql
 | |
| 
 | |
| #
 | |
| # USE and names with backticks
 | |
| #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/backticks.sql
 | |
| \u aa`bb``cc
 | |
| SELECT DATABASE();
 | |
| USE test
 | |
| SELECT DATABASE();
 | |
| USE aa`bb``cc
 | |
| SELECT DATABASE();
 | |
| USE test
 | |
| SELECT DATABASE();
 | |
| USE `aa``bb````cc`
 | |
| SELECT DATABASE();
 | |
| EOF
 | |
| create database `aa``bb````cc`;
 | |
| --exec $MYSQL < $MYSQLTEST_VARDIR/tmp/backticks.sql
 | |
| drop database `aa``bb````cc`;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/backticks.sql
 | |
| 
 | |
| #
 | |
| # MySQL Bug#13639125 DELIMITER STRIPS THE NEXT NEW LINE IN A SQL STATEMENT
 | |
| #
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/13639125.sql
 | |
| select ">>
 | |
| delimiter
 | |
| <<" as a;
 | |
| EOF
 | |
| --exec $MYSQL < $MYSQLTEST_VARDIR/tmp/13639125.sql
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/13639125.sql
 | |
| 
 | |
| #
 | |
| # --skip-column-names and alignment
 | |
| #
 | |
| --exec $MYSQL -t -N -e "SELECT 'a' union select 'aaaaaaaaaaaaaaaaa'"
 | |
| 
 | |
| --echo #
 | |
| --echo # Start of 10.1 tests
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-6572 "USE dbname" with a bad sequence erroneously connects to a wrong database
 | |
| --echo #
 | |
| 
 | |
| --echo #
 | |
| --echo # End of 10.1 tests
 | |
| --echo #
 | |
| 
 | |
| 
 | |
| --write_file $MYSQLTEST_VARDIR/tmp/mdev-6572.sql
 | |
| SET NAMES utf8;
 | |
| USE test😁 ;
 | |
| EOF
 | |
| --error 1
 | |
| --exec $MYSQL --default-character-set=utf8 < $MYSQLTEST_VARDIR/tmp/mdev-6572.sql 2>&1
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/mdev-6572.sql
 | |
| 
 | |
| set GLOBAL sql_mode=default;
 | |
| --echo
 | |
| --echo End of tests
 | |
| 
 | |
| #
 | |
| # MDEV-13187 incorrect backslash parsing in clients
 | |
| #
 | |
| create table `a1\``b1` (a int);
 | |
| show tables;
 | |
| insert `a1\``b1` values (1),(2);
 | |
| show create table `a1\``b1`;
 | |
| --exec $MYSQL_DUMP --compact test
 | |
| --exec $MYSQL_DUMP test > $MYSQLTEST_VARDIR/tmp/bug.sql
 | |
| insert `a1\``b1` values (4),(5);
 | |
| --exec $MYSQL test < $MYSQLTEST_VARDIR/tmp/bug.sql
 | |
| show create table `a1\``b1`;
 | |
| select * from `a1\``b1`;
 | |
| drop table `a1\``b1`;
 | |
| 
 | |
| # same with ansi_quotes
 | |
| set sql_mode=ansi_quotes;
 | |
| create table "a1\""b1" (a int);
 | |
| show tables;
 | |
| insert "a1\""b1" values (1),(2);
 | |
| show create table "a1\""b1";
 | |
| --exec $MYSQL_DUMP --compact --compatible=postgres test
 | |
| --exec $MYSQL_DUMP --compatible=postgres test > $MYSQLTEST_VARDIR/tmp/bug.sql
 | |
| insert "a1\""b1" values (4),(5);
 | |
| --exec $MYSQL test < $MYSQLTEST_VARDIR/tmp/bug.sql
 | |
| show create table "a1\""b1";
 | |
| select * from "a1\""b1";
 | |
| drop table "a1\""b1";
 | |
| set sql_mode=default;
 | |
| 
 | |
| #
 | |
| # mysql --local-infile
 | |
| #
 | |
| --let $ldli = load data local infile '$MYSQLTEST_VARDIR/tmp/bug.sql' into table test.t1;
 | |
| create table t1 (a text);
 | |
| --exec $MYSQL -e "$ldli"
 | |
| select count(*) from t1; truncate table t1;
 | |
| --exec $MYSQL --enable-local-infile -e "$ldli"
 | |
| select count(*) from t1; truncate table t1;
 | |
| --error 1
 | |
| --exec $MYSQL --disable-local-infile -e "$ldli"
 | |
| select count(*) from t1; truncate table t1;
 | |
| --error 1
 | |
| --exec $MYSQL --local-infile=0 -e "/*q*/$ldli"
 | |
| select count(*) from t1; truncate table t1;
 | |
| --exec $MYSQL --enable-local-infile -e "/*q*/$ldli"
 | |
| select count(*) from t1; truncate table t1;
 | |
|  --error 1
 | |
|  --exec $MYSQL --disable-local-infile -e "/*q*/$ldli"
 | |
| select count(*) from t1; truncate table t1;
 | |
| drop table t1;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/bug.sql
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-15538 '-N' Produce html output wrong
 | |
| --echo #
 | |
| --exec $MYSQL -NHe "select 1 as a"
 | |
| 
 | |
| 
 | |
| #
 | |
| # Test obsolete option --enable-cleartext-plugin
 | |
| # This should proceed with a warning
 | |
| #
 | |
| --echo
 | |
| --exec $MYSQL test --enable-cleartext-plugin -e "select 1"
 | |
| 
 | |
| --echo # End of 10.3 tests
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-21778 Disable system commands in mysql/mariadb client
 | |
| --echo #
 | |
| 
 | |
| --error 1
 | |
| --exec $MYSQL --sandbox -Ne "select 1; \! echo foo; select 0" 2>&1
 | |
| --error 1
 | |
| --exec $MYSQL --sandbox -Ne "select 2; \T echo foo; select 0" 2>&1
 | |
| --error 1
 | |
| --exec $MYSQL --sandbox -Ne "select 3; \. echo.foo; select 0" 2>&1
 | |
| 
 | |
| --write_file $MYSQL_TMP_DIR/mysql_in
 | |
| select 'entering sandbox';
 | |
| \-
 | |
| select 'system';
 | |
| \! echo foo
 | |
| select 'tee';
 | |
| \T echo foo
 | |
| select 'source';
 | |
| \. echo.foo
 | |
| select '^^^';
 | |
| EOF
 | |
| 
 | |
| write_line "select 1;
 | |
| source $MYSQL_TMP_DIR/mysql_in;
 | |
| select 2;
 | |
| source $MYSQL_TMP_DIR/mysql_in;
 | |
| sandbox;
 | |
| select 3;
 | |
| source $MYSQL_TMP_DIR/mysql_in;" $MYSQL_TMP_DIR/mysql_in2;
 | |
| 
 | |
| --exec $MYSQL -fN <$MYSQL_TMP_DIR/mysql_in2
 | |
| 
 | |
| --remove_file $MYSQL_TMP_DIR/mysql_in
 | |
| --remove_file $MYSQL_TMP_DIR/mysql_in2
 | |
| 
 | |
| --echo #
 | |
| --echo # MDEV-34203: Sandbox mode \- is not compatible with --binary-mode
 | |
| --echo #
 | |
| 
 | |
| create table t1 (a int);
 | |
| 
 | |
| --exec $MYSQL_DUMP test t1 > $MYSQLTEST_VARDIR/tmp/MDEV-34203.sql
 | |
| 
 | |
| drop table t1;
 | |
| 
 | |
| --exec $MYSQL --binary-mode test 2>&1 < $MYSQLTEST_VARDIR/tmp/MDEV-34203.sql
 | |
| 
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| --remove_file $MYSQLTEST_VARDIR/tmp/MDEV-34203.sql
 | |
| 
 | |
| --echo # End of 10.5 tests
 | 
