=== added file 'mysql-test/suite/archive/archive_symlink.result' --- mysql-test/suite/archive/archive_symlink.result 1970-01-01 00:00:00 +0000 +++ mysql-test/suite/archive/archive_symlink.result 2014-03-11 08:41:13 +0000 @@ -0,0 +1,57 @@ +# +# Archive can only use an existing directory for DATA DIRECTORY. +# +CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) +ENGINE archive DATA DIRECTORY = 'MYSQL_TMP_DIR/archive' INDEX DIRECTORY = 'MYSQL_TMP_DIR/archive'; +ERROR HY000: Can't find file: 't1' (errno: 2 - No such file or directory) +# +# mkdir MYSQL_TMP_DIR/archive and try again... +# Archive will use a symlink for DATA DIRECTORY but ignore INDEX DIRECTORY. +# +CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) +ENGINE archive DATA DIRECTORY = 'MYSQL_TMP_DIR/archive' INDEX DIRECTORY = 'MYSQL_TMP_DIR/archive'; +Warnings: +Warning 1618 option ignored +INSERT INTO t1 VALUES (NULL, "blue"); +INSERT INTO t1 VALUES (NULL, "red"); +INSERT INTO t1 VALUES (NULL, "yellow"); +# Checking if archive file exists where we specified in DATA DIRECTORY +SHOW CREATE TABLE t1; +Table Create Table +t1 CREATE TABLE `t1` ( + `a` int(11) NOT NULL AUTO_INCREMENT, + `b` char(30) DEFAULT NULL, + PRIMARY KEY (`a`) +) ENGINE=ARCHIVE AUTO_INCREMENT=4 DEFAULT CHARSET=latin1 DATA DIRECTORY='MYSQL_TMP_DIR/archive/' +DROP TABLE t1; +# +# Be sure SQL MODE "NO_DIR_IN_CREATE" prevents the use of DATA DIRECTORY +# +SET @org_mode=@@sql_mode; +SET @@sql_mode='NO_DIR_IN_CREATE'; +SELECT @@sql_mode; +@@sql_mode +NO_DIR_IN_CREATE +CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) +ENGINE archive DATA DIRECTORY = 'MYSQL_TMP_DIR/archive'; +Warnings: +Warning 1618 option ignored +INSERT INTO t1 VALUES (NULL, "blue"); +INSERT INTO t1 VALUES (NULL, "red"); +INSERT INTO t1 VALUES (NULL, "yellow"); +# Checking if archive file exists in --datadir since DATA DIRECTORY was ignored. +DROP TABLE t1; +set @@sql_mode=@org_mode; +# +# MySQL engine does not allow DATA DIRECTORY to be +# within --datadir for any engine, including Archive +# +CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) +ENGINE archive DATA DIRECTORY 'MYSQLD_DATADIR/test'; +ERROR HY000: Incorrect arguments to DATA DIRECTORY +CREATE TABLE t1 (c1 int(10), PRIMARY KEY (c1)) +ENGINE archive INDEX DIRECTORY 'MYSQLD_DATADIR/test'; +ERROR HY000: Incorrect arguments to INDEX DIRECTORY +# +# Cleanup +# === added file 'mysql-test/suite/archive/archive_symlink.test' --- mysql-test/suite/archive/archive_symlink.test 1970-01-01 00:00:00 +0000 +++ mysql-test/suite/archive/archive_symlink.test 2014-03-11 08:41:13 +0000 @@ -0,0 +1,72 @@ +# Test archive engine when symbolic links are available. +--source include/not_windows.inc +--source include/have_archive.inc + +# DATA DIRECTORY/INDEX DIRECTORY require symbolic link support +--source include/have_symlink.inc + +let $MYSQLD_DATADIR= `select @@datadir`; +let $data_directory = DATA DIRECTORY = '$MYSQL_TMP_DIR/archive'; +let $index_directory = INDEX DIRECTORY = '$MYSQL_TMP_DIR/archive'; + +--echo # +--echo # Archive can only use an existing directory for DATA DIRECTORY. +--echo # +--replace_result $MYSQL_TMP_DIR MYSQL_TMP_DIR +--error ER_CANT_CREATE_TABLE +eval CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) + ENGINE archive $data_directory $index_directory; + +--echo # +--echo # mkdir MYSQL_TMP_DIR/archive and try again... +--echo # Archive will use a symlink for DATA DIRECTORY but ignore INDEX DIRECTORY. +--echo # +--mkdir $MYSQL_TMP_DIR/archive +--replace_result $MYSQL_TMP_DIR MYSQL_TMP_DIR +eval CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) + ENGINE archive $data_directory $index_directory; +INSERT INTO t1 VALUES (NULL, "blue"); +INSERT INTO t1 VALUES (NULL, "red"); +INSERT INTO t1 VALUES (NULL, "yellow"); +--echo # Checking if archive file exists where we specified in DATA DIRECTORY +--file_exists $MYSQL_TMP_DIR/archive/t1.ARZ +--replace_result $MYSQL_TMP_DIR MYSQL_TMP_DIR +SHOW CREATE TABLE t1; +DROP TABLE t1; + +--echo # +--echo # Be sure SQL MODE "NO_DIR_IN_CREATE" prevents the use of DATA DIRECTORY +--echo # +SET @org_mode=@@sql_mode; +SET @@sql_mode='NO_DIR_IN_CREATE'; +SELECT @@sql_mode; +--replace_result $MYSQL_TMP_DIR MYSQL_TMP_DIR +eval CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) + ENGINE archive $data_directory; +INSERT INTO t1 VALUES (NULL, "blue"); +INSERT INTO t1 VALUES (NULL, "red"); +INSERT INTO t1 VALUES (NULL, "yellow"); +--echo # Checking if archive file exists in --datadir since DATA DIRECTORY was ignored. +--file_exists $MYSQLD_DATADIR/test/t1.ARZ +DROP TABLE t1; +set @@sql_mode=@org_mode; + +--echo # +--echo # MySQL engine does not allow DATA DIRECTORY to be +--echo # within --datadir for any engine, including Archive +--echo # +--replace_result $MYSQLD_DATADIR MYSQLD_DATADIR +--error ER_WRONG_ARGUMENTS +eval CREATE TABLE t1 (a int AUTO_INCREMENT KEY, b char(30)) + ENGINE archive DATA DIRECTORY '$MYSQLD_DATADIR/test'; + +--replace_result $MYSQLD_DATADIR MYSQLD_DATADIR +--error ER_WRONG_ARGUMENTS +eval CREATE TABLE t1 (c1 int(10), PRIMARY KEY (c1)) +ENGINE archive INDEX DIRECTORY '$MYSQLD_DATADIR/test'; + +--echo # +--echo # Cleanup +--echo # +--rmdir $MYSQL_TMP_DIR/archive +