mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 13:02:28 +01:00
df0d80a31b
into sita.local:/Users/tsmith/m/bk/maint/51 This merge requires a post-merge fix to remove rpl_udf from suite/rpl/t/disabled.def. mysql-test/lib/mtr_report.pl: Auto merged mysql-test/r/show_check.result: Auto merged mysql-test/suite/ndb/r/ndb_dd_basic.result: Auto merged mysql-test/suite/ndb/r/ndb_dd_ddl.result: Auto merged mysql-test/suite/ndb/r/ndb_gis.result: Auto merged mysql-test/suite/ndb/r/ndb_row_format.result: Auto merged mysql-test/suite/ndb/r/ndb_single_user.result: Auto merged mysql-test/suite/ndb/t/ndb_single_user.test: Auto merged mysql-test/suite/rpl/r/rpl_extraCol_innodb.result: Auto merged mysql-test/suite/rpl/r/rpl_extraCol_myisam.result: Auto merged mysql-test/suite/rpl/r/rpl_incident.result: Auto merged mysql-test/suite/rpl/r/rpl_row_tabledefs_2myisam.result: Auto merged mysql-test/suite/rpl/r/rpl_row_tabledefs_3innodb.result: Auto merged mysql-test/suite/rpl/r/rpl_sp.result: Auto merged mysql-test/suite/rpl_ndb/r/rpl_ndb_extraCol.result: Auto merged sql/field.cc: Auto merged sql/field.h: Auto merged sql/log.cc: Auto merged sql/mysql_priv.h: Auto merged sql/sql_class.cc: Auto merged sql/sql_class.h: Auto merged sql/sql_show.cc: Auto merged storage/csv/ha_tina.cc: Auto merged storage/innobase/handler/ha_innodb.cc: Auto merged mysql-test/r/csv.result: Manual merge mysql-test/t/csv.test: Manual merge mysql-test/t/disabled.def: Manual merge
173 lines
4.8 KiB
Text
173 lines
4.8 KiB
Text
-- source include/have_multi_ndb.inc
|
|
-- source include/ndb_default_cluster.inc
|
|
-- source include/not_embedded.inc
|
|
|
|
--disable_warnings
|
|
use test;
|
|
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9,t10;
|
|
--enable_warnings
|
|
|
|
# operations allowed while cluster is in single user mode
|
|
|
|
--connection server1
|
|
--let $node_id= `SHOW STATUS LIKE 'Ndb_cluster_node_id'`
|
|
--disable_query_log
|
|
--eval set @node_id= SUBSTRING('$node_id', 20)+0
|
|
--enable_query_log
|
|
--let $node_id= `SELECT @node_id`
|
|
--exec $NDB_MGM --no-defaults --ndb-connectstring="localhost:$NDBCLUSTER_PORT" -e "enter single user mode $node_id" >> $NDB_TOOLS_OUTPUT
|
|
--exec $NDB_TOOLS_DIR/ndb_waiter --no-defaults --ndb-connectstring="localhost:$NDBCLUSTER_PORT" --single-user >> $NDB_TOOLS_OUTPUT
|
|
|
|
# verify that we are indeed in single user mode
|
|
# and test that some operations give correct errors
|
|
--connection server2
|
|
--error 1005
|
|
create table t1 (a int key, b int unique, c int) engine ndb;
|
|
# Bug #27712 Single user mode. Creating logfile group and tablespace is allowed
|
|
# - before bug fix these would succeed
|
|
--error ER_CREATE_FILEGROUP_FAILED
|
|
CREATE LOGFILE GROUP lg1
|
|
ADD UNDOFILE 'undofile.dat'
|
|
INITIAL_SIZE 16M
|
|
UNDO_BUFFER_SIZE = 1M
|
|
ENGINE=NDB;
|
|
show warnings;
|
|
|
|
# test some sql on first mysqld
|
|
--connection server1
|
|
create table t1 (a int key, b int unique, c int) engine ndb;
|
|
# Check that we can create logfile group
|
|
CREATE LOGFILE GROUP lg1
|
|
ADD UNDOFILE 'undofile.dat'
|
|
INITIAL_SIZE 16M
|
|
UNDO_BUFFER_SIZE = 1M
|
|
ENGINE=NDB;
|
|
--connection server2
|
|
--error ER_CREATE_FILEGROUP_FAILED
|
|
CREATE TABLESPACE ts1
|
|
ADD DATAFILE 'datafile.dat'
|
|
USE LOGFILE GROUP lg1
|
|
INITIAL_SIZE 12M
|
|
ENGINE NDB;
|
|
show warnings;
|
|
--error ER_DROP_FILEGROUP_FAILED
|
|
DROP LOGFILE GROUP lg1
|
|
ENGINE =NDB;
|
|
show warnings;
|
|
--connection server1
|
|
CREATE TABLESPACE ts1
|
|
ADD DATAFILE 'datafile.dat'
|
|
USE LOGFILE GROUP lg1
|
|
INITIAL_SIZE 12M
|
|
ENGINE NDB;
|
|
--connection server2
|
|
--error ER_ALTER_FILEGROUP_FAILED
|
|
ALTER TABLESPACE ts1
|
|
DROP DATAFILE 'datafile.dat'
|
|
ENGINE NDB;
|
|
show warnings;
|
|
--connection server1
|
|
ALTER TABLESPACE ts1
|
|
DROP DATAFILE 'datafile.dat'
|
|
ENGINE NDB;
|
|
--connection server2
|
|
--error ER_DROP_FILEGROUP_FAILED
|
|
DROP TABLESPACE ts1
|
|
ENGINE NDB;
|
|
show warnings;
|
|
--connection server1
|
|
DROP TABLESPACE ts1
|
|
ENGINE NDB;
|
|
DROP LOGFILE GROUP lg1
|
|
ENGINE =NDB;
|
|
insert into t1 values (1,1,0),(2,2,0),(3,3,0),(4,4,0),(5,5,0),(6,6,0),(7,7,0),(8,8,0),(9,9,0),(10,10,0);
|
|
create table t2 as select * from t1;
|
|
# read with pk
|
|
select * from t1 where a = 1;
|
|
# read with unique index
|
|
select * from t1 where b = 4;
|
|
# read with ordered index
|
|
select * from t1 where a > 4 order by a;
|
|
# update with pk
|
|
update t1 set b=102 where a = 2;
|
|
# update with unique index
|
|
update t1 set b=103 where b = 3;
|
|
# update with full table scan
|
|
update t1 set b=b+100;
|
|
# update with ordered insex scan
|
|
update t1 set b=b+100 where a > 7;
|
|
# delete with full table scan
|
|
delete from t1;
|
|
insert into t1 select * from t2;
|
|
# Bug #27710 Creating unique index fails during single user mode
|
|
# - prior to bugfix this would fail
|
|
create unique index new_index on t1 (b,c);
|
|
|
|
# test some sql on other mysqld
|
|
--connection server2
|
|
--error 1051
|
|
drop table t1;
|
|
--error 1296
|
|
create index new_index_fail on t1 (c);
|
|
--error 1296
|
|
insert into t1 values (21,21,0),(22,22,0),(23,23,0),(24,24,0),(25,25,0),(26,26,0),(27,27,0),(28,28,0),(29,29,0),(210,210,0);
|
|
--error 1296
|
|
select * from t1 where a = 1;
|
|
--error 1296
|
|
select * from t1 where b = 4;
|
|
--error 1296
|
|
update t1 set b=102 where a = 2;
|
|
--error 1296
|
|
update t1 set b=103 where b = 3;
|
|
--error 1296
|
|
update t1 set b=b+100;
|
|
--error 1296
|
|
update t1 set b=b+100 where a > 7;
|
|
|
|
--exec $NDB_MGM --no-defaults --ndb-connectstring="localhost:$NDBCLUSTER_PORT" -e "exit single user mode" >> $NDB_TOOLS_OUTPUT
|
|
--exec $NDB_TOOLS_DIR/ndb_waiter --no-defaults >> $NDB_TOOLS_OUTPUT
|
|
|
|
#
|
|
# we should be able to run transaction while in single user mode
|
|
#
|
|
--connection server1
|
|
BEGIN;
|
|
update t1 set b=b+100 where a=1;
|
|
|
|
--connection server2
|
|
BEGIN;
|
|
update t1 set b=b+100 where a=2;
|
|
|
|
# enter single user mode
|
|
--exec $NDB_MGM --no-defaults --ndb-connectstring="localhost:$NDBCLUSTER_PORT" -e "enter single user mode $node_id" >> $NDB_TOOLS_OUTPUT
|
|
--exec $NDB_TOOLS_DIR/ndb_waiter --no-defaults --ndb-connectstring="localhost:$NDBCLUSTER_PORT" --single-user >> $NDB_TOOLS_OUTPUT
|
|
|
|
--connection server1
|
|
update t1 set b=b+100 where a=3;
|
|
COMMIT;
|
|
|
|
# while on other mysqld it should be aborted
|
|
--connection server2
|
|
--error 1296
|
|
update t1 set b=b+100 where a=4;
|
|
--error 1296
|
|
COMMIT;
|
|
|
|
# Bug #25275 SINGLE USER MODE prevents ALTER on non-ndb
|
|
# tables for other mysqld nodes
|
|
--connection server2
|
|
create table t2 (a int) engine myisam;
|
|
alter table t2 add column (b int);
|
|
|
|
# exit single user mode
|
|
--exec $NDB_MGM --no-defaults --ndb-connectstring="localhost:$NDBCLUSTER_PORT" -e "exit single user mode" >> $NDB_TOOLS_OUTPUT
|
|
--exec $NDB_TOOLS_DIR/ndb_waiter --no-defaults >> $NDB_TOOLS_OUTPUT
|
|
|
|
# cleanup
|
|
--connection server2
|
|
drop table t2;
|
|
--connection server1
|
|
drop table t1;
|
|
|
|
# End of 5.0 tests
|
|
|