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;
85
--echo 'Bug# 34877: Invalid Values are coming in variable on assigning valid values';
87
--echo '#--------------------FN_DYNVARS_005_04-------------------------#'
88
###################################################################
89
# Change the value of variable to a valid value for SESSION Scope #
90
###################################################################
92
SET @@session.transaction_alloc_block_size = 1024;
93
SELECT @@session.transaction_alloc_block_size;
95
SET @@session.transaction_alloc_block_size =4294967295;
96
SELECT @@session.transaction_alloc_block_size;
98
SET @@session.transaction_alloc_block_size = 65535;
99
SELECT @@session.transaction_alloc_block_size;
100
--echo 'Bug# 34877: Invalid Values are coming in variable on assigning valid values';
103
--echo '#------------------FN_DYNVARS_005_05-----------------------#'
104
########################################################################
105
# Change the value of transaction_alloc_block_size to an invalid value #
106
########################################################################
108
SET @@global.transaction_alloc_block_size = 0;
109
SELECT @@global.transaction_alloc_block_size;
111
SET @@global.transaction_alloc_block_size = -1024;
112
SELECT @@global.transaction_alloc_block_size;
115
SET @@global.transaction_alloc_block_size = 123456789201;
116
SELECT @@global.transaction_alloc_block_size;
118
--echo 'Bug # 34837: Errors are not coming on assigning invalid values to variable';
120
-- Error ER_WRONG_TYPE_FOR_VAR
121
SET @@global.transaction_alloc_block_size = ON;
123
-- Error ER_WRONG_TYPE_FOR_VAR
124
SET @@global.transaction_alloc_block_size = OFF;
127
SET @@global.transaction_alloc_block_size = True;
128
SELECT @@global.transaction_alloc_block_size;
130
SET @@global.transaction_alloc_block_size = False;
131
SELECT @@global.transaction_alloc_block_size;
134
-- Error ER_WRONG_TYPE_FOR_VAR
135
SET @@global.transaction_alloc_block_size = 65530.34;
137
-- Error ER_WRONG_TYPE_FOR_VAR
138
SET @@global.transaction_alloc_block_size ="Test";
140
SET @@global.transaction_alloc_block_size = 1000;
141
SELECT @@global.transaction_alloc_block_size;
143
SET @@session.transaction_alloc_block_size = 12345678901;
144
SELECT @@session.transaction_alloc_block_size;
146
--echo 'Bug # 34837: Errors are not coming on assigning invalid values to variable';
148
-- Error ER_WRONG_TYPE_FOR_VAR
149
SET @@session.transaction_alloc_block_size = ON;
151
-- Error ER_WRONG_TYPE_FOR_VAR
152
SET @@session.transaction_alloc_block_size = OFF;
154
SET @@session.transaction_alloc_block_size = True;
155
SELECT @@session.transaction_alloc_block_size;
157
SET @@session.transaction_alloc_block_size = False;
158
SELECT @@session.transaction_alloc_block_size;
161
-- Error ER_WRONG_TYPE_FOR_VAR
162
SET @@session.transaction_alloc_block_size = "Test";
165
--Error ER_WRONG_TYPE_FOR_VAR
166
SET @@session.transaction_alloc_block_size = 'test';
168
--echo '#------------------FN_DYNVARS_005_06-----------------------#'
169
####################################################################
170
# Check if the value in GLOBAL Table matches value in variable #
171
####################################################################
174
SELECT @@global.transaction_alloc_block_size = VARIABLE_VALUE
175
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
176
WHERE VARIABLE_NAME='transaction_alloc_block_size';
178
--echo '#------------------FN_DYNVARS_005_07-----------------------#'
179
####################################################################
180
# Check if the value in SESSION Table matches value in variable #
181
####################################################################
183
SELECT @@session.transaction_alloc_block_size = VARIABLE_VALUE
184
FROM INFORMATION_SCHEMA.SESSION_VARIABLES
185
WHERE VARIABLE_NAME='transaction_alloc_block_size';
188
--echo '#---------------------FN_DYNVARS_001_08----------------------#'
189
###########################################################################
190
# Check if global and session variable are independent of each other #
191
###########################################################################
193
SET @@transaction_alloc_block_size = 1024;
194
SET @@global.transaction_alloc_block_size = 4294967295;
195
SELECT @@transaction_alloc_block_size = @@global.transaction_alloc_block_size;
198
--echo '#---------------------FN_DYNVARS_001_09----------------------#'
199
########################################################################
200
# Check if accessing variable with SESSION,LOCAL and without SCOPE #
201
# points to same session variable #
202
########################################################################
204
SET @@transaction_alloc_block_size = 100;
205
SELECT @@transaction_alloc_block_size = @@local.transaction_alloc_block_size;
206
SELECT @@local.transaction_alloc_block_size = @@session.transaction_alloc_block_size;
209
--echo '#---------------------FN_DYNVARS_001_10----------------------#'
210
################################################################
211
# Check if variable can be accessed with and without @@ sign #
212
################################################################
214
SET transaction_alloc_block_size = 1027;
215
SELECT @@transaction_alloc_block_size;
217
--Error ER_UNKNOWN_TABLE
218
SELECT local.transaction_alloc_block_size;
220
--Error ER_UNKNOWN_TABLE
221
SELECT session.transaction_alloc_block_size;
223
--Error ER_BAD_FIELD_ERROR
224
SELECT transaction_alloc_block_size = @@session.transaction_alloc_block_size;
227
####################################
228
# Restore initial value #
229
####################################
231
SET @@global.transaction_alloc_block_size = @start_global_value;
232
SELECT @@global.transaction_alloc_block_size;
233
SET @@session.tmp_table_size = @start_session_value;
234
SELECT @@session.transaction_alloc_block_size;
237
#############################################################
238
# END OF transaction_alloc_block_size TESTS #
239
#############################################################