summaryrefslogtreecommitdiffstats
path: root/mysql-test/suite/parts/inc/partition_alter_1.inc
diff options
context:
space:
mode:
Diffstat (limited to 'mysql-test/suite/parts/inc/partition_alter_1.inc')
-rw-r--r--mysql-test/suite/parts/inc/partition_alter_1.inc72
1 files changed, 72 insertions, 0 deletions
diff --git a/mysql-test/suite/parts/inc/partition_alter_1.inc b/mysql-test/suite/parts/inc/partition_alter_1.inc
new file mode 100644
index 00000000..a348407a
--- /dev/null
+++ b/mysql-test/suite/parts/inc/partition_alter_1.inc
@@ -0,0 +1,72 @@
+################################################################################
+# inc/partition_alter_1.inc #
+# #
+# Purpose: #
+# Alter a partioned table and check the usability afterwards #
+# This script is only usefule when sourced by #
+# inc/partition_alter_1[1|3].inc #
+# #
+# 0. Expect there is a table t1 #
+# 1. Insert the first half of the table t0_template into t1 #
+# 2. Execute the ALTER TABLE statement within the variable $alter #
+# Case SQL code in #
+# 0: 1. Insert the second half of the table t0_template into t1 #
+# 2. Execute the usability test inc/partition_check.inc #
+# >0, but expected: nothing #
+# >0 and unexpected: abort #
+# 3. DROP the table t1 #
+# #
+# The parameter $alter has to be set before sourcing this script. #
+# Example: #
+# CREATE TABLE t1 (f_int1 INT,f_int2 INT, .... ); #
+# let $alter= ALTER TABLE t1 ADD PRIMARY KEY(f_int2); #
+# inc/partition_alter_1.inc #
+# #
+# The parameters $insert_first_half and $insert_second_half #
+# are also to be set outside (source ./inc/partition.pre). #
+# #
+#------------------------------------------------------------------------------#
+# Original Author: mleich #
+# Original Date: 2006-03-05 #
+# Change Author: mleich #
+# Change Date: 2007-10-08 #
+# Change: Fix for #
+# Bug#31481 test suite parts: Many tests fail because of #
+# changed server error codes #
+################################################################################
+
+eval $insert_first_half;
+# Possible/Expected return codes for ALTER TABLE ...
+# 0
+# 1030: ER_GET_ERRNO
+# 1502: ER_UNIQUE_KEY_NEED_ALL_FIELDS_IN_PF
+# 1506: ER_PARTITION_DOES_NOT_EXIST
+--disable_abort_on_error
+eval $alter;
+--enable_abort_on_error
+if ($no_debug)
+{
+--disable_query_log
+}
+eval SET @my_errno = $mysql_errno;
+let $run_test= `SELECT @my_errno = 0`;
+if (`SELECT @my_errno NOT IN (0,$ER_GET_ERRNO,
+ $ER_UNIQUE_KEY_NEED_ALL_FIELDS_IN_PF,
+ $ER_PARTITION_DOES_NOT_EXIST)`);
+{
+ --echo # The last command got an unexepected error response.
+ --echo # Expected/handled SQL codes are 0,$ER_GET_ERRNO,$ER_UNIQUE_KEY_NEED_ALL_FIELDS_IN_PF,$ER_PARTITION_DOES_NOT_EXIST
+ SELECT '# SQL code we got was: ' AS "", @my_errno AS "";
+ --echo # Sorry, have to abort.
+ --echo # Please check the error name to number mapping in inc/partition.pre.
+ exit;
+ --echo
+}
+--enable_query_log
+# Prevent execution of following usage tests, when ALTER TABLE failed
+if ($run_test)
+{
+eval $insert_second_half;
+--source suite/parts/inc/partition_check.inc
+}
+DROP TABLE t1;