mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 14:54:20 +01:00
161 lines
5.7 KiB
Text
161 lines
5.7 KiB
Text
# Non-windows specific partition tests.
|
|
--source include/not_windows.inc
|
|
--source include/have_partition.inc
|
|
# DATA DIRECTORY/INDEX DIRECTORY require symbolic link support
|
|
--source include/have_symlink.inc
|
|
|
|
# The test for Bug 20770 is disabled on Windows due to BUG#19107; it
|
|
# should be moved into partition.test once the bug has been resolved.
|
|
|
|
#
|
|
# Bug 20770 Partitions: DATA DIRECTORY clause change in reorganize
|
|
# doesn't remove old directory
|
|
|
|
--disable_query_log
|
|
eval SET @data_dir = 'DATA DIRECTORY = ''$MYSQLTEST_VARDIR/tmp''';
|
|
let $data_directory = `select @data_dir`;
|
|
|
|
eval SET @inx_dir = 'INDEX DIRECTORY = ''$MYSQLTEST_VARDIR/tmp''';
|
|
let $inx_directory = `select @inx_dir`;
|
|
--enable_query_log
|
|
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
eval create table t1 (a int) engine myisam
|
|
partition by range (a)
|
|
subpartition by hash (a)
|
|
(partition p0 VALUES LESS THAN (1) $data_directory $inx_directory
|
|
(SUBPARTITION subpart00, SUBPARTITION subpart01));
|
|
|
|
--echo Checking if file exists before alter
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1.frm
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1.par
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p0#SP#subpart00.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p0#SP#subpart00.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p0#SP#subpart01.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p0#SP#subpart01.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p0#SP#subpart00.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p0#SP#subpart01.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p0#SP#subpart00.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p0#SP#subpart01.MYI
|
|
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
eval ALTER TABLE t1 REORGANIZE PARTITION p0 INTO
|
|
(partition p1 VALUES LESS THAN (1) $data_directory $inx_directory
|
|
(SUBPARTITION subpart10, SUBPARTITION subpart11),
|
|
partition p2 VALUES LESS THAN (2) $data_directory $inx_directory
|
|
(SUBPARTITION subpart20, SUBPARTITION subpart21));
|
|
|
|
--echo Checking if file exists after alter
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1.frm
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1.par
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p1#SP#subpart10.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p1#SP#subpart10.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p1#SP#subpart11.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p1#SP#subpart11.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p2#SP#subpart20.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p2#SP#subpart20.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p2#SP#subpart21.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/master-data/test/t1#P#p2#SP#subpart21.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p1#SP#subpart10.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p1#SP#subpart11.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p2#SP#subpart20.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p2#SP#subpart21.MYD
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p1#SP#subpart10.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p1#SP#subpart11.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p2#SP#subpart20.MYI
|
|
--file_exists $MYSQLTEST_VARDIR/tmp/t1#P#p2#SP#subpart21.MYI
|
|
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug #24633 SQL MODE "NO_DIR_IN_CREATE" does not work with partitioned tables
|
|
#
|
|
disable_query_log;
|
|
eval create table t2 (i int )
|
|
partition by range (i)
|
|
(
|
|
partition p01 values less than (1000)
|
|
data directory="$MYSQLTEST_VARDIR/tmp/"
|
|
index directory="$MYSQLTEST_VARDIR/tmp/"
|
|
);
|
|
enable_query_log;
|
|
|
|
set @org_mode=@@sql_mode;
|
|
set @@sql_mode='NO_DIR_IN_CREATE';
|
|
select @@sql_mode;
|
|
create table t1 (i int )
|
|
partition by range (i)
|
|
(
|
|
partition p01 values less than (1000)
|
|
data directory='/not/existing'
|
|
index directory='/not/existing'
|
|
);
|
|
show create table t2;
|
|
DROP TABLE t1, t2;
|
|
set @@sql_mode=@org_mode;
|
|
|
|
#
|
|
# Bug#32167: another privilege bypass with DATA/INDEX DIRECTORY
|
|
#
|
|
--replace_result $MYSQLTEST_VARDIR TEST_DIR
|
|
--error 1210
|
|
eval CREATE TABLE t1(a INT)
|
|
PARTITION BY KEY (a)
|
|
(PARTITION p0 DATA DIRECTORY '$MYSQLTEST_VARDIR/master-data/test');
|
|
--replace_result $MYSQLTEST_VARDIR TEST_DIR
|
|
--error 1210
|
|
eval CREATE TABLE t1(a INT)
|
|
PARTITION BY KEY (a)
|
|
(PARTITION p0 INDEX DIRECTORY '$MYSQLTEST_VARDIR/master-data/test');
|
|
|
|
--replace_result $MYSQLTEST_VARDIR TEST_DIR
|
|
--error 1210
|
|
eval CREATE TABLE ts (id INT, purchased DATE)
|
|
PARTITION BY RANGE(YEAR(purchased))
|
|
SUBPARTITION BY HASH(TO_DAYS(purchased)) (
|
|
PARTITION p0 VALUES LESS THAN (1990) (
|
|
SUBPARTITION s0a
|
|
DATA DIRECTORY = '$MYSQLTEST_VARDIR/master-data/test',
|
|
SUBPARTITION s0b
|
|
DATA DIRECTORY = '$MYSQLTEST_VARDIR/master-data/test'
|
|
));
|
|
|
|
--replace_result $MYSQLTEST_VARDIR TEST_DIR
|
|
--error 1210
|
|
eval CREATE TABLE ts (id INT, purchased DATE)
|
|
PARTITION BY RANGE(YEAR(purchased))
|
|
SUBPARTITION BY HASH(TO_DAYS(purchased)) (
|
|
PARTITION p0 VALUES LESS THAN (1990) (
|
|
SUBPARTITION s0a
|
|
INDEX DIRECTORY = '$MYSQLTEST_VARDIR/master-data/test',
|
|
SUBPARTITION s0b
|
|
INDEX DIRECTORY = '$MYSQLTEST_VARDIR/master-data/test'
|
|
));
|
|
|
|
# End Windows specific test failures.
|
|
|
|
# These tests contain non-Windows specific directory/file format.
|
|
|
|
#
|
|
# Bug 25141: Crash Server on Partitioning command
|
|
#
|
|
|
|
--disable_warnings
|
|
DROP TABLE IF EXISTS `example`;
|
|
--enable_warnings
|
|
|
|
--disable_abort_on_error
|
|
CREATE TABLE `example` (
|
|
`ID_EXAMPLE` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
|
`DESCRIPTION` varchar(30) NOT NULL,
|
|
`LEVEL` smallint(5) unsigned DEFAULT NULL,
|
|
PRIMARY KEY (`ID_EXAMPLE`)
|
|
) ENGINE = MYISAM
|
|
PARTITION BY HASH(ID_EXAMPLE)(
|
|
PARTITION p0 DATA DIRECTORY = '/build/5.1/data/partitiontest/p0Data',
|
|
PARTITION p1 DATA DIRECTORY = '/build/5.1/data/partitiontest/p1Data',
|
|
PARTITION p2 DATA DIRECTORY = '/build/5.1/data/partitiontest/p2Data',
|
|
PARTITION p3 DATA DIRECTORY = '/build/5.1/data/partitiontest/p3Data'
|
|
);
|
|
--enable_abort_on_error
|
|
|