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
SET @@global.transaction_alloc_block_size = ON;
122
SET @@global.transaction_alloc_block_size = OFF;
125
SET @@global.transaction_alloc_block_size = True;
126
SELECT @@global.transaction_alloc_block_size;
128
SET @@global.transaction_alloc_block_size = False;
129
SELECT @@global.transaction_alloc_block_size;
132
SET @@global.transaction_alloc_block_size = 65530.34;
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
--echo 'Bug # 34837: Errors are not coming on assigning invalid values to variable';
144
SET @@session.transaction_alloc_block_size = ON;
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
SET @@session.transaction_alloc_block_size = "Test";
158
--Error ER_WRONG_TYPE_FOR_VAR
159
SET @@session.transaction_alloc_block_size = 'test';
161
--echo '#------------------FN_DYNVARS_005_06-----------------------#'
162
####################################################################
163
# Check if the value in GLOBAL Table matches value in variable #
164
####################################################################
167
SELECT @@global.transaction_alloc_block_size = VARIABLE_VALUE
168
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
169
WHERE VARIABLE_NAME='transaction_alloc_block_size';
171
--echo '#------------------FN_DYNVARS_005_07-----------------------#'
172
####################################################################
173
# Check if the value in SESSION Table matches value in variable #
174
####################################################################
176
SELECT @@session.transaction_alloc_block_size = VARIABLE_VALUE
177
FROM INFORMATION_SCHEMA.SESSION_VARIABLES
178
WHERE VARIABLE_NAME='transaction_alloc_block_size';
181
--echo '#---------------------FN_DYNVARS_001_08----------------------#'
182
###########################################################################
183
# Check if global and session variable are independent of each other #
184
###########################################################################
186
SET @@transaction_alloc_block_size = 1024;
187
SET @@global.transaction_alloc_block_size = 4294967295;
188
SELECT @@transaction_alloc_block_size = @@global.transaction_alloc_block_size;
191
--echo '#---------------------FN_DYNVARS_001_09----------------------#'
192
########################################################################
193
# Check if accessing variable with SESSION,LOCAL and without SCOPE #
194
# points to same session variable #
195
########################################################################
197
SET @@transaction_alloc_block_size = 100;
198
SELECT @@transaction_alloc_block_size = @@local.transaction_alloc_block_size;
199
SELECT @@local.transaction_alloc_block_size = @@session.transaction_alloc_block_size;
202
--echo '#---------------------FN_DYNVARS_001_10----------------------#'
203
################################################################
204
# Check if variable can be accessed with and without @@ sign #
205
################################################################
207
SET transaction_alloc_block_size = 1027;
208
SELECT @@transaction_alloc_block_size;
210
--Error ER_UNKNOWN_TABLE
211
SELECT local.transaction_alloc_block_size;
213
--Error ER_UNKNOWN_TABLE
214
SELECT session.transaction_alloc_block_size;
216
--Error ER_BAD_FIELD_ERROR
217
SELECT transaction_alloc_block_size = @@session.transaction_alloc_block_size;
220
####################################
221
# Restore initial value #
222
####################################
224
SET @@global.transaction_alloc_block_size = @start_global_value;
225
SELECT @@global.transaction_alloc_block_size;
226
SET @@session.tmp_table_size = @start_session_value;
227
SELECT @@session.transaction_alloc_block_size;
230
#############################################################
231
# END OF transaction_alloc_block_size TESTS #
232
#############################################################