mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
06142cd545
assertion .\filesort.cc, line 797 A query with the "ORDER BY @@some_system_variable" clause, where @@some_system_variable is NULL, causes assertion failure in the filesort procedures. The reason of the failure is in the value of Item_func_get_system_var::maybe_null: it was unconditionally set to false even if the value of a variable was NULL. mysql-test/r/variables.result: Added test case for bug #42778. mysql-test/suite/sys_vars/r/innodb_data_home_dir_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/innodb_flush_method_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/rpl_init_slave_func.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/ssl_capath_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/ssl_cipher_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/innodb_data_home_dir_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/innodb_flush_method_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/ssl_capath_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/ssl_cipher_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/t/variables.test: Added test case for bug #42778. sql/item.cc: Bug #42778: delete order by null global variable causes assertion .\filesort.cc, line 797 The longlong_from_string_with_check function has been modified to skip unwanted warnings: now it uses the THD::no_errors flag to suppress warnings. The Item_func_get_system_var::update_null_value method sets the no_error flag. sql/item_func.cc: Bug #42778: delete order by null global variable causes assertion .\filesort.cc, line 797 1. The Item_func_get_system_var::fix_length_and_dec method has been modified to make system variables truly nullable. 2. The Item_func_get_system_var::update_null_value method method has been overloaded with a simple wrapper (like Item_field::update_null_value) to suppress unwanted warnings from Item_func_get_system_var::val_int() calls on non-numeric variable values: the Item_func_get_system_var::update_null_value method sets and restores THD::no_errors flag for a nested call of the longlong_from_string_with_check function. sql/item_func.h: Bug #42778: delete order by null global variable causes assertion .\filesort.cc, line 797 The Item_func_get_system_var::update_null_value method method has been overloaded.
100 lines
4.1 KiB
Text
100 lines
4.1 KiB
Text
|
|
|
|
################## mysql-test\t\ssl_cipher_basic.test #########################
|
|
# #
|
|
# Variable Name: ssl_cipher #
|
|
# Scope: Global #
|
|
# Access Type: Static #
|
|
# Data Type: filename #
|
|
# #
|
|
# #
|
|
# Creation Date: 2008-02-07 #
|
|
# Author : Sharique Abdullah #
|
|
# #
|
|
# #
|
|
# Description:Test Cases of Dynamic System Variable ssl_cipher #
|
|
# that checks the behavior of this variable in the following ways #
|
|
# * Value Check #
|
|
# * Scope Check #
|
|
# #
|
|
# Reference: http://dev.mysql.com/doc/refman/5.1/en/ #
|
|
# server-system-variables.html #
|
|
# #
|
|
###############################################################################
|
|
|
|
--echo '#---------------------BS_STVARS_048_01----------------------#'
|
|
####################################################################
|
|
# Displaying default value #
|
|
####################################################################
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
--echo 0 Expected
|
|
|
|
|
|
--echo '#---------------------BS_STVARS_048_02----------------------#'
|
|
####################################################################
|
|
# Check if Value can set #
|
|
####################################################################
|
|
|
|
--error ER_INCORRECT_GLOBAL_LOCAL_VAR
|
|
SET @@GLOBAL.ssl_cipher=1;
|
|
--echo Expected error 'Read only variable'
|
|
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
--echo 0 Expected
|
|
|
|
|
|
|
|
|
|
--echo '#---------------------BS_STVARS_048_03----------------------#'
|
|
#################################################################
|
|
# Check if the value in GLOBAL Table matches value in variable #
|
|
#################################################################
|
|
|
|
SELECT @@GLOBAL.ssl_cipher = VARIABLE_VALUE
|
|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
|
|
WHERE VARIABLE_NAME='ssl_cipher';
|
|
--echo 1 Expected
|
|
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
--echo 0 Expected
|
|
|
|
SELECT COUNT(VARIABLE_VALUE)
|
|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
|
|
WHERE VARIABLE_NAME='ssl_cipher';
|
|
--echo 1 Expected
|
|
|
|
|
|
|
|
--echo '#---------------------BS_STVARS_048_04----------------------#'
|
|
################################################################################
|
|
# Check if accessing variable with and without GLOBAL point to same variable #
|
|
################################################################################
|
|
SELECT @@ssl_cipher = @@GLOBAL.ssl_cipher;
|
|
--echo 1 Expected
|
|
|
|
|
|
|
|
--echo '#---------------------BS_STVARS_048_05----------------------#'
|
|
################################################################################
|
|
# Check if ssl_cipher can be accessed with and without @@ sign #
|
|
################################################################################
|
|
|
|
SELECT COUNT(@@ssl_cipher);
|
|
--echo 0 Expected
|
|
|
|
--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
|
|
SELECT COUNT(@@local.ssl_cipher);
|
|
--echo Expected error 'Variable is a GLOBAL variable'
|
|
|
|
--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
|
|
SELECT COUNT(@@SESSION.ssl_cipher);
|
|
--echo Expected error 'Variable is a GLOBAL variable'
|
|
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
--echo 0 Expected
|
|
|
|
--Error ER_BAD_FIELD_ERROR
|
|
SELECT ssl_cipher = @@SESSION.ssl_cipher;
|
|
--echo Expected error 'Readonly variable'
|
|
|
|
|