1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
############## mysql-test\t\default_master_connection_basic.test ###############
#
# Implemented in the scope of MDEV-253
# The variable is SESSION-only
#
--source include/not_embedded.inc
#############################################################
# Save initial value #
#############################################################
SET @start_session_value = @@session.default_master_connection;
SELECT @start_session_value;
###################################################################
# Display the DEFAULT value of default_master_connection #
###################################################################
SET @@session.default_master_connection = 'bar';
SET @@session.default_master_connection = DEFAULT;
SELECT @@session.default_master_connection;
###################################################################
# Check the DEFAULT value of default_master_connection #
###################################################################
SET @@session.default_master_connection = @start_session_value;
SELECT @@session.default_master_connection = '';
#################################################
# Check that the GLOBAL scope is not applicable #
#################################################
--error ER_LOCAL_VARIABLE
SET @@global.default_master_connection = 'master1';
--error ER_INCORRECT_GLOBAL_LOCAL_VAR
SELECT @@global.default_master_connection;
####################################################################################
# Change the value of default_master_connection to a valid value for SESSION Scope #
####################################################################################
SET @@session.default_master_connection = 'master1';
SELECT @@session.default_master_connection;
SET @@session.default_master_connection = '';
SELECT @@session.default_master_connection;
SET @@session.default_master_connection = '1234-5678';
SELECT @@session.default_master_connection;
SET @@session.default_master_connection = '@!*/"';
SELECT @@session.default_master_connection;
SET @@session.default_master_connection = REPEAT('a',191);
SELECT @@session.default_master_connection;
SET @@session.default_master_connection = master2;
SELECT @@session.default_master_connection;
#####################################################################
# Change the value of default_master_connection to an invalid value #
#####################################################################
--error ER_WRONG_TYPE_FOR_VAR
SET @@session.default_master_connection = 1;
--error ER_WRONG_TYPE_FOR_VAR
SET @@session.default_master_connection = 65530.30;
--error ER_WRONG_TYPE_FOR_VAR
SET @@session.default_master_connection = FALSE;
SELECT @@session.default_master_connection;
--error ER_WRONG_VALUE_FOR_VAR
SET @@session.default_master_connection = REPEAT('a',192);
SELECT @@session.default_master_connection;
--error ER_WRONG_VALUE_FOR_VAR
SET @@session.default_master_connection = NULL;
SELECT @@session.default_master_connection;
###############################################################################
# Check if the value in GLOBAL & SESSION Tables matches value in variable #
###############################################################################
--error ER_INCORRECT_GLOBAL_LOCAL_VAR
SELECT @@global.default_master_connection = VARIABLE_VALUE
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
WHERE VARIABLE_NAME='default_master_connection';
SELECT @@session.default_master_connection = VARIABLE_VALUE
FROM INFORMATION_SCHEMA.SESSION_VARIABLES
WHERE VARIABLE_NAME='default_master_connection';
########################################################################################################
# Check if accessing variable with SESSION,LOCAL and without SCOPE points to same session variable #
########################################################################################################
SET @@default_master_connection = 'foo';
SELECT @@default_master_connection = @@local.default_master_connection;
SELECT @@local.default_master_connection = @@session.default_master_connection;
###################################################################################
# Check if default_master_connection can be accessed with and without @@ sign #
###################################################################################
SET default_master_connection = 'foo';
SELECT @@default_master_connection;
--Error ER_UNKNOWN_TABLE
SELECT local.default_master_connection;
--Error ER_UNKNOWN_TABLE
SELECT session.default_master_connection;
--Error ER_BAD_FIELD_ERROR
SELECT default_master_connection = @@session.default_master_connection;
####################################
# Restore initial value #
####################################
SET @@session.default_master_connection = @start_session_value;
SELECT @@session.default_master_connection;
#############################################################
# END OF default_master_connection TESTS #
#############################################################
|