Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
ee8a682b
Commit
ee8a682b
authored
Aug 06, 2008
by
Sven Sandberg
Browse files
Options
Browse Files
Download
Plain Diff
merged 5.1 main -> 5.1-rpl-testfixes
all files automerged without conflict
parents
cf12cdc1
8b9b4b28
Changes
15
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
180 additions
and
87 deletions
+180
-87
mysql-test/extra/binlog_tests/binlog_insert_delayed.test
mysql-test/extra/binlog_tests/binlog_insert_delayed.test
+40
-16
mysql-test/include/show_binlog_events.inc
mysql-test/include/show_binlog_events.inc
+2
-2
mysql-test/suite/binlog/r/binlog_killed_simulate.result
mysql-test/suite/binlog/r/binlog_killed_simulate.result
+1
-1
mysql-test/suite/binlog/r/binlog_row_binlog.result
mysql-test/suite/binlog/r/binlog_row_binlog.result
+2
-2
mysql-test/suite/binlog/r/binlog_row_mix_innodb_myisam.result
...l-test/suite/binlog/r/binlog_row_mix_innodb_myisam.result
+1
-1
mysql-test/suite/binlog/r/binlog_statement_insert_delayed.result
...est/suite/binlog/r/binlog_statement_insert_delayed.result
+2
-2
mysql-test/suite/binlog/r/binlog_stm_binlog.result
mysql-test/suite/binlog/r/binlog_stm_binlog.result
+2
-2
mysql-test/suite/binlog/r/binlog_stm_mix_innodb_myisam.result
...l-test/suite/binlog/r/binlog_stm_mix_innodb_myisam.result
+2
-2
mysql-test/suite/rpl/r/rpl_loaddata_map.result
mysql-test/suite/rpl/r/rpl_loaddata_map.result
+13
-8
mysql-test/suite/rpl/r/rpl_stm_log.result
mysql-test/suite/rpl/r/rpl_stm_log.result
+1
-1
mysql-test/suite/rpl/r/rpl_variables.result
mysql-test/suite/rpl/r/rpl_variables.result
+13
-13
mysql-test/suite/rpl/t/rpl_incident.test
mysql-test/suite/rpl/t/rpl_incident.test
+31
-0
mysql-test/suite/rpl/t/rpl_loaddata_map.test
mysql-test/suite/rpl/t/rpl_loaddata_map.test
+33
-14
mysql-test/suite/rpl/t/rpl_trunc_temp.test
mysql-test/suite/rpl/t/rpl_trunc_temp.test
+26
-12
mysql-test/suite/rpl/t/rpl_variables.test
mysql-test/suite/rpl/t/rpl_variables.test
+11
-11
No files found.
mysql-test/extra/binlog_tests/binlog_insert_delayed.test
View file @
ee8a682b
# Test of binlogging of INSERT_ID with INSERT DELAYED
# ==== Purpose ====
#
# Verify that INSERT DELAYED in mixed or row mode writes events to the
# binlog, and that AUTO_INCREMENT works correctly.
#
# ==== Method ====
#
# Insert both single and multiple rows into an autoincrement column,
# both with specified value and with NULL.
#
# With INSERT DELAYED, the rows do not show up in the table
# immediately, so we must do source include/wait_until_rows_count.inc
# between any two INSERT DELAYED statements. Moreover, if mixed or
# row-based logging is used, there is also a delay between when rows
# show up in the table and when they show up in the binlog. To ensure
# that the rows show up in the binlog, we call FLUSH TABLES, which
# waits until the delayed_insert thread has finished.
#
# We cannot read the binlog after executing INSERT DELAYED statements
# that insert multiple rows, because that is nondeterministic. More
# precisely, rows may be written in batches to the binlog, where each
# batch has one Table_map_log_event and one or more
# Write_rows_log_event. The number of rows included in each batch is
# nondeterministic.
#
# ==== Related bugs ====
#
# BUG#20627: INSERT DELAYED does not honour auto_increment_* variables
# Bug in this test: BUG#38068: binlog_stm_binlog fails sporadically in pushbuild
create
table
t1
(
a
int
not
null
auto_increment
,
primary
key
(
a
))
engine
=
myisam
;
# First, avoid BUG#20627:
set
@@
session
.
auto_increment_increment
=
1
,
@@
session
.
auto_increment_offset
=
1
;
# Verify that only one INSERT_ID event is binlogged.
# Note, that because of WL#3368 mixed mode binlog records RBR events for the delayed
let
$table
=
t1
;
let
$rows_inserted
=
11
;
# total number of inserted rows in this test
insert
delayed
into
t1
values
(
207
);
let
$count
=
1
;
# use this macro instead of sleeps.
let
$table
=
t1
;
let
$count
=
0
;
insert
delayed
into
t1
values
(
207
);
inc
$count
;
--
source
include
/
wait_until_rows_count
.
inc
insert
delayed
into
t1
values
(
null
);
inc
$count
;
--
source
include
/
wait_until_rows_count
.
inc
...
...
@@ -20,9 +46,10 @@ insert delayed into t1 values (300);
inc
$count
;
--
source
include
/
wait_until_rows_count
.
inc
# moving binlog check affront of multi-rows queries which work is indeterministic (extra table_maps)
# todo: better check is to substitute SHOW BINLOG with reading from binlog, probably bug#19459 is in
# the way
# It is not enough to wait until all rows have been inserted into the
# table. FLUSH TABLES ensures that they are in the binlog too. See
# comment above.
FLUSH
TABLES
;
source
include
/
show_binlog_events
.
inc
;
insert
delayed
into
t1
values
(
null
),(
null
),(
null
),(
null
);
...
...
@@ -33,8 +60,5 @@ insert delayed into t1 values (null),(null),(400),(null);
inc
$count
;
inc
$count
;
inc
$count
;
inc
$count
;
--
source
include
/
wait_until_rows_count
.
inc
#check this assertion about $count calculation
--
echo
$count
==
$rows_inserted
select
*
from
t1
;
drop
table
t1
;
mysql-test/include/show_binlog_events.inc
View file @
ee8a682b
...
...
@@ -4,7 +4,7 @@ if (!$binlog_start)
{
let
$binlog_start
=
106
;
}
--
replace_result
$binlog_start
<
binlog_start
>
--
replace_result
$
MYSQLTEST_VARDIR
MYSQLTEST_VARDIR
$
binlog_start
<
binlog_start
>
--
replace_column
2
# 4 # 5 #
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /file_id=[0-9]+/file_id=#/
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /table_id: [0-9]+/table_id: #/ /file_id=[0-9]+/file_id=#/
/block_len=[0-9]+/block_len=#/
--
eval
show
binlog
events
from
$binlog_start
mysql-test/suite/binlog/r/binlog_killed_simulate.result
View file @
ee8a682b
...
...
@@ -18,7 +18,7 @@ load data infile '../std_data_ln/rpl_loaddata.dat' into table t2 /* will be "kil
ERROR 70100: Query execution was interrupted
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
12
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
#
master-bin.000001 # Execute_load_query # # use `test`; load data infile '../std_data_ln/rpl_loaddata.dat' into table t2 /* will be "killed" in the middle */ ;file_id=#
select
(@a:=load_file("MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog"))
...
...
mysql-test/suite/binlog/r/binlog_row_binlog.result
View file @
ee8a682b
...
...
@@ -1141,10 +1141,10 @@ master-bin.000001 # Delete_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Query # # use `mysql`; COMMIT
drop table t1,t2,t3,tt1;
create table t1 (a int not null auto_increment, primary key (a)) engine=myisam;
set @@session.auto_increment_increment=1, @@session.auto_increment_offset=1;
insert delayed into t1 values (207);
insert delayed into t1 values (null);
insert delayed into t1 values (300);
FLUSH TABLES;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; create table t1 (id tinyint auto_increment primary key)
...
...
@@ -1188,9 +1188,9 @@ master-bin.000001 # Query # # use `test`; BEGIN
master-bin.000001 # Table_map # # table_id: # (test.t1)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Query # # use `test`; COMMIT
master-bin.000001 # Query # # use `test`; FLUSH TABLES
insert delayed into t1 values (null),(null),(null),(null);
insert delayed into t1 values (null),(null),(400),(null);
11 == 11
select * from t1;
a
207
...
...
mysql-test/suite/binlog/r/binlog_row_mix_innodb_myisam.result
View file @
ee8a682b
...
...
@@ -926,7 +926,7 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; BEGIN
master-bin.000001 # Intvar # # INSERT_ID=10
master-bin.000001 # User var # # @`b`=_latin1 0x3135 COLLATE latin1_swedish_ci
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
12
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
#
master-bin.000001 # Intvar # # INSERT_ID=10
master-bin.000001 # User var # # @`b`=_latin1 0x3135 COLLATE latin1_swedish_ci
master-bin.000001 # Execute_load_query # # use `test`; load data infile '../std_data_ln/rpl_loaddata.dat' into table t4 (a, @b) set b= @b + bug27417(2) ;file_id=#
...
...
mysql-test/suite/binlog/r/binlog_statement_insert_delayed.result
View file @
ee8a682b
create table t1 (a int not null auto_increment, primary key (a)) engine=myisam;
set @@session.auto_increment_increment=1, @@session.auto_increment_offset=1;
insert delayed into t1 values (207);
insert delayed into t1 values (null);
insert delayed into t1 values (300);
FLUSH TABLES;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; create table t1 (a int not null auto_increment, primary key (a)) engine=myisam
...
...
@@ -10,9 +10,9 @@ master-bin.000001 # Query # # use `test`; insert delayed into t1 values (207)
master-bin.000001 # Intvar # # INSERT_ID=208
master-bin.000001 # Query # # use `test`; insert delayed into t1 values (null)
master-bin.000001 # Query # # use `test`; insert delayed into t1 values (300)
master-bin.000001 # Query # # use `test`; FLUSH TABLES
insert delayed into t1 values (null),(null),(null),(null);
insert delayed into t1 values (null),(null),(400),(null);
11 == 11
select * from t1;
a
207
...
...
mysql-test/suite/binlog/r/binlog_stm_binlog.result
View file @
ee8a682b
...
...
@@ -629,10 +629,10 @@ master-bin.000001 # Query # # use `mysql`; UPDATE user SET password=password('An
master-bin.000001 # Query # # use `mysql`; DELETE FROM user WHERE host='localhost' AND user='@#@'
drop table t1,t2,t3,tt1;
create table t1 (a int not null auto_increment, primary key (a)) engine=myisam;
set @@session.auto_increment_increment=1, @@session.auto_increment_offset=1;
insert delayed into t1 values (207);
insert delayed into t1 values (null);
insert delayed into t1 values (300);
FLUSH TABLES;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; create table t1 (id tinyint auto_increment primary key)
...
...
@@ -660,9 +660,9 @@ master-bin.000001 # Query # # use `test`; BEGIN
master-bin.000001 # Table_map # # table_id: # (test.t1)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Query # # use `test`; COMMIT
master-bin.000001 # Query # # use `test`; FLUSH TABLES
insert delayed into t1 values (null),(null),(null),(null);
insert delayed into t1 values (null),(null),(400),(null);
11 == 11
select * from t1;
a
207
...
...
mysql-test/suite/binlog/r/binlog_stm_mix_innodb_myisam.result
View file @
ee8a682b
...
...
@@ -623,7 +623,7 @@ show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; BEGIN
master-bin.000001 # Intvar # # INSERT_ID=10
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
12
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
#
master-bin.000001 # Intvar # # INSERT_ID=10
master-bin.000001 # Execute_load_query # # use `test`; load data infile '../std_data_ln/rpl_loaddata.dat' into table t4 (a, @b) set b= @b + bug27417(2) ;file_id=#
master-bin.000001 # Query # # use `test`; ROLLBACK
...
...
@@ -858,7 +858,7 @@ Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # use `test`; BEGIN
master-bin.000001 # Intvar # # INSERT_ID=10
master-bin.000001 # User var # # @`b`=_latin1 0x3135 COLLATE latin1_swedish_ci
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
12
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
#
master-bin.000001 # Intvar # # INSERT_ID=10
master-bin.000001 # User var # # @`b`=_latin1 0x3135 COLLATE latin1_swedish_ci
master-bin.000001 # Execute_load_query # # use `test`; load data infile '../std_data_ln/rpl_loaddata.dat' into table t4 (a, @b) set b= @b + bug27417(2) ;file_id=#
...
...
mysql-test/suite/rpl/r/rpl_loaddata_map.result
View file @
ee8a682b
...
...
@@ -4,6 +4,8 @@ reset master;
reset slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
start slave;
==== Create a big file ====
==== Load our big file into a table ====
create table t2 (id int not null primary key auto_increment);
select @@session.read_buffer_size - @@session.max_allowed_packet > 0 ;
@@session.read_buffer_size - @@session.max_allowed_packet > 0
...
...
@@ -12,15 +14,18 @@ load data infile 'MYSQLTEST_VARDIR/tmp/bug30435_5k.txt' into table t2;
select count(*) from t2 /* 5 000 */;
count(*)
5000
show binlog events
in 'master-bin.000002'
from <binlog_start>;
show binlog events from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000002 # Query # # use `test`; create table t2 (id int not null primary key auto_increment)
master-bin.000002 # Begin_load_query # # ;file_id=#;block_len=#
master-bin.000002 # Append_block # # ;file_id=#;block_len=#
master-bin.000002 # Append_block # # ;file_id=#;block_len=#
master-bin.000002 # Execute_load_query # # use `test`; load data infile 'MYSQLTEST_VARDIR/tmp/bug30435_5k.txt' into table t2 ;file_id=#
master-bin.000001 # Query # # use `test`; create table t2 (id int not null primary key auto_increment)
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=#
master-bin.000001 # Append_block # # ;file_id=#;block_len=#
master-bin.000001 # Append_block # # ;file_id=#;block_len=#
master-bin.000001 # Execute_load_query # # use `test`; load data infile 'MYSQLTEST_VARDIR/tmp/bug30435_5k.txt' into table t2 ;file_id=#
==== Verify results on slave ====
[on slave]
select count(*) from t2 /* 5 000 */;
count(*)
5000
drop table t1, t2;
end of the tests
==== Clean up ====
[on master]
drop table t2;
mysql-test/suite/rpl/r/rpl_stm_log.result
View file @
ee8a682b
...
...
@@ -196,7 +196,7 @@ master-bin.000001 # Intvar # # INSERT_ID=1
master-bin.000001 # Query # # use `test`; insert into t1 values (NULL)
master-bin.000001 # Query # # use `test`; drop table t1
master-bin.000001 # Query # # use `test`; create table t1 (word char(20) not null)ENGINE=MyISAM
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
581
master-bin.000001 # Begin_load_query # # ;file_id=#;block_len=
#
master-bin.000001 # Execute_load_query # # use `test`; load data infile '../std_data_ln/words.dat' into table t1 ignore 1 lines ;file_id=#
master-bin.000001 # Rotate # # master-bin.000002;pos=4
show binlog events in 'master-bin.000002';
...
...
mysql-test/suite/rpl/r/rpl_variables.result
View file @
ee8a682b
...
...
@@ -45,7 +45,7 @@ RESET SLAVE;
RESET MASTER;
START SLAVE;
[on slave]
SET @@global.init_slave = '
ant
';
SET @@global.init_slave = '
SELECT 1
';
[on master]
CREATE TABLE tstmt (id INT AUTO_INCREMENT PRIMARY KEY,
truth BOOLEAN,
...
...
@@ -66,9 +66,9 @@ SET @@global.sync_binlog = 2000000;
INSERT INTO tstmt(num) VALUES (@@global.sync_binlog);
SET @@global.sync_binlog = 3000000;
INSERT INTO tstmt(num) VALUES (@@global.sync_binlog);
SET @@global.init_slave = '
bison
';
SET @@global.init_slave = '
SELECT 2
';
INSERT INTO tstmt(text) VALUES (@@global.init_slave);
SET @@global.init_slave = '
cat
';
SET @@global.init_slave = '
SELECT 3
';
INSERT INTO tstmt(text) VALUES (@@global.init_slave);
SET @@global.slave_exec_mode = 'IDEMPOTENT';
INSERT INTO tstmt(text) VALUES (@@global.slave_exec_mode);
...
...
@@ -140,9 +140,9 @@ INSERT INTO tproc(num) VALUES (@@global.sync_binlog);
SET @@global.sync_binlog = 3000000;
INSERT INTO tproc(num) VALUES (@@global.sync_binlog);
# string
SET @@global.init_slave = '
bison
';
SET @@global.init_slave = '
SELECT 2
';
INSERT INTO tproc(text) VALUES (@@global.init_slave);
SET @@global.init_slave = '
cat
';
SET @@global.init_slave = '
SELECT 3
';
INSERT INTO tproc(text) VALUES (@@global.init_slave);
# enumeration
SET @@global.slave_exec_mode = 'IDEMPOTENT';
...
...
@@ -226,9 +226,9 @@ INSERT INTO tfunc(num) VALUES (@@global.sync_binlog);
SET @@global.sync_binlog = 3000000;
INSERT INTO tfunc(num) VALUES (@@global.sync_binlog);
# string
SET @@global.init_slave = '
bison
';
SET @@global.init_slave = '
SELECT 2
';
INSERT INTO tfunc(text) VALUES (@@global.init_slave);
SET @@global.init_slave = '
cat
';
SET @@global.init_slave = '
SELECT 3
';
INSERT INTO tfunc(text) VALUES (@@global.init_slave);
# enumeration
SET @@global.slave_exec_mode = 'IDEMPOTENT';
...
...
@@ -316,9 +316,9 @@ INSERT INTO ttrig(num) VALUES (@@global.sync_binlog);
SET @@global.sync_binlog = 3000000;
INSERT INTO ttrig(num) VALUES (@@global.sync_binlog);
# string
SET @@global.init_slave = '
bison
';
SET @@global.init_slave = '
SELECT 2
';
INSERT INTO ttrig(text) VALUES (@@global.init_slave);
SET @@global.init_slave = '
cat
';
SET @@global.init_slave = '
SELECT 3
';
INSERT INTO ttrig(text) VALUES (@@global.init_slave);
# enumeration
SET @@global.slave_exec_mode = 'IDEMPOTENT';
...
...
@@ -395,9 +395,9 @@ PREPARE p5 FROM 'SET @@global.sync_binlog = 2000000';
PREPARE p6 FROM 'INSERT INTO tprep(num) VALUES (@@global.sync_binlog)';
PREPARE p7 FROM 'SET @@global.sync_binlog = 3000000';
PREPARE p8 FROM 'INSERT INTO tprep(num) VALUES (@@global.sync_binlog)';
PREPARE p9 FROM 'SET @@global.init_slave = \'
bison
\'';
PREPARE p9 FROM 'SET @@global.init_slave = \'
SELECT 2
\'';
PREPARE p10 FROM 'INSERT INTO tprep(text) VALUES (@@global.init_slave)';
PREPARE p11 FROM 'SET @@global.init_slave = \'
cat
\'';
PREPARE p11 FROM 'SET @@global.init_slave = \'
SELECT 3
\'';
PREPARE p12 FROM 'INSERT INTO tprep(text) VALUES (@@global.init_slave)';
PREPARE p13 FROM 'SET @@global.slave_exec_mode = \'IDEMPOTENT\'';
PREPARE p14 FROM 'INSERT INTO tprep(text) VALUES (@@global.slave_exec_mode)';
...
...
@@ -522,8 +522,8 @@ id truth num text
2 0 NULL NULL
3 NULL 2000000 NULL
4 NULL 3000000 NULL
5 NULL NULL
bison
6 NULL NULL
cat
5 NULL NULL
SELECT 2
6 NULL NULL
SELECT 3
7 NULL NULL IDEMPOTENT
8 NULL NULL STRICT
9 1 NULL NULL
...
...
mysql-test/suite/rpl/t/rpl_incident.test
View file @
ee8a682b
...
...
@@ -19,6 +19,37 @@ connection slave;
# The 4 should not be inserted into the table, since the incident log
# event should have stop the slave.
--
echo
****
On
Slave
****
#### BEGIN DEBUG INFO ADDED BY SVEN 2008-07-18 -- SEE BUG#38077 ####
let
$tables
=
query_get_value
(
SHOW
TABLES
,
Tables_in_test
,
1
);
if
(
`SELECT '$tables' != 't1'`
)
{
--
echo
****
TEST
CASE
BUG
!
PRINTING
DEBUG
INFO
!
****
--
echo
****
Dear
developer
,
if
you
see
this
in
the
output
of
a
test
--
echo
****
case
run
,
please
add
all
the
information
below
as
a
--
echo
****
comment
to
BUG
#38077. If it's a pushbuild failure, please
--
echo
****
include
a
link
to
the
push
page
.
--
echo
****
Thank
you
!
/
Sven
SHOW
BINLOG
EVENTS
;
--
echo
****
master
binlog
****
--
error
0
,
1
--
exec
$MYSQL_BINLOG
--
hexdump
$MYSQLTEST_VARDIR
/
log
/
master
-
bin
.
000001
--
echo
****
slave
binlog
****
--
error
0
,
1
--
exec
$MYSQL_BINLOG
--
hexdump
$MYSQLTEST_VARDIR
/
log
/
slave
-
bin
.
000001
--
echo
****
slave
status
****
query_vertical
SHOW
SLAVE
STATUS
;
--
echo
****
slave
'
s
master
status
****
SHOW
MASTER
STATUS
;
--
echo
****
slave
binlog
events
****
--
echo
[
on
master
]
connection
master
;
--
echo
****
master
status
****
SHOW
MASTER
STATUS
;
--
echo
****
master
binlog
events
****
SHOW
BINLOG
EVENTS
;
exit
;
}
#### END DEBUG INFO ####
SELECT
*
FROM
t1
;
--
replace_result
$MASTER_MYPORT
MASTER_PORT
...
...
mysql-test/suite/rpl/t/rpl_loaddata_map.test
View file @
ee8a682b
# ==== Purpose ====
#
# check replication of load data with the server parameters subjected to
# read_buffer_size > max_allowed_packet
#
# ==== Implementation ====
#
# Insert many rows into t1, write t1 to file.
# Load the file into t2.
# See that t2 came out as expected on slave.
#
# ==== Related Bugs ====
#
# BUG#30435 loading large LOAD DATA INFILE breaks slave with
# read_buffer_size set on master
# BUG#33413 show binlog events fails if binlog has event size of close
...
...
@@ -9,10 +18,17 @@
source
include
/
have_binlog_format_mixed_or_statement
.
inc
;
source
include
/
master
-
slave
.
inc
;
source
include
/
have_innodb
.
inc
;
source
include
/
have_binlog_format_mixed_or_statement
.
inc
;
--
echo
====
Create
a
big
file
====
# We turn off binlogging to avoid too much noise in the binlog. t1 is
# just an auxiliary construction anyways, it is not needed on the
# slave.
--
disable_query_log
SET
@@
sql_log_bin
=
0
;
let
$rows
=
5000
;
create
table
t1
(
id
int
not
null
primary
key
auto_increment
);
...
...
@@ -22,10 +38,13 @@ while($rows)
dec
$rows
;
}
eval
select
*
into
outfile
'$MYSQLTEST_VARDIR/tmp/bug30435_5k.txt'
from
t1
;
flush
logs
;
DROP
TABLE
t1
;
SET
@@
sql_log_bin
=
1
;
--
enable_query_log
connection
master
;
--
echo
====
Load
our
big
file
into
a
table
====
create
table
t2
(
id
int
not
null
primary
key
auto_increment
);
select
@@
session
.
read_buffer_size
-
@@
session
.
max_allowed_packet
>
0
;
...
...
@@ -34,21 +53,21 @@ select @@session.read_buffer_size - @@session.max_allowed_packet > 0 ;
eval
load
data
infile
'$MYSQLTEST_VARDIR/tmp/bug30435_5k.txt'
into
table
t2
;
select
count
(
*
)
from
t2
/* 5 000 */
;
# the binglog will show fragmented Append_block events
--
let
$binlog_start
=
106
--
replace_column
2
# 4 # 5 #
--
replace_regex
/
\
/
\
*
xid
=.*
\
*
\
//\/* XID *\// /file_id=[0-9]+/file_id=#/ /block_len=[0-9]+/block_len=#/
--
replace_result
$MYSQLTEST_VARDIR
MYSQLTEST_VARDIR
$binlog_start
<
binlog_start
>
--
eval
show
binlog
events
in
'master-bin.000002'
from
$binlog_start
# the binlog will show fragmented Append_block events
source
include
/
show_binlog_events
.
inc
;
--
echo
====
Verify
results
on
slave
====
--
echo
[
on
slave
]
sync_slave_with_master
;
#connection slave;
select
count
(
*
)
from
t2
/* 5 000 */
;
--
echo
====
Clean
up
====
--
echo
[
on
master
]
connection
master
;
drop
table
t
1
,
t
2
;
drop
table
t2
;
sync_slave_with_master
;
remove_file
$MYSQLTEST_VARDIR
/
tmp
/
bug30435_5k
.
txt
;
--
echo
end
of
the
tests
mysql-test/suite/rpl/t/rpl_trunc_temp.test
View file @
ee8a682b
# Requires statement logging
# ==== Purpose ====
#
# Verify that Slave_open_temp_tables is increased when a temporary
# table is opened on the slave, and decreased when a temporary table
# is closed on the slave, and that it is preserved during 'DELETE FROM
# table' and 'TRUNCATE table'.
#
# ==== Method ====
#
# Create a temporary table on master, insert rows, and try:
# - delete rows from the table
# - truncate the table
# - drop the table
#
# ==== Related bugs ====
#
# BUG#17137 Running "truncate table" on temporary table leaves the table open on a slave
#
# Bug in this test: BUG#37493: rpl_trunc_temp.test nondeterministic
# Requires statement-based logging since temporary tables are not
# logged in row-based logging
--
source
include
/
have_binlog_format_mixed_or_statement
.
inc
source
include
/
master
-
slave
.
inc
;
#
# Bug#17137 Running "truncate table" on temporary table
# leaves the table open on a slave
#
create
temporary
table
t1
(
n
int
);
insert
into
t1
values
(
1
);
sync_slave_with_master
;
...
...
@@ -28,13 +45,10 @@ show status like 'Slave_open_temp_tables';
# Disconnect the master, temp table on slave should dissapear
disconnect
master
;
connection
master1
;
# Wait until drop of temp tables appers in binlog
connection
slave
;
# Wait until drop of temp tables appers in slave's binlog
let
$wait_binlog_event
=
DROP
;
source
include
/
wait_for_binlog_event
.
inc
;
connection
slave
;
show
status
like
'Slave_open_temp_tables'
;
# End of 4.1 tests
mysql-test/suite/rpl/t/rpl_variables.test
View file @
ee8a682b
...
...
@@ -117,7 +117,7 @@ source include/reset_master_and_slave.inc;
# above, but can't because it affects how the slave works.
--
echo
[
on
slave
]
connection
slave
;
SET
@@
global
.
init_slave
=
'
ant
'
;
SET
@@
global
.
init_slave
=
'
SELECT 1
'
;
--
echo
[
on
master
]
...
...
@@ -154,9 +154,9 @@ SET @@global.sync_binlog = 3000000;
INSERT
INTO
tstmt
(
num
)
VALUES
(
@@
global
.
sync_binlog
);
# string
SET
@@
global
.
init_slave
=
'
bison
'
;
SET
@@
global
.
init_slave
=
'
SELECT 2
'
;
INSERT
INTO
tstmt
(
text
)
VALUES
(
@@
global
.
init_slave
);
SET
@@
global
.
init_slave
=
'
cat
'
;
SET
@@
global
.
init_slave
=
'
SELECT 3
'
;
INSERT
INTO
tstmt
(
text
)
VALUES
(
@@
global
.
init_slave
);
# enumeration
...
...
@@ -258,9 +258,9 @@ BEGIN
INSERT
INTO
tproc
(
num
)
VALUES
(
@@
global
.
sync_binlog
);
# string
SET
@@
global
.
init_slave
=
'
bison
'
;
SET
@@
global
.
init_slave
=
'
SELECT 2
'
;
INSERT
INTO
tproc
(
text
)
VALUES
(
@@
global
.
init_slave
);
SET
@@
global
.
init_slave
=
'
cat
'
;
SET
@@
global
.
init_slave
=
'
SELECT 3
'
;
INSERT
INTO
tproc
(
text
)
VALUES
(
@@
global
.
init_slave
);
# enumeration
...
...
@@ -367,9 +367,9 @@ BEGIN
INSERT
INTO
tfunc
(
num
)
VALUES
(
@@
global
.
sync_binlog
);
# string
SET
@@
global
.
init_slave
=
'
bison
'
;
SET
@@
global
.
init_slave
=
'
SELECT 2
'
;
INSERT
INTO
tfunc
(
text
)
VALUES
(
@@
global
.
init_slave
);
SET
@@
global
.
init_slave
=
'
cat
'
;
SET
@@
global
.
init_slave
=
'
SELECT 3
'
;
INSERT
INTO
tfunc
(
text
)
VALUES
(
@@
global
.
init_slave
);
# enumeration
...
...
@@ -478,9 +478,9 @@ BEGIN
INSERT
INTO
ttrig
(
num
)
VALUES
(
@@
global
.
sync_binlog
);
# string
SET
@@
global
.
init_slave
=
'
bison
'
;
SET
@@
global
.
init_slave
=
'
SELECT 2
'
;
INSERT
INTO
ttrig
(
text
)
VALUES
(
@@
global
.
init_slave
);
SET
@@
global
.
init_slave
=
'
cat
'
;
SET
@@
global
.
init_slave
=
'
SELECT 3
'
;
INSERT
INTO
ttrig
(
text
)
VALUES
(
@@
global
.
init_slave
);
# enumeration
...
...
@@ -581,9 +581,9 @@ PREPARE p7 FROM 'SET @@global.sync_binlog = 3000000';
PREPARE
p8
FROM
'INSERT INTO tprep(num) VALUES (@@global.sync_binlog)'
;
# string
PREPARE
p9
FROM
'SET @@global.init_slave = \'
bison
\''
;
PREPARE
p9
FROM
'SET @@global.init_slave = \'
SELECT 2
\''
;
PREPARE
p10
FROM
'INSERT INTO tprep(text) VALUES (@@global.init_slave)'
;
PREPARE
p11
FROM
'SET @@global.init_slave = \'
cat
\''
;
PREPARE
p11
FROM
'SET @@global.init_slave = \'
SELECT 3
\''
;
PREPARE
p12
FROM
'INSERT INTO tprep(text) VALUES (@@global.init_slave)'
;
# enumeration
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment