2006-12-12 19:12:30 -05:00
|
|
|
# WL #3031 This test tests the new servers table as well as
|
|
|
|
# if federated can utilise the servers table
|
Added option --staging-run to mysql-test-run to mark slow, not important tests, to not be run in staging trees
Use MY_MUTEX_INIT_FAST for pool mutex
mysql-test/mysql-test-run.pl:
Added option --staging-run
Added information about --parallell=# to help message
mysql-test/suite/federated/federated_server.test:
Slow test, don't run with --staging-run
mysql-test/suite/maria/t/maria-preload.test:
Slow test, don't run with --staging-run
mysql-test/suite/rpl/t/rpl_optimize.test:
Slow test, don't run with --staging-run
mysql-test/suite/rpl/t/rpl_relayrotate.test:
Slow test, don't run with --staging-run
mysql-test/suite/rpl/t/rpl_row_001.test:
Slow test, don't run with --staging-run
mysql-test/suite/rpl/t/rpl_row_mysqlbinlog.test:
Slow test, don't run with --staging-run
mysql-test/suite/rpl/t/rpl_row_sp003.test:
Slow test, don't run with --staging-run
mysql-test/suite/rpl/t/rpl_start_stop_slave.test:
Slow test, don't run with --staging-run
mysql-test/t/compress.test:
Slow test, don't run with --staging-run
mysql-test/t/count_distinct3.test:
Slow test, don't run with --staging-run
mysql-test/t/index_merge_innodb.test:
Slow test, don't run with --staging-run
mysql-test/t/information_schema_all_engines.test:
Slow test, don't run with --staging-run
mysql-test/t/innodb_mysql.test:
Slow test, don't run with --staging-run
mysql-test/t/pool_of_threads.test:
Slow test, don't run with --staging-run
mysql-test/t/preload.test:
Slow test, don't run with --staging-run
mysql-test/t/ssl.test:
Slow test, don't run with --staging-run
mysql-test/t/ssl_compress.test:
Slow test, don't run with --staging-run
mysql-test/valgrind.supp:
Suppress warnings from SuSE 11.1 on x86
sql/scheduler.cc:
Use MY_MUTEX_INIT_FAST for pool mutex
2009-06-05 18:35:22 +03:00
|
|
|
|
|
|
|
# Slow test, don't run during staging part
|
|
|
|
-- source include/not_staging.inc
|
2009-10-30 01:05:51 +02:00
|
|
|
-- source include/big_test.inc
|
2012-10-16 13:04:42 +02:00
|
|
|
-- source include/federated.inc
|
2006-12-01 19:47:45 -05:00
|
|
|
|
|
|
|
connection slave;
|
|
|
|
create database first_db;
|
|
|
|
create database second_db;
|
|
|
|
|
|
|
|
use first_db;
|
|
|
|
|
|
|
|
DROP TABLE IF EXISTS first_db.t1;
|
|
|
|
CREATE TABLE first_db.t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
DEFAULT CHARSET=latin1;
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
DROP TABLE IF EXISTS first_db.t2;
|
|
|
|
CREATE TABLE first_db.t2 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
DEFAULT CHARSET=latin1;
|
|
|
|
|
2006-12-01 19:47:45 -05:00
|
|
|
use second_db;
|
|
|
|
DROP TABLE IF EXISTS second_db.t1;
|
|
|
|
CREATE TABLE second_db.t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
DEFAULT CHARSET=latin1;
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
DROP TABLE IF EXISTS second_db.t2;
|
|
|
|
CREATE TABLE second_db.t2 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
DEFAULT CHARSET=latin1;
|
|
|
|
|
2006-12-01 19:47:45 -05:00
|
|
|
connection master;
|
|
|
|
|
|
|
|
drop server if exists 'server_one';
|
2006-12-12 17:23:11 -05:00
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
2006-12-01 19:47:45 -05:00
|
|
|
eval create server 'server_one' foreign data wrapper 'mysql' options
|
|
|
|
(HOST '127.0.0.1',
|
|
|
|
DATABASE 'first_db',
|
|
|
|
USER 'root',
|
|
|
|
PASSWORD '',
|
|
|
|
PORT $SLAVE_MYPORT,
|
|
|
|
SOCKET '',
|
|
|
|
OWNER 'root');
|
|
|
|
|
|
|
|
drop server if exists 'server_two';
|
2006-12-12 17:23:11 -05:00
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
2006-12-01 19:47:45 -05:00
|
|
|
eval create server 'server_two' foreign data wrapper 'mysql' options
|
|
|
|
(HOST '127.0.0.1',
|
|
|
|
DATABASE 'second_db',
|
|
|
|
USER 'root',
|
|
|
|
PASSWORD '',
|
|
|
|
PORT $SLAVE_MYPORT,
|
|
|
|
SOCKET '',
|
|
|
|
OWNER 'root');
|
|
|
|
|
2006-12-12 19:39:45 -05:00
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
2011-03-01 00:35:05 +02:00
|
|
|
eval select * from mysql.servers order by db;
|
2006-12-01 19:47:45 -05:00
|
|
|
|
|
|
|
DROP TABLE IF EXISTS federated.old;
|
2006-12-12 17:23:11 -05:00
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
2006-12-01 19:47:45 -05:00
|
|
|
eval CREATE TABLE federated.old (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
ENGINE="FEDERATED" DEFAULT CHARSET=latin1
|
|
|
|
CONNECTION='mysql://root@127.0.0.1:$SLAVE_MYPORT/first_db/t1';
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
INSERT INTO federated.old (id, name) values (1, 'federated.old-> first_db.t1, url format');
|
2006-12-01 19:47:45 -05:00
|
|
|
|
|
|
|
SELECT * FROM federated.old;
|
|
|
|
|
|
|
|
DROP TABLE IF EXISTS federated.old2;
|
2006-12-12 17:23:11 -05:00
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
2006-12-01 19:47:45 -05:00
|
|
|
eval CREATE TABLE federated.old2 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
ENGINE="FEDERATED" DEFAULT CHARSET=latin1
|
2007-03-24 01:18:19 -07:00
|
|
|
CONNECTION='mysql://root@127.0.0.1:$SLAVE_MYPORT/first_db/t2';
|
|
|
|
|
|
|
|
INSERT INTO federated.old2 (id, name) values (1, 'federated.old2-> first_db.t2, url format');
|
|
|
|
SELECT * FROM federated.old2;
|
|
|
|
|
|
|
|
DROP TABLE IF EXISTS federated.urldb2t1;
|
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
|
|
|
eval CREATE TABLE federated.urldb2t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
ENGINE="FEDERATED" DEFAULT CHARSET=latin1
|
2006-12-01 19:47:45 -05:00
|
|
|
CONNECTION='mysql://root@127.0.0.1:$SLAVE_MYPORT/second_db/t1';
|
2007-03-24 01:18:19 -07:00
|
|
|
INSERT INTO federated.urldb2t1 (id, name) values (1, 'federated.urldb2t1 -> second_db.t1, url format');
|
|
|
|
SELECT * FROM federated.urldb2t1;
|
2006-12-01 19:47:45 -05:00
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
DROP TABLE IF EXISTS federated.urldb2t2;
|
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
|
|
|
eval CREATE TABLE federated.urldb2t2 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
ENGINE="FEDERATED" DEFAULT CHARSET=latin1
|
|
|
|
CONNECTION='mysql://root@127.0.0.1:$SLAVE_MYPORT/second_db/t2';
|
|
|
|
INSERT INTO federated.urldb2t2 (id, name) values (1, 'federated.urldb2t2 -> second_db.t2, url format');
|
|
|
|
SELECT * FROM federated.urldb2t2;
|
2006-12-01 19:47:45 -05:00
|
|
|
|
|
|
|
DROP TABLE IF EXISTS federated.t1;
|
|
|
|
CREATE TABLE federated.t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
ENGINE="FEDERATED" DEFAULT CHARSET=latin1
|
|
|
|
CONNECTION='server_one';
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
INSERT INTO federated.t1 (id, name) values (1, 'server_one, new scheme, first_db.t1');
|
2006-12-01 19:47:45 -05:00
|
|
|
|
|
|
|
SELECT * FROM federated.t1;
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
DROP TABLE IF EXISTS federated.whatever;
|
|
|
|
CREATE TABLE federated.whatever (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
ENGINE="FEDERATED" DEFAULT CHARSET=latin1
|
|
|
|
CONNECTION='server_one/t1';
|
|
|
|
INSERT INTO federated.whatever (id, name) values (1, 'server_one, new scheme, whatever, first_db.t1');
|
|
|
|
SELECT * FROM federated.whatever;
|
|
|
|
|
2006-12-01 19:47:45 -05:00
|
|
|
ALTER SERVER 'server_one' options(DATABASE 'second_db');
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
# FLUSH TABLES is now unneccessary
|
2006-12-01 19:47:45 -05:00
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
INSERT INTO federated.t1 (id, name) values (1, 'server_two, new scheme, second_db.t1');
|
2006-12-01 19:47:45 -05:00
|
|
|
SELECT * FROM federated.t1;
|
|
|
|
|
2007-03-24 01:18:19 -07:00
|
|
|
INSERT INTO federated.whatever (id, name) values (1, 'server_two, new scheme, whatever, second_db.t1');
|
|
|
|
SELECT * FROM federated.whatever;
|
|
|
|
|
2006-12-01 19:47:45 -05:00
|
|
|
drop table federated.t1;
|
|
|
|
|
|
|
|
drop server 'server_one';
|
|
|
|
drop server 'server_two';
|
2011-03-01 00:35:05 +02:00
|
|
|
select * from mysql.servers order by db;
|
2006-12-01 19:47:45 -05:00
|
|
|
|
|
|
|
connection slave;
|
|
|
|
drop table first_db.t1;
|
|
|
|
drop table second_db.t1;
|
|
|
|
drop database first_db;
|
|
|
|
drop database second_db;
|
|
|
|
|
2007-03-13 11:58:24 -07:00
|
|
|
#
|
|
|
|
# Bug#25671 - CREATE/DROP/ALTER SERVER should require privileges
|
|
|
|
#
|
|
|
|
# Changes to SERVER declarations should require SUPER privilege.
|
|
|
|
# Based upon test case by Giuseppe Maxia
|
|
|
|
|
|
|
|
create database db_legitimate;
|
|
|
|
create database db_bogus;
|
|
|
|
|
|
|
|
use db_legitimate;
|
|
|
|
CREATE TABLE db_legitimate.t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
);
|
|
|
|
INSERT INTO db_legitimate.t1 VALUES ('1','this is legitimate');
|
|
|
|
|
|
|
|
use db_bogus;
|
|
|
|
CREATE TABLE db_bogus.t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
)
|
|
|
|
;
|
|
|
|
INSERT INTO db_bogus.t1 VALUES ('2','this is bogus');
|
|
|
|
|
2009-10-30 01:05:51 +02:00
|
|
|
connection slave;
|
|
|
|
create user test_fed@localhost identified by 'foo';
|
|
|
|
grant all on db_legitimate.* to test_fed@localhost;
|
|
|
|
|
2007-03-13 11:58:24 -07:00
|
|
|
connection master;
|
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
|
|
|
eval create server 's1' foreign data wrapper 'mysql' options
|
|
|
|
(HOST '127.0.0.1',
|
|
|
|
DATABASE 'db_legitimate',
|
2009-10-30 01:05:51 +02:00
|
|
|
USER 'test_fed',
|
|
|
|
PASSWORD 'foo',
|
2007-03-13 11:58:24 -07:00
|
|
|
PORT $SLAVE_MYPORT,
|
|
|
|
SOCKET '',
|
|
|
|
OWNER 'root');
|
|
|
|
|
|
|
|
create user guest_select@localhost;
|
|
|
|
grant select on federated.* to guest_select@localhost;
|
|
|
|
|
|
|
|
create user guest_super@localhost;
|
|
|
|
grant select,SUPER,RELOAD on *.* to guest_super@localhost;
|
|
|
|
|
|
|
|
create user guest_usage@localhost;
|
|
|
|
grant usage on *.* to guest_usage@localhost;
|
|
|
|
|
|
|
|
CREATE TABLE federated.t1 (
|
|
|
|
`id` int(20) NOT NULL,
|
|
|
|
`name` varchar(64) NOT NULL default ''
|
|
|
|
) ENGINE = FEDERATED CONNECTION = 's1';
|
|
|
|
|
|
|
|
select * from federated.t1;
|
|
|
|
|
|
|
|
connect (conn_select,127.0.0.1,guest_select,,federated,$MASTER_MYPORT);
|
|
|
|
connect (conn_usage,127.0.0.1,guest_usage,,,$MASTER_MYPORT);
|
|
|
|
connect (conn_super,127.0.0.1,guest_super,,,$MASTER_MYPORT);
|
|
|
|
|
|
|
|
connection conn_select;
|
|
|
|
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
|
|
|
alter server s1 options (database 'db_bogus');
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
flush tables;
|
|
|
|
select * from federated.t1;
|
|
|
|
|
|
|
|
connection conn_usage;
|
|
|
|
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
|
|
|
alter server s1 options (database 'db_bogus');
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
flush tables;
|
|
|
|
select * from federated.t1;
|
|
|
|
|
|
|
|
connection conn_super;
|
|
|
|
alter server s1 options (database 'db_bogus');
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
flush tables;
|
2011-11-30 11:37:28 +01:00
|
|
|
--error ER_DBACCESS_DENIED_ERROR,ER_CONNECT_TO_FOREIGN_DATA_SOURCE
|
2007-03-13 11:58:24 -07:00
|
|
|
select * from federated.t1;
|
|
|
|
|
|
|
|
connection conn_select;
|
|
|
|
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
|
|
|
drop server if exists 's1';
|
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
|
|
|
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
|
|
|
eval create server 's1' foreign data wrapper 'mysql' options
|
|
|
|
(HOST '127.0.0.1',
|
|
|
|
DATABASE 'db_legitimate',
|
2009-11-04 03:11:04 -08:00
|
|
|
USER 'test_fed',
|
|
|
|
PASSWORD 'foo',
|
2007-03-13 11:58:24 -07:00
|
|
|
PORT $SLAVE_MYPORT,
|
|
|
|
SOCKET '',
|
|
|
|
OWNER 'root');
|
|
|
|
|
|
|
|
connection conn_super;
|
|
|
|
drop server 's1';
|
|
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
|
|
|
eval create server 's1' foreign data wrapper 'mysql' options
|
|
|
|
(HOST '127.0.0.1',
|
|
|
|
DATABASE 'db_legitimate',
|
2009-11-04 03:11:04 -08:00
|
|
|
USER 'test_fed',
|
|
|
|
PASSWORD 'foo',
|
2007-03-13 11:58:24 -07:00
|
|
|
PORT $SLAVE_MYPORT,
|
|
|
|
SOCKET '',
|
|
|
|
OWNER 'root');
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
flush tables;
|
|
|
|
select * from federated.t1;
|
|
|
|
|
|
|
|
# clean up test
|
|
|
|
connection slave;
|
2009-11-04 03:11:04 -08:00
|
|
|
drop user test_fed@localhost;
|
2007-03-13 11:58:24 -07:00
|
|
|
drop database db_legitimate;
|
|
|
|
drop database db_bogus;
|
|
|
|
|
|
|
|
disconnect conn_select;
|
|
|
|
disconnect conn_usage;
|
|
|
|
disconnect conn_super;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
drop user guest_super@localhost;
|
|
|
|
drop user guest_usage@localhost;
|
|
|
|
drop user guest_select@localhost;
|
|
|
|
drop table federated.t1;
|
|
|
|
drop server 's1';
|
|
|
|
|
2007-11-01 12:30:03 -07:00
|
|
|
#
|
|
|
|
# Bug#30671 - ALTER SERVER causes the server to crash
|
|
|
|
#
|
2014-11-16 13:15:35 +01:00
|
|
|
create server 's1' foreign data wrapper 'mysql' options (host 'foo');
|
2007-11-01 12:30:03 -07:00
|
|
|
alter server 's1' options
|
|
|
|
(host 'localhost', database '', user '',
|
|
|
|
password '', socket '', owner '', port 3306);
|
|
|
|
# The next statement would crash unpatched server
|
|
|
|
alter server 's1' options
|
|
|
|
(host 'localhost', database 'database1', user '',
|
|
|
|
password '', socket '', owner '', port 3306);
|
|
|
|
drop server 's1';
|
2007-03-13 11:58:24 -07:00
|
|
|
|
|
|
|
--echo # End of 5.1 tests
|
|
|
|
|
2007-03-23 17:31:27 -07:00
|
|
|
|
|
|
|
#
|
|
|
|
# Bug#25721 - deadlock with ALTER/CREATE SERVER
|
|
|
|
#
|
|
|
|
connect (other,localhost,root,,);
|
|
|
|
connection master;
|
|
|
|
use test;
|
2010-07-31 17:10:27 +04:00
|
|
|
create table t1(a int);
|
|
|
|
insert into t1 values (1);
|
2007-03-23 17:31:27 -07:00
|
|
|
delimiter //;
|
|
|
|
create procedure p1 ()
|
|
|
|
begin
|
|
|
|
DECLARE v INT DEFAULT 0;
|
2007-04-04 21:35:58 +00:00
|
|
|
DECLARE i INT;
|
BUG#40143 federated.federated_server fails sporadically in pushbuild
The original goal of the test, as reported on BUG #25721, is to check whether
a deadlock happens or not when concurrently CREATING/ALTERING/DROPPING the
same server. For that a procedure (p1) is created that runs the exact same
CREATE/ALTER/DROP statements for 10K iterations and two different connections
(threads - t1 and t2) call p1 concurrently. At the end of the 10K iterations,
the test checks if there was errors while running the loop (SELECT e >0).
The problem is that In some cases it may happen that one thread, t1, gets
scheduled to execute with just enough time to complete the iteration and
never bumps into the other thread t2. Meaning that t1 will never run into an
SQL exception. On the other hand, the other thread, t2, may run into t1 and
never issue any/part of its own statements because it will throw an SQLEXCEPTION.
This is probably the case for failures where only one value differs.
Furthermore, there is a third scenario: both threads are scheduled to run
interleaved for each iteration (or even one thread completes all iterations
before the other starts). In this case, both will succeed without any error.
This is probably the case for the failure that reports two different values.
This patch addresses the failure in pushbuild by removing the error counting
and the printout (SELECT > 0) at the end of the test. A timeout should occur
if the error that the test is checking surfaces.
2009-01-22 14:07:58 +01:00
|
|
|
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN END;
|
2007-04-04 21:35:58 +00:00
|
|
|
SET i = sleep(5);
|
2007-04-17 14:41:16 +03:00
|
|
|
WHILE v < 10000 do
|
2007-03-23 17:31:27 -07:00
|
|
|
CREATE SERVER s
|
|
|
|
FOREIGN DATA WRAPPER mysql
|
|
|
|
OPTIONS (USER 'Remote', HOST '192.168.1.106', DATABASE 'test');
|
|
|
|
ALTER SERVER s OPTIONS (USER 'Remote');
|
|
|
|
DROP SERVER s;
|
|
|
|
SET v = v + 1;
|
|
|
|
END WHILE;
|
2010-07-31 17:10:27 +04:00
|
|
|
select a into @a from t1; # Just reset warnings
|
2007-03-23 17:31:27 -07:00
|
|
|
END//
|
|
|
|
delimiter ;//
|
|
|
|
connection other;
|
|
|
|
use test;
|
|
|
|
send call p1();
|
|
|
|
connection master;
|
|
|
|
call p1();
|
|
|
|
connection other;
|
|
|
|
reap;
|
|
|
|
drop procedure p1;
|
2010-07-31 17:10:27 +04:00
|
|
|
drop table t1;
|
2007-03-23 17:31:27 -07:00
|
|
|
drop server if exists s;
|
|
|
|
|
|
|
|
|
Bug #12876932 - INCORRECT SELECT RESULT ON FEDERATED TABLE
Problem description:
Table 't' created with two colums having compound index on both the
columns under innodb/myisam engine at remote machine. In the local
machine same table is created undet the federated engine.
A select having where clause with along 'AND' operation gives wrong
results on local machine.
Analysis:
The given query at federated engine is wrongly transformed by
federated::create_where_from_key() function and the same was sent to
the remote machine. Hence the local machine is showing wrong results.
Given query "select c1 from t where c1 <= 2 and c2 = 1;"
Query transformed, after ha_federated::create_where_from_key() function is:
SELECT `c1`, `c2` FROM `t` WHERE (`c1` IS NOT NULL ) AND
( (`c1` >= 2) AND (`c2` <= 1) ) and the same sent to real_query().
In the above the '<=' and '=' conditions were transformed to '>=' and
'<=' respectively.
ha_federated::create_where_from_key() function behaving as below:
The key_range is having both the start_key and end_key. The start_key
is used to get "(`c1` IS NOT NULL )" part of the where clause, this
transformation is correct. The end_key is used to get "( (`c1` >= 2)
AND (`c2` <= 1) )", which is wrong, here the given conditions('<=' and '=')
are changed as wrong conditions('>=' and '<=').
The end_key is having {key = 0x39fa6d0 "", length = 10, keypart_map = 3,
flag = HA_READ_AFTER_KEY}
The store_length is having value '5'. Based on store_length and length
values the condition values is applied in HA_READ_AFTER_KEY switch case.
The switch case 'HA_READ_AFTER_KEY' is applicable to only the last part of
the end_key and for previous parts it is going to 'HA_READ_KEY_OR_NEXT' case,
here the '>=' is getting added as a condition instead of '<='.
Fix:
Updated the 'if' condition in 'HA_READ_AFTER_KEY' case to affect for all
parts of the end_key. i.e 'i > 0' will used for end_key, Hence added it in
the if condition.
mysql-test/suite/federated/federated.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_archive.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_bug_13118.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_bug_25714.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_bug_35333.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_debug.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_innodb.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_server.test:
modified the federated.inc file location
mysql-test/suite/federated/federated_transactions.test:
modified the federated.inc file location
mysql-test/suite/federated/include/federated.inc:
moved the file from federated suite to federated/include folder
mysql-test/suite/federated/include/federated_cleanup.inc:
moved the file from federated suite to federated/include folder
mysql-test/suite/federated/include/have_federated_db.inc:
moved the file from federated suite to federated/include folder
storage/federated/ha_federated.cc:
updated the 'if condition' in ha_federated::create_where_from_key()
function.
2012-07-26 15:09:22 +05:30
|
|
|
source suite/federated/include/federated_cleanup.inc;
|