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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
31569606
Commit
31569606
authored
Apr 20, 2008
by
skozlov/ksm@mysql.com/virtop.(none)
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
WL#3734 Testing slave group execution
parent
596aca33
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
307 additions
and
0 deletions
+307
-0
mysql-test/suite/rpl/r/rpl_slave_grp_exec.result
mysql-test/suite/rpl/r/rpl_slave_grp_exec.result
+123
-0
mysql-test/suite/rpl/t/rpl_slave_grp_exec-master.opt
mysql-test/suite/rpl/t/rpl_slave_grp_exec-master.opt
+1
-0
mysql-test/suite/rpl/t/rpl_slave_grp_exec-slave.opt
mysql-test/suite/rpl/t/rpl_slave_grp_exec-slave.opt
+1
-0
mysql-test/suite/rpl/t/rpl_slave_grp_exec.test
mysql-test/suite/rpl/t/rpl_slave_grp_exec.test
+182
-0
No files found.
mysql-test/suite/rpl/r/rpl_slave_grp_exec.result
0 → 100644
View file @
31569606
stop slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
reset master;
reset slave;
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
start slave;
*** Preparing data ***
CREATE TABLE t1 (a INT NOT NULL, b VARCHAR(10)) ENGINE=MyISAM;
CREATE TABLE t2 LIKE t1;
CREATE TABLE t3 LIKE t1;
CREATE TRIGGER tr1 BEFORE UPDATE ON t1
FOR EACH ROW BEGIN
UPDATE t2 SET b='YY' WHERE a=NEW.a;
END|
CREATE TRIGGER tr2 AFTER UPDATE ON t1
FOR EACH ROW BEGIN
UPDATE t3 SET b='ZZ' WHERE a=NEW.a;
END|
*** Test non-transactional group w/o PK ***
INSERT INTO t3 VALUES(1, 'AA');
INSERT INTO t2 VALUES(1, 'AA');
INSERT INTO t1 VALUES(1, 'AA');
RENAME TABLE t3 TO t3_bak;
UPDATE t1 SET b = 'XX' WHERE a = 1;
SELECT * FROM t1 ORDER BY a;
a b
1 XX
SELECT * FROM t2 ORDER BY a;
a b
1 YY
SELECT * FROM t3 ORDER BY a;
a b
1 ZZ
SHOW TABLES LIKE 't%';
Tables_in_test (t%)
t1
t2
t3_bak
SELECT * FROM t1 ORDER BY a;
a b
1 AA_for_row_or_XX_for_stmt_mixed
SELECT * FROM t2 ORDER BY a;
a b
1 AA_for_row_or_YY_for_stmt_mixed
STOP SLAVE;
RENAME TABLE t3_bak TO t3;
START SLAVE;
TRUNCATE t1;
TRUNCATE t2;
TRUNCATE t3;
*** Test non-transactional group w/ PK ***
ALTER TABLE t1 ADD PRIMARY KEY (a);
ALTER TABLE t2 ADD PRIMARY KEY (a);
ALTER TABLE t3 ADD PRIMARY KEY (a);
RENAME TABLE t3 TO t3_bak;
INSERT INTO t3 VALUES(2, 'B');
INSERT INTO t2 VALUES(2, 'B');
INSERT INTO t1 VALUES(2, 'B');
UPDATE t1 SET b = 'X' WHERE a = 2;
SELECT * FROM t1 ORDER BY a;
a b
2 X
SELECT * FROM t2 ORDER BY a;
a b
2 YY
SELECT * FROM t3 ORDER BY a;
a b
2 ZZ
SHOW TABLES LIKE 't%';
Tables_in_test (t%)
t1
t2
t3_bak
SELECT * FROM t1 ORDER BY a;
a b
SELECT * FROM t2 ORDER BY a;
a b
STOP SLAVE;
RENAME TABLE t3_bak TO t3;
START SLAVE;
TRUNCATE t1;
TRUNCATE t2;
TRUNCATE t3;
*** Test transactional group w/ PK ***
ALTER TABLE t1 ENGINE=InnoDB;
ALTER TABLE t2 ENGINE=InnoDB;
ALTER TABLE t3 ENGINE=InnoDB;
RENAME TABLE t3 TO t3_bak;
BEGIN;
INSERT INTO t1 VALUES (3, 'C'), (4, 'D');
INSERT INTO t2 VALUES (3, 'C'), (4, 'D');
INSERT INTO t3 VALUES (3, 'C'), (4, 'D');
COMMIT;
SELECT * FROM t1 ORDER BY a;
a b
3 C
4 D
SELECT * FROM t2 ORDER BY a;
a b
3 C
4 D
SELECT * FROM t3 ORDER BY a;
a b
3 C
4 D
SHOW TABLES LIKE 't%';
Tables_in_test (t%)
t1
t2
t3_bak
SELECT * FROM t1 ORDER BY a;
a b
SELECT * FROM t2 ORDER BY a;
a b
STOP SLAVE;
RENAME TABLE t3_bak TO t3;
START SLAVE;
*** Clean up ***
DROP TABLE t1,t2,t3;
mysql-test/suite/rpl/t/rpl_slave_grp_exec-master.opt
0 → 100644
View file @
31569606
--innodb
mysql-test/suite/rpl/t/rpl_slave_grp_exec-slave.opt
0 → 100644
View file @
31569606
--innodb
mysql-test/suite/rpl/t/rpl_slave_grp_exec.test
0 → 100644
View file @
31569606
#############################################################
# Author: Serge Kozlov <skozlov@mysql.com>
# Date: 03/21/2008
# Purpose:
# WL#3734 Test: slave group execution
# Testing slave group execution: stop in middle of the group
# (of events) should be immpossible on slave.
# Group of events means set of statements between BEGIN/COMMIT
# for transactional engines or a statement for
# non-transactional engines that fires triggers and
# affects to another tables.
# Implementation of slave stop in middle of the group:
# Delete the table on slave before start of the group
# on master where this table is participant of the group.
# So sql thread will failed inside of the group.
# Expected results:
# 1. For non-transactional engines w/o PK slave should trying
# to complete executing of the group.
# 2. For non-transactional engines slave should stop on
# start position of the group.
#############################################################
--
source
include
/
have_innodb
.
inc
--
source
include
/
master
-
slave
.
inc
--
echo
# Create tables and data
--
echo
***
Preparing
data
***
--
connection
master
CREATE
TABLE
t1
(
a
INT
NOT
NULL
,
b
VARCHAR
(
10
))
ENGINE
=
MyISAM
;
CREATE
TABLE
t2
LIKE
t1
;
CREATE
TABLE
t3
LIKE
t1
;
DELIMITER
|
;
CREATE
TRIGGER
tr1
BEFORE
UPDATE
ON
t1
FOR
EACH
ROW
BEGIN
UPDATE
t2
SET
b
=
'YY'
WHERE
a
=
NEW
.
a
;
END
|
CREATE
TRIGGER
tr2
AFTER
UPDATE
ON
t1
FOR
EACH
ROW
BEGIN
UPDATE
t3
SET
b
=
'ZZ'
WHERE
a
=
NEW
.
a
;
END
|
DELIMITER
;
|
--
echo
# Test non-transactional group with MyISAM tables w/o PK.
# Data for t1,t2 should be replicated for SBR even t3
# doesn't exist on slave
--
echo
***
Test
non
-
transactional
group
w
/
o
PK
***
--
connection
master
INSERT
INTO
t3
VALUES
(
1
,
'AA'
);
INSERT
INTO
t2
VALUES
(
1
,
'AA'
);
INSERT
INTO
t1
VALUES
(
1
,
'AA'
);
--
sync_slave_with_master
RENAME
TABLE
t3
TO
t3_bak
;
--
connection
master
UPDATE
t1
SET
b
=
'XX'
WHERE
a
=
1
;
SELECT
*
FROM
t1
ORDER
BY
a
;
SELECT
*
FROM
t2
ORDER
BY
a
;
SELECT
*
FROM
t3
ORDER
BY
a
;
--
connection
slave
--
source
include
/
wait_for_slave_sql_to_stop
.
inc
SHOW
TABLES
LIKE
't%'
;
if
(
`SELECT @@BINLOG_FORMAT = 'ROW'`
)
{
--
replace_regex
/
AA
/
AA_for_row_or_XX_for_stmt_mixed
/
SELECT
*
FROM
t1
ORDER
BY
a
;
--
replace_regex
/
AA
/
AA_for_row_or_YY_for_stmt_mixed
/
SELECT
*
FROM
t2
ORDER
BY
a
;
}
if
(
!
`SELECT @@BINLOG_FORMAT = 'ROW'`
)
{
--
replace_regex
/
XX
/
AA_for_row_or_XX_for_stmt_mixed
/
SELECT
*
FROM
t1
ORDER
BY
a
;
--
replace_regex
/
YY
/
AA_for_row_or_YY_for_stmt_mixed
/
SELECT
*
FROM
t2
ORDER
BY
a
;
}
STOP
SLAVE
;
--
source
include
/
wait_for_slave_to_stop
.
inc
RENAME
TABLE
t3_bak
TO
t3
;
START
SLAVE
;
--
source
include
/
wait_for_slave_to_start
.
inc
--
connection
master
TRUNCATE
t1
;
TRUNCATE
t2
;
TRUNCATE
t3
;
--
sync_slave_with_master
--
echo
# Test non-transactional group with MyISAM tables and PK.
# No data replicated because update based on PK
--
echo
***
Test
non
-
transactional
group
w
/
PK
***
--
connection
master
ALTER
TABLE
t1
ADD
PRIMARY
KEY
(
a
);
ALTER
TABLE
t2
ADD
PRIMARY
KEY
(
a
);
ALTER
TABLE
t3
ADD
PRIMARY
KEY
(
a
);
--
sync_slave_with_master
RENAME
TABLE
t3
TO
t3_bak
;
--
connection
master
INSERT
INTO
t3
VALUES
(
2
,
'B'
);
INSERT
INTO
t2
VALUES
(
2
,
'B'
);
INSERT
INTO
t1
VALUES
(
2
,
'B'
);
UPDATE
t1
SET
b
=
'X'
WHERE
a
=
2
;
--
connection
slave
--
source
include
/
wait_for_slave_sql_to_stop
.
inc
--
connection
master
SELECT
*
FROM
t1
ORDER
BY
a
;
SELECT
*
FROM
t2
ORDER
BY
a
;
SELECT
*
FROM
t3
ORDER
BY
a
;
--
connection
slave
SHOW
TABLES
LIKE
't%'
;
SELECT
*
FROM
t1
ORDER
BY
a
;
SELECT
*
FROM
t2
ORDER
BY
a
;
STOP
SLAVE
;
--
source
include
/
wait_for_slave_to_stop
.
inc
RENAME
TABLE
t3_bak
TO
t3
;
START
SLAVE
;
--
source
include
/
wait_for_slave_to_start
.
inc
--
connection
master
TRUNCATE
t1
;
TRUNCATE
t2
;
TRUNCATE
t3
;
--
sync_slave_with_master
--
echo
# Test transactional group with InnoDB tables with PK
# No data replicated if errors happens inside transaction
--
echo
***
Test
transactional
group
w
/
PK
***
--
connection
master
ALTER
TABLE
t1
ENGINE
=
InnoDB
;
ALTER
TABLE
t2
ENGINE
=
InnoDB
;
ALTER
TABLE
t3
ENGINE
=
InnoDB
;
--
connection
slave
RENAME
TABLE
t3
TO
t3_bak
;
--
connection
master
BEGIN
;
INSERT
INTO
t1
VALUES
(
3
,
'C'
),
(
4
,
'D'
);
INSERT
INTO
t2
VALUES
(
3
,
'C'
),
(
4
,
'D'
);
INSERT
INTO
t3
VALUES
(
3
,
'C'
),
(
4
,
'D'
);
COMMIT
;
--
connection
slave
--
source
include
/
wait_for_slave_sql_to_stop
.
inc
--
connection
master
SELECT
*
FROM
t1
ORDER
BY
a
;
SELECT
*
FROM
t2
ORDER
BY
a
;
SELECT
*
FROM
t3
ORDER
BY
a
;
--
connection
slave
SHOW
TABLES
LIKE
't%'
;
SELECT
*
FROM
t1
ORDER
BY
a
;
SELECT
*
FROM
t2
ORDER
BY
a
;
STOP
SLAVE
;
--
source
include
/
wait_for_slave_to_stop
.
inc
RENAME
TABLE
t3_bak
TO
t3
;
START
SLAVE
;
--
source
include
/
wait_for_slave_to_start
.
inc
# Clean up
--
echo
***
Clean
up
***
--
connection
master
DROP
TABLE
t1
,
t2
,
t3
;
--
sync_slave_with_master
# End of 5.1 test
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