1 ############## mysql-test\t\transaction_alloc_block_size_basic.test ###########
3 # Variable Name: transaction_alloc_block_size #
4 # Scope: GLOBAL | SESSION #
5 # Access Type: Dynamic #
7 # Default Value: 8192 #
8 # Range: 1024-4294967295 #
11 # Creation Date: 2008-02-14 #
14 # Description: Test Cases of Dynamic System Variable #
15 # transaction_alloc_block_size #
16 # that checks the behavior of this variable in the following ways#
18 # * Valid & Invalid values #
19 # * Scope & Access method #
22 # Reference: http://dev.mysql.com/doc/refman/5.1/en/ #
23 # server-system-variables.html #
25 ###############################################################################
27 --source include/load_sysvars.inc
29 ########################################################################
30 # START OF transaction_alloc_block_size TESTS #
31 ########################################################################
34 #############################################################
35 # Save initial value #
36 #############################################################
38 SET @start_global_value = @@global.transaction_alloc_block_size;
39 SELECT @start_global_value;
40 SET @start_session_value = @@session.transaction_alloc_block_size;
41 SELECT @start_session_value;
44 --echo
'#--------------------FN_DYNVARS_005_01-------------------------#'
45 ########################################################################
46 # Display the DEFAULT value of transaction_alloc_block_size #
47 ########################################################################
49 SET @@global.transaction_alloc_block_size = 100;
50 SET @@global.transaction_alloc_block_size = DEFAULT;
51 SELECT @@global.transaction_alloc_block_size;
54 SET @@session.transaction_alloc_block_size = 200;
55 SET @@session.transaction_alloc_block_size = DEFAULT;
56 SELECT @@session.transaction_alloc_block_size;
60 --echo
'#--------------------FN_DYNVARS_005_02-------------------------#'
61 ########################################################################
62 # Check the DEFAULT value of transaction_alloc_block_size #
63 ########################################################################
65 SET @@global.transaction_alloc_block_size = DEFAULT;
66 SELECT @@global.transaction_alloc_block_size = 8192;
68 SET @@session.transaction_alloc_block_size = DEFAULT;
69 SELECT @@session.transaction_alloc_block_size = 8192;
72 --echo
'#--------------------FN_DYNVARS_005_03-------------------------#'
73 ##################################################################
74 # Change the value of variable to a valid value for GLOBAL Scope #
75 ##################################################################
77 SET @@global.transaction_alloc_block_size = 1024;
78 SELECT @@global.transaction_alloc_block_size;
80 SET @@global.transaction_alloc_block_size = 60020;
81 SELECT @@global.transaction_alloc_block_size;
83 SET @@global.transaction_alloc_block_size = 4294967295;
84 SELECT @@global.transaction_alloc_block_size;
86 --echo
'#--------------------FN_DYNVARS_005_04-------------------------#'
87 ###################################################################
88 # Change the value of variable to a valid value for SESSION Scope #
89 ###################################################################
91 SET @@session.transaction_alloc_block_size = 1024;
92 SELECT @@session.transaction_alloc_block_size;
94 SET @@session.transaction_alloc_block_size =4294967295;
95 SELECT @@session.transaction_alloc_block_size;
97 SET @@session.transaction_alloc_block_size = 65535;
98 SELECT @@session.transaction_alloc_block_size;
101 --echo
'#------------------FN_DYNVARS_005_05-----------------------#'
102 ########################################################################
103 # Change the value of transaction_alloc_block_size to an invalid value #
104 ########################################################################
106 SET @@global.transaction_alloc_block_size = 0;
107 SELECT @@global.transaction_alloc_block_size;
109 SET @@global.transaction_alloc_block_size = -1024;
110 SELECT @@global.transaction_alloc_block_size;
113 SET @@global.transaction_alloc_block_size = 123456789201;
114 SELECT @@global.transaction_alloc_block_size;
116 -- Error ER_WRONG_TYPE_FOR_VAR
117 SET @@global.transaction_alloc_block_size = ON;
119 -- Error ER_WRONG_TYPE_FOR_VAR
120 SET @@global.transaction_alloc_block_size = OFF;
123 SET @@global.transaction_alloc_block_size =
True;
124 SELECT @@global.transaction_alloc_block_size;
126 SET @@global.transaction_alloc_block_size = False;
127 SELECT @@global.transaction_alloc_block_size;
130 -- Error ER_WRONG_TYPE_FOR_VAR
131 SET @@global.transaction_alloc_block_size = 65530.34;
133 -- Error ER_WRONG_TYPE_FOR_VAR
134 SET @@global.transaction_alloc_block_size =
"Test";
136 SET @@global.transaction_alloc_block_size = 1000;
137 SELECT @@global.transaction_alloc_block_size;
139 SET @@session.transaction_alloc_block_size = 12345678901;
140 SELECT @@session.transaction_alloc_block_size;
142 -- Error ER_WRONG_TYPE_FOR_VAR
143 SET @@session.transaction_alloc_block_size = ON;
145 -- Error ER_WRONG_TYPE_FOR_VAR
146 SET @@session.transaction_alloc_block_size = OFF;
148 SET @@session.transaction_alloc_block_size =
True;
149 SELECT @@session.transaction_alloc_block_size;
151 SET @@session.transaction_alloc_block_size = False;
152 SELECT @@session.transaction_alloc_block_size;
155 -- Error ER_WRONG_TYPE_FOR_VAR
156 SET @@session.transaction_alloc_block_size =
"Test";
159 --Error ER_WRONG_TYPE_FOR_VAR
160 SET @@session.transaction_alloc_block_size =
'test';
162 --echo
'#------------------FN_DYNVARS_005_06-----------------------#'
163 ####################################################################
164 # Check if the value in GLOBAL Table matches value in variable #
165 ####################################################################
168 SELECT @@global.transaction_alloc_block_size = VARIABLE_VALUE
169 FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
170 WHERE VARIABLE_NAME=
'transaction_alloc_block_size';
172 --echo
'#------------------FN_DYNVARS_005_07-----------------------#'
173 ####################################################################
174 # Check if the value in SESSION Table matches value in variable #
175 ####################################################################
177 SELECT @@session.transaction_alloc_block_size = VARIABLE_VALUE
178 FROM INFORMATION_SCHEMA.SESSION_VARIABLES
179 WHERE VARIABLE_NAME=
'transaction_alloc_block_size';
182 --echo
'#---------------------FN_DYNVARS_001_08----------------------#'
183 ###########################################################################
184 # Check if global and session variable are independent of each other #
185 ###########################################################################
187 SET @@transaction_alloc_block_size = 1024;
188 SET @@global.transaction_alloc_block_size = 4294967295;
189 SELECT @@transaction_alloc_block_size = @@global.transaction_alloc_block_size;
192 --echo
'#---------------------FN_DYNVARS_001_09----------------------#'
193 ########################################################################
194 # Check if accessing variable with SESSION,LOCAL and without SCOPE #
195 # points to same session variable #
196 ########################################################################
198 SET @@transaction_alloc_block_size = 100;
199 SELECT @@transaction_alloc_block_size = @@local.transaction_alloc_block_size;
200 SELECT @@local.transaction_alloc_block_size = @@session.transaction_alloc_block_size;
203 --echo
'#---------------------FN_DYNVARS_001_10----------------------#'
204 ################################################################
205 # Check if variable can be accessed with and without @@ sign #
206 ################################################################
208 SET transaction_alloc_block_size = 1027;
209 SELECT @@transaction_alloc_block_size;
211 --Error ER_UNKNOWN_TABLE
212 SELECT local.transaction_alloc_block_size;
214 --Error ER_UNKNOWN_TABLE
215 SELECT session.transaction_alloc_block_size;
217 --Error ER_BAD_FIELD_ERROR
218 SELECT transaction_alloc_block_size = @@session.transaction_alloc_block_size;
221 ####################################
222 # Restore initial value #
223 ####################################
225 SET @@global.transaction_alloc_block_size = @start_global_value;
226 SELECT @@global.transaction_alloc_block_size;
227 SET @@session.tmp_table_size = @start_session_value;
228 SELECT @@session.transaction_alloc_block_size;
231 #############################################################
232 # END OF transaction_alloc_block_size TESTS #
233 #############################################################