################# mysql-test\t\delayed_insert_timeout_basic.test ############### # # # Variable Name: delayed_insert_timeout # # Scope: GLOBAL # # Access Type: Dynamic # # Data Type: Numeric # # Default Value: 300 # # Range: 1 - 4294967286 # # # # # # Creation Date: 2008-02-07 # # Author: Salman Rawala # # # # Description: Test Cases of Dynamic System Variable "delayed_insert_timeout" # # that checks behavior of this variable in the following ways # # * Default Value # # * Valid & Invalid values # # * Scope & Access method # # * Data Integrity . # # # # Reference: http://dev.mysql.com/doc/refman/5.1/en/ # # server-system-variables.html#option_mysqld_delayed_insert_timeout # # # ################################################################################ --source include/load_sysvars.inc ################################################################# # START OF delayed_insert_timeout TESTS # ################################################################# ############################################################################## # Saving initial value of delayed_insert_timeout in a temporary variable # ############################################################################## SET @start_value = @@global.delayed_insert_timeout; SELECT @start_value; --echo '#--------------------FN_DYNVARS_025_01------------------------#' ############################################################################## # Display the DEFAULT value of delayed_insert_timeout # ############################################################################## SET @@global.delayed_insert_timeout = 100; SET @@global.delayed_insert_timeout = DEFAULT; SELECT @@global.delayed_insert_timeout; --echo '#---------------------FN_DYNVARS_025_02-------------------------#' ############################################### # Verify default value of variable # ############################################### SET @@global.delayed_insert_timeout = @start_value; SELECT @@global.delayed_insert_timeout = 300; --echo '#--------------------FN_DYNVARS_025_03------------------------#' ############################################################################## # Change the value of delayed_insert_timeout to a valid value # ############################################################################## SET @@global.delayed_insert_timeout = 10000; SELECT @@global.delayed_insert_timeout; SET @@global.delayed_insert_timeout = 429; SELECT @@global.delayed_insert_timeout; SET @@global.delayed_insert_timeout = 1; SELECT @@global.delayed_insert_timeout; --echo '#--------------------FN_DYNVARS_025_04-------------------------#' ################################################################################# # Change the value of delayed_insert_timeout to invalid value # ################################################################################# SET @@global.delayed_insert_timeout = 0; SELECT @@global.delayed_insert_timeout; SET @@global.delayed_insert_timeout = -1024; SELECT @@global.delayed_insert_timeout; SET @@global.delayed_insert_timeout = 42949672950; SELECT @@global.delayed_insert_timeout; --Error ER_WRONG_TYPE_FOR_VAR SET @@global.delayed_insert_timeout = 429496729.5; SELECT @@global.delayed_insert_timeout; --Error ER_WRONG_TYPE_FOR_VAR SET @@global.delayed_insert_timeout = ON; SELECT @@global.delayed_insert_timeout; --echo '#-------------------FN_DYNVARS_025_05----------------------------#' ################################################################################# # Test if accessing session delayed_insert_timeout gives error # ################################################################################# --Error ER_GLOBAL_VARIABLE SET @@session.delayed_insert_timeout = 0; --Error ER_UNKNOWN_SYSTEM_VARIABLE SELECT @@session.dalayed_insert_timeout; --echo '#----------------------FN_DYNVARS_025_06------------------------#' ############################################################################## # Check if the value in GLOBAL & SESSION Tables matches values in variable # ############################################################################## SELECT @@global.delayed_insert_timeout = VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES WHERE VARIABLE_NAME='delayed_insert_timeout'; SELECT @@delayed_insert_timeout = VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES WHERE VARIABLE_NAME='delayed_insert_timeout'; --echo '#---------------------FN_DYNVARS_025_07----------------------#' ################################################################### # Check if TRUE and FALSE values can be used on variable # ################################################################### SET @@global.delayed_insert_timeout = TRUE; SELECT @@global.delayed_insert_timeout; SET @@global.delayed_insert_timeout = FALSE; SELECT @@global.delayed_insert_timeout; --echo '#---------------------FN_DYNVARS_025_08----------------------#' ######################################################################################################## # Check if accessing variable with SESSION,LOCAL and without SCOPE points to same session variable # ######################################################################################################## SET @@global.delayed_insert_timeout = 1; SELECT @@delayed_insert_timeout = @@global.delayed_insert_timeout; --echo '#---------------------FN_DYNVARS_025_09----------------------#' ################################################################################ # Check if delayed_insert_timeout can be accessed with and without @@ sign # ################################################################################ --Error ER_GLOBAL_VARIABLE SET delayed_insert_timeout = 1; SELECT @@delayed_insert_timeout; --Error ER_PARSE_ERROR SET local.delayed_insert_timeout = 1; --Error ER_UNKNOWN_TABLE SELECT local.delayed_insert_timeout; --Error ER_PARSE_ERROR SET global.delayed_insert_timeout = 1; --Error ER_UNKNOWN_TABLE SELECT global.delayed_insert_timeout; --Error ER_BAD_FIELD_ERROR SELECT delayed_insert_timeout = @@session.delayed_insert_timeout; # Restore initial value SET @@global.delayed_insert_timeout = @start_value; SELECT @@global.delayed_insert_timeout; ############################## # Restore initial value # ############################## SET @@global.delayed_insert_timeout = @start_value; SELECT @@global.delayed_insert_timeout; ################################################################ # END OF delayed_insert_timeout TESTS # ################################################################