1
############## mysql-test\t\character_set_connection_basic.test ###############
3
# Variable Name: character_set_connection #
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_connection #
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_connection TESTS ##
34
###################################################
36
#############################################################
37
# Save initial value #
38
#############################################################
39
SET @global_start_value = @@global.character_set_connection;
40
SELECT @global_start_value;
41
# Save initial session value
42
SET @session_start_value = @@character_set_connection;
43
SELECT @session_start_value;
44
# now save using local access
45
SET @session_start_value = @@local.character_set_connection;
46
SELECT @session_start_value;
47
# save using default access (session)
48
SET @session_start_value = @@session.character_set_connection;
49
SELECT @session_start_value;
51
--echo '#--------------------FN_DYNVARS_011_01------------------#'
52
###############################################################################
53
# Test Variable access and assignment with and withoud @@ #
54
###############################################################################
56
--error ER_BAD_FIELD_ERROR
57
SELECT character_set_connection;
58
# assign value without @@
59
SET character_set_connection=utf8;
60
SELECT @@session.character_set_connection;
61
# assign global variable without @@
62
--Error ER_PARSE_ERROR
63
SET global.character_set_connection=utf8;
64
# using another syntax for accessing session variable
65
SET session character_set_connection=utf8;
66
# accessing variable with scope the wrong way
67
--Error ER_BAD_FIELD_ERROR
68
SELECT session character_set_connection;
69
# using another syntax for accessing dynamic variable
70
SET global character_set_connection=utf8;
71
--Error ER_BAD_FIELD_ERROR
72
SELECT global character_set_connection;
74
--echo '#--------------------FN_DYNVARS_011_02-------------------------#'
75
###############################################################################
76
# Check the DEFAULT value of character_set_connection for session and global #
77
###############################################################################
78
SET @@character_set_connection = latin5;
79
SET @@character_set_connection = DEFAULT;
80
SELECT @@character_set_connection AS DEFAULT_VALUE;
82
SET @@global.character_set_connection = latin5;
83
SET @@global.character_set_connection = DEFAULT;
84
SELECT @@global.character_set_connection;
86
--echo '#--------------------FN_DYNVARS_011_03-------------------------#'
87
###############################################################################
88
# see if setting global value changes session value and vice versa #
89
###############################################################################
90
SET @@session.character_set_connection = utf8;
91
SELECT @@session.character_set_connection;
92
SET @@global.character_set_connection = latin2;
93
SELECT @@global.character_set_connection;
94
SELECT @@session.character_set_connection AS res_is_utf8;
96
SET @@session.character_set_connection = latin5;
97
SELECT @@session.character_set_connection;
98
SELECT @@global.character_set_connection AS res_is_latin2;
100
SELECT @@global.character_set_connection=@@session.character_set_connection
103
--echo '#--------------------FN_DYNVARS_011_04-------------------------#'
104
#############################################################################
105
# Check if accessing variable with and without session point to #
107
#############################################################################
108
SELECT @@character_set_connection = @@session.character_set_connection AS res;
109
SELECT @@character_set_connection = @@local.character_set_connection AS res;
111
--echo '#--------------------FN_DYNVARS_011_05-------------------------#'
112
###########################################################################
113
# Check if combining character set works #
114
###########################################################################
115
--Error ER_BAD_FIELD_ERROR
116
SET @@character_set_connection = utf8 + latin2;
118
--echo '#--------------------FN_DYNVARS_011_06-------------------------#'
119
##############################################################################
120
# Change the value of character_set_connection to a valid value #
122
##############################################################################
124
let charset_variable = @@session.character_set_connection;
125
--source include/charset_basic.inc
128
--echo '#--------------------FN_DYNVARS_011_07-------------------------#'
129
##############################################################################
130
# Change the value of character_set_connection to a valid value for global #
131
##############################################################################
133
let charset_variable = @@global.character_set_connection;
134
--source include/charset_basic.inc
137
--echo '#--------------------FN_DYNVARS_011_08-------------------------#'
138
##############################################################################
139
# Change the value of character_set_connection to a valid value with #
140
# uppercase,lowercase and mixedcase #
141
##############################################################################
142
SET @@character_set_connection = UTF8;
143
SELECT @@character_set_connection;
144
SET @@character_set_connection = utf8;
145
SELECT @@character_set_connection;
147
SET @@global.character_set_connection = uTf8;
148
SELECT @@global.character_set_connection;
150
--echo '#--------------------FN_DYNVARS_011_09-------------------------#'
151
##############################################################
152
# Check if 1,2,3, ... values can be used on variable #
153
##############################################################
154
SET @@character_set_connection = 1;
155
SELECT @@character_set_connection;
156
SET @@character_set_connection = 2;
157
SELECT @@character_set_connection;
158
SET @@character_set_connection = 3;
159
SELECT @@character_set_connection;
160
SET @@character_set_connection = 36;
161
SELECT @@character_set_connection;
162
SET @@character_set_connection = 99;
163
SELECT @@character_set_connection;
165
--Error ER_UNKNOWN_CHARACTER_SET
166
SET @@character_set_connection = 100;
169
SET @@global.character_set_connection = 1;
170
SELECT @@global.character_set_connection;
171
SET @@global.character_set_connection = 2;
172
SELECT @@global.character_set_connection;
173
SET @@global.character_set_connection = 3;
174
SELECT @@global.character_set_connection;
175
SET @@global.character_set_connection = 36;
176
SELECT @@global.character_set_connection;
177
SET @@global.character_set_connection = 99;
178
SELECT @@global.character_set_connection;
180
--Error ER_UNKNOWN_CHARACTER_SET
181
SET @@global.character_set_connection = 100;
183
SET @total_charset = (SELECT count(*) FROM INFORMATION_SCHEMA.CHARACTER_SETS);
184
SELECT @total_charset;
185
--echo 'Bug # 34843: character sets are mapped in such a way that 100 and following ';
186
--echo 'numbers gives error, and before 100 the 36 mapped wraps arround';
187
--echo 'several times.';
189
--echo '#--------------------FN_DYNVARS_011_10-------------------------#'
190
################################################################################
191
# Change the value of character_set_connection to an invalid value for session #
192
################################################################################
193
--Error ER_UNKNOWN_CHARACTER_SET
194
SET @@character_set_connection = abc;
195
--Error ER_UNKNOWN_CHARACTER_SET
196
SET @@character_set_connection = 1utf8;
197
--Error ER_UNKNOWN_CHARACTER_SET
198
SET @@character_set_connection = 0;
199
--Error ER_WRONG_TYPE_FOR_VAR
200
SET @@character_set_connection = 1.1;
201
--Error ER_UNKNOWN_CHARACTER_SET
202
SET @@character_set_connection = -1;
203
--Error ER_UNKNOWN_CHARACTER_SET
204
SET @@character_set_connection = 'utf8 ';
205
--Error ER_UNKNOWN_CHARACTER_SET
206
SET @@character_set_connection = 'l�tin2';
207
SET @@character_set_connection = true;
208
SELECT @@character_set_connection AS res_with_true;
209
--Error ER_UNKNOWN_CHARACTER_SET
210
SET @@character_set_connection = ON;
212
--echo '#--------------------FN_DYNVARS_011_11-------------------------#'
213
###############################################################################
214
# Change the value of character_set_connection to an invalid value for global #
215
###############################################################################
216
--Error ER_UNKNOWN_CHARACTER_SET
217
SET @@global.character_set_connection = abc;
218
--Error ER_UNKNOWN_CHARACTER_SET
219
SET @@global.character_set_connection = 1utf8;
220
--Error ER_UNKNOWN_CHARACTER_SET
221
SET @@global.character_set_connection = 0;
222
--Error ER_WRONG_TYPE_FOR_VAR
223
SET @@global.character_set_connection = 1.1;
224
--Error ER_UNKNOWN_CHARACTER_SET
225
SET @@global.character_set_connection = -1;
226
--Error ER_UNKNOWN_CHARACTER_SET
227
SET @@global.character_set_connection = '';
228
--Error ER_UNKNOWN_CHARACTER_SET
229
SET @@global.character_set_connection = 'utf';
231
SET @@global.character_set_connection = true;
233
--Error ER_UNKNOWN_CHARACTER_SET
234
SET @@global.character_set_connection = ON;
236
--echo '#--------------------FN_DYNVARS_011_12-------------------------#'
237
##########################################################################
238
# Check if the value in GLOBAL Table matches value in variable #
239
##########################################################################
240
SELECT @@global.character_set_connection =
241
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
242
WHERE VARIABLE_NAME='character_set_connection') AS res;
243
SET @@global.character_set_connection = 1;
244
SELECT @@global.character_set_connection;
245
SELECT @@global.character_set_connection =
246
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
247
WHERE VARIABLE_NAME='character_set_connection') AS res;
249
--echo '#--------------------FN_DYNVARS_011_13-------------------------#'
250
############################################################################
251
# Check if the value in SESSION Table matches value in variable #
252
############################################################################
253
SELECT @@character_set_connection =
254
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES
255
WHERE VARIABLE_NAME='character_set_connection') AS res;
256
SELECT @@local.character_set_connection =
257
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES
258
WHERE VARIABLE_NAME='character_set_connection') AS res;
259
SELECT @@session.character_set_connection =
260
(SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.SESSION_VARIABLES
261
WHERE VARIABLE_NAME='character_set_connection') AS res;
263
####################################
264
# Restore initial value #
265
####################################
266
SET @@global.character_set_connection = @global_start_value;
267
SELECT @@global.character_set_connection;
268
SET @@session.character_set_connection = @session_start_value;
269
SELECT @@session.character_set_connection;
271
#############################################################
272
# END OF character_set_connection TESTS #
273
#############################################################