mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 13:02:28 +01:00
6388a13230
The additional patch. That 'loadxml.test' failure was actually about our testing system, not the code. Firstly we need a new mysqltest command, wich i called 'send_eval'. So the expression can be evaluated, then started in a parallel thread. We only have separane 'send' and 'eval' commands at the moment. Then we need to add the waiting code after the 'KILL' to our test, so the thread will be killed before the test goes further. The present 'reap' command doesn't handle the killed threads well. per-file comments: client/mysqltest.cc Bug#42520 killing load .. infile Assertion failed: ! is_set(), file .\sql_error.cc, line 8 The 'send_eval' command implemented. mysql-test/r/loadxml.result Bug#42520 killing load .. infile Assertion failed: ! is_set(), file .\sql_error.cc, line 8 test result updated. mysql-test/t/loadxml.test Bug#42520 killing load .. infile Assertion failed: ! is_set(), file .\sql_error.cc, line 8 test case added.
110 lines
2.9 KiB
Text
110 lines
2.9 KiB
Text
#
|
|
# Tests for "LOAD XML" - a contributed patch from Erik Wetterberg.
|
|
#
|
|
|
|
# Running the $MYSQL_DUMP tool against an embedded server does not work.
|
|
--source include/not_embedded.inc
|
|
|
|
--disable_warnings
|
|
drop table if exists t1, t2;
|
|
--enable_warnings
|
|
|
|
create table t1 (a int, b varchar(64));
|
|
|
|
|
|
--echo -- Load a static XML file
|
|
load xml infile '../../std_data/loadxml.dat' into table t1
|
|
rows identified by '<row>';
|
|
select * from t1 order by a;
|
|
delete from t1;
|
|
|
|
|
|
--echo -- Load a static XML file with 'IGNORE num ROWS'
|
|
load xml infile '../../std_data/loadxml.dat' into table t1
|
|
rows identified by '<row>' ignore 4 rows;
|
|
select * from t1 order by a;
|
|
|
|
|
|
--echo -- Check 'mysqldump --xml' + 'LOAD XML' round trip
|
|
--exec $MYSQL_DUMP --xml test t1 > "$MYSQLTEST_VARDIR/tmp/loadxml-dump.xml" 2>&1
|
|
delete from t1;
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
--eval load xml infile '$MYSQLTEST_VARDIR/tmp/loadxml-dump.xml' into table t1 rows identified by '<row>';
|
|
select * from t1 order by a;
|
|
|
|
--echo --Check that default row tag is '<row>
|
|
delete from t1;
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
--eval load xml infile '$MYSQLTEST_VARDIR/tmp/loadxml-dump.xml' into table t1;
|
|
select * from t1 order by a;
|
|
|
|
--echo -- Check that 'xml' is not a keyword
|
|
select 1 as xml;
|
|
|
|
|
|
#
|
|
# Bug #42520 killing load .. infile Assertion failed: ! is_set(), file .\sql_error.cc, line 8
|
|
#
|
|
|
|
--disable_query_log
|
|
delete from t1;
|
|
insert into t1 values (1, '12345678900987654321'), (2, 'asdfghjkl;asdfghjkl;');
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
insert into t1 select * from t1;
|
|
--exec $MYSQL_DUMP --xml test t1 > "$MYSQLTEST_VARDIR/tmp/loadxml-dump.xml" 2>&1
|
|
--enable_query_log
|
|
|
|
connect (addconroot, localhost, root,,);
|
|
connection addconroot;
|
|
create table t2(fl text);
|
|
--let $PSEUDO_THREAD_ID=`select @@pseudo_thread_id `
|
|
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
--send_eval LOAD XML LOCAL INFILE "$MYSQLTEST_VARDIR/tmp/loadxml-dump.xml" INTO TABLE t2 ROWS IDENTIFIED BY '<person>';
|
|
|
|
sleep 3;
|
|
|
|
|
|
connection default;
|
|
sleep 1;
|
|
--replace_column 1 # 3 localhost 6 #
|
|
show processlist;
|
|
|
|
--disable_query_log
|
|
--eval kill $PSEUDO_THREAD_ID
|
|
sleep 2;
|
|
--enable_query_log
|
|
|
|
disconnect addconroot;
|
|
|
|
#
|
|
# Clean up
|
|
#
|
|
remove_file $MYSQLTEST_VARDIR/tmp/loadxml-dump.xml;
|
|
drop table t1;
|
|
drop table t2;
|
|
|
|
#
|
|
# Bug #36750 LOAD XML doesn't understand new line (feed) characters in multi line text fields
|
|
#
|
|
|
|
create table t1 (
|
|
id int(11) not null,
|
|
text text,
|
|
primary key (id)
|
|
) engine=MyISAM default charset=latin1;
|
|
load xml infile '../../std_data/loadxml2.dat' into table t1;
|
|
select * from t1;
|
|
drop table t1;
|
|
|