1
############## mysql-test\t\character_set_results_basic.test ##################
3
# Variable Name: character_set_results #
4
# Scope: GLOBAL | SESSION #
5
# Access Type: Dynamic #
7
# Default Value: utf8 (session), latin1 (global) #
11
# Creation Date: 2008-02-07 #
14
# Description: Test Cases of Dynamic System Variable character_set_results #
15
# that checks the behavior of this variable in the following ways#
17
# * Valid & Invalid values #
18
# * Scope & Access method #
21
# Reference: http://dev.mysql.com/doc/refman/5.1/en/ #
22
# server-system-variables.html #
24
###############################################################################
25
--source include/have_big5.inc
26
--source include/have_ujis.inc
27
--source include/have_sjis.inc
28
--source include/have_utf8.inc
29
--source include/have_ucs2.inc
31
--source include/load_sysvars.inc
32
################################################
33
## START OF character_set_results TESTS ##
34
################################################
36
#############################################################
37
# Save initial value #
38
#############################################################
39
SET @global_start_value = @@global.character_set_results;
40
SELECT @global_start_value;
41
# Save initial session value
42
SET @session_start_value = @@character_set_results;
43
SELECT @session_start_value;
44
# now save using local access
45
SET @session_start_value = @@local.character_set_results;
46
SELECT @session_start_value;
47
# save using default access (session)
48
SET @session_start_value = @@session.character_set_results;
49
SELECT @session_start_value;
51
--echo '#--------------------FN_DYNVARS_013_01------------------#'
52
##############################################################################
53
# Test Variable access and assignment with and withoud @@ #
54
##############################################################################
56
--error ER_BAD_FIELD_ERROR
57
SELECT character_set_results;
58
# assign value without @@
59
SET character_set_results=utf8;
60
SELECT @@session.character_set_results;
61
# assign global variable without @@
62
--Error ER_PARSE_ERROR
63
SET global.character_set_results=utf8;
64
# using another syntax for accessing session variable
65
SET session character_set_results=utf8;
66
# accessing variable with scope the wrong way
67
--Error ER_BAD_FIELD_ERROR
68
SELECT session character_set_results;
69
# using another syntax for accessing dynamic variable
70
SET global character_set_results=utf8;
71
--Error ER_BAD_FIELD_ERROR
72
SELECT global character_set_results;
74
--echo '#--------------------FN_DYNVARS_013_02-------------------------#'
75
###############################################################################
76
# Check the DEFAULT value of character_set_results for session and global #
77
###############################################################################
78
SET @@character_set_results = latin5;
79
SET @@character_set_results = DEFAULT;
80
SELECT @@character_set_results AS DEFAULT_VALUE;
82
SET @@global.character_set_results = latin5;
83
SET @@global.character_set_results = DEFAULT;
84
SELECT @@global.character_set_results;
86
--echo '#--------------------FN_DYNVARS_013_03-------------------------#'
87
###############################################################################
88
# see if setting global value changes session value and vice versa #
89
###############################################################################
90
SET @@session.character_set_results = utf8;
91
SELECT @@session.character_set_results;
92
SET @@global.character_set_results = latin2;
93
SELECT @@global.character_set_results;
94
SELECT @@session.character_set_results AS res_is_utf8;
96
SET @@session.character_set_results = latin5;
97
SELECT @@session.character_set_results;
98
SELECT @@global.character_set_results AS res_is_latin2;
100
SELECT @@global.character_set_results=@@session.character_set_results
103
--echo '#--------------------FN_DYNVARS_013_04-------------------------#'
104
###################################################################
105
# Check if accessing variable with and without session point to #
107
###################################################################
108
SELECT @@character_set_results = @@session.character_set_results AS res;
109
SELECT @@character_set_results = @@local.character_set_results AS res;
111
--echo '#--------------------FN_DYNVARS_013_05-------------------------#'
112
###########################################################################
113
# Check if combining character set works #
114
###########################################################################
115
--Error ER_BAD_FIELD_ERROR
116
SET @@character_set_results = utf8 + latin2;
118
--echo '#--------------------FN_DYNVARS_013_06-------------------------#'
119
##############################################################################
120
# Change the value of character_set_results to a valid value for session #
121
##############################################################################
123
let charset_variable = @@session.character_set_results;
124
--source include/charset_basic.inc
127
--echo '#--------------------FN_DYNVARS_013_07-------------------------#'
128
###############################################################################
129
# Change the value of character_set_results to a valid value for global #
130
###############################################################################
132
let charset_variable = @@global.character_set_results;
133
--source include/charset_basic.inc
136
--echo '#--------------------FN_DYNVARS_013_08-------------------------#'
137
################################################################################
138
# Change the value of character_set_results to a valid value with uppercase, #
139
# lowercase and mixedcase #
140
################################################################################
141
SET @@character_set_results = UTF8;
142
SELECT @@character_set_results;
143
SET @@character_set_results = utf8;
144
SELECT @@character_set_results;
146
SET @@global.character_set_results = uTf8;
147
SELECT @@global.character_set_results;
149
--echo '#--------------------FN_DYNVARS_013_09-------------------------#'
150
##############################################################
151
# Check if 1,2,3, ... values can be used on variable #
152
##############################################################
153
SET @@character_set_results = 1;
154
SELECT @@character_set_results;
155
SET @@character_set_results = 2;
156
SELECT @@character_set_results;
157
SET @@character_set_results = 3;
158
SELECT @@character_set_results;
159
SET @@character_set_results = 36;
160
SELECT @@character_set_results;
161
SET @@character_set_results = 99;
162
SELECT @@character_set_results;
164
--Error ER_UNKNOWN_CHARACTER_SET
165
SET @@character_set_results = 100;
167
SET @@global.character_set_results = 1;
168
SELECT @@global.character_set_results;
169
SET @@global.character_set_results = 2;
170
SELECT @@global.character_set_results;
171
SET @@global.character_set_results = 3;
172
SELECT @@global.character_set_results;
173
SET @@global.character_set_results = 36;
174
SELECT @@global.character_set_results;
175
SET @@global.character_set_results = 99;
176
SELECT @@global.character_set_results;
178
--Error ER_UNKNOWN_CHARACTER_SET
179
SET @@global.character_set_results = 100;
181
SET @total_charset = (SELECT count(*) FROM INFORMATION_SCHEMA.CHARACTER_SETS);
182
SELECT @total_charset;
183
--echo 'Bug # 34843: character sets are mapped in such a way that 100 and following';
184
--echo 'numbers gives error, and before 100 the 36 mapped wraps arround several times.';
186
--echo '#--------------------FN_DYNVARS_013_10-------------------------#'
187
###############################################################################
188
# Change the value of character_set_results to an invalid value for session #
189
###############################################################################
190
--Error ER_UNKNOWN_CHARACTER_SET
191
SET @@character_set_results = abc;
192
--Error ER_UNKNOWN_CHARACTER_SET
193
SET @@character_set_results = 1utf8;
194
--Error ER_UNKNOWN_CHARACTER_SET
195
SET @@character_set_results = 0;
196
--Error ER_WRONG_TYPE_FOR_VAR
197
SET @@character_set_results = .1;
198
--Error ER_UNKNOWN_CHARACTER_SET
199
SET @@character_set_results = -1;
200
--Error ER_UNKNOWN_CHARACTER_SET
201
SET @@character_set_results = "";
202
--Error ER_UNKNOWN_CHARACTER_SET
203
SET @@character_set_results = 'utf';
204
SET @@character_set_results = true;
205
SELECT @@character_set_results AS res_with_true;
207
--Error ER_UNKNOWN_CHARACTER_SET
208
SET @@character_set_results = ON;
210
--echo '#--------------------FN_DYNVARS_013_11-------------------------#'
211
###############################################################################
212
# Change the value of character_set_results to an invalid value for global #
213
###############################################################################
214
--Error ER_UNKNOWN_CHARACTER_SET
215
SET @@global.character_set_results = "'latin2'";
216
--Error ER_UNKNOWN_CHARACTER_SET
217
SET @@global.character_set_results = 1utf8;
218
--Error ER_UNKNOWN_CHARACTER_SET
219
SET @@global.character_set_results = 0;
220
--Error ER_WRONG_TYPE_FOR_VAR
221
SET @@global.character_set_results = 0.1;
222
--Error ER_UNKNOWN_CHARACTER_SET
223
SET @@global.character_set_results = -1;
224
--Error ER_UNKNOWN_CHARACTER_SET
225
SET @@global.character_set_results = "";
226
--Error ER_UNKNOWN_CHARACTER_SET
227
SET @@global.character_set_results = 'utf';
229
SET @@global.character_set_results = true;
231
--Error ER_UNKNOWN_CHARACTER_SET
232
SET @@global.character_set_results = ON;
234
--echo '#--------------------FN_DYNVARS_013_12-------------------------#'
235
##############################################################################
236
# Check if the value in GLOBAL Table matches value in variable #
237
##############################################################################
238
SELECT @@global.character_set_results =
239
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
240
WHERE VARIABLE_NAME='character_set_results') AS res;
241
SET @@global.character_set_results = 1;
242
SELECT @@global.character_set_results;
243
SELECT @@global.character_set_results =
244
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
245
WHERE VARIABLE_NAME='character_set_results') AS res;
247
--echo '#--------------------FN_DYNVARS_013_13-------------------------#'
248
##############################################################################
249
# Check if the value in SESSION Table matches value in variable #
250
##############################################################################
251
SELECT @@character_set_results =
252
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES
253
WHERE VARIABLE_NAME='character_set_results') AS res;
254
SELECT @@local.character_set_results =
255
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES
256
WHERE VARIABLE_NAME='character_set_results') AS res;
257
SELECT @@session.character_set_results =
258
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES
259
WHERE VARIABLE_NAME='character_set_results') AS res;
261
####################################
262
# Restore initial value #
263
####################################
264
SET @@global.character_set_results = @global_start_value;
265
SELECT @@global.character_set_results;
266
SET @@session.character_set_results = @session_start_value;
267
SELECT @@session.character_set_results;
269
#############################################################
270
# END OF character_set_results TESTS #
271
#############################################################