mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-30 04:26:45 +03:00 
			
		
		
		
	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.
		
			
				
	
	
		
			101 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
 | |
| 
 | |
| ################## mysql-test\t\ssl_capath_basic.test #########################
 | |
| #                                                                             #
 | |
| # Variable Name: ssl_capath                                                   #
 | |
| # Scope: Global                                                               #
 | |
| # Access Type: Static                                                         #
 | |
| # Data Type: filename                                                         #
 | |
| #                                                                             #
 | |
| #                                                                             #
 | |
| # Creation Date: 2008-02-07                                                   #
 | |
| # Author : Sharique Abdullah                                                      #
 | |
| #                                                                             #
 | |
| #                                                                             #
 | |
| # Description:Test Cases of Dynamic System Variable ssl_capath                #
 | |
| #             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_046_01----------------------#'
 | |
| ####################################################################
 | |
| #   Displaying default value                                       #
 | |
| ####################################################################
 | |
| SELECT COUNT(@@GLOBAL.ssl_capath);
 | |
| --echo 0 Expected
 | |
| 
 | |
| 
 | |
| --echo '#---------------------BS_STVARS_046_02----------------------#'
 | |
| ####################################################################
 | |
| #   Check if Value can set                                         #
 | |
| ####################################################################
 | |
| 
 | |
| --error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | |
| SET @@GLOBAL.ssl_capath=1;
 | |
| --echo Expected error 'Read only variable'
 | |
| 
 | |
| SELECT COUNT(@@GLOBAL.ssl_capath);
 | |
| --echo 0 Expected
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| --echo '#---------------------BS_STVARS_046_03----------------------#'
 | |
| #################################################################
 | |
| # Check if the value in GLOBAL Table matches value in variable  #
 | |
| #################################################################
 | |
| 
 | |
| SELECT @@GLOBAL.ssl_capath = VARIABLE_VALUE
 | |
| FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
 | |
| WHERE VARIABLE_NAME='ssl_capath';
 | |
| --echo 1 Expected
 | |
| 
 | |
| SELECT COUNT(@@GLOBAL.ssl_capath);
 | |
| --echo 0 Expected
 | |
| 
 | |
| SELECT COUNT(VARIABLE_VALUE)
 | |
| FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES 
 | |
| WHERE VARIABLE_NAME='ssl_capath';
 | |
| --echo 1 Expected
 | |
| 
 | |
| 
 | |
| 
 | |
| --echo '#---------------------BS_STVARS_046_04----------------------#'
 | |
| ################################################################################
 | |
| #  Check if accessing variable with and without GLOBAL point to same variable  #
 | |
| ################################################################################
 | |
| SELECT @@ssl_capath = @@GLOBAL.ssl_capath;
 | |
| --echo 1 Expected
 | |
| 
 | |
| 
 | |
| 
 | |
| --echo '#---------------------BS_STVARS_046_05----------------------#'
 | |
| ################################################################################
 | |
| #   Check if ssl_capath can be accessed with and without @@ sign               #
 | |
| ################################################################################
 | |
| 
 | |
| SELECT COUNT(@@ssl_capath);
 | |
| --echo 0 Expected
 | |
| 
 | |
| --Error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | |
| SELECT COUNT(@@local.ssl_capath);
 | |
| --echo Expected error 'Variable is a GLOBAL variable'
 | |
| 
 | |
| --Error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | |
| SELECT COUNT(@@SESSION.ssl_capath);
 | |
| --echo Expected error 'Variable is a GLOBAL variable'
 | |
| 
 | |
| SELECT COUNT(@@GLOBAL.ssl_capath);
 | |
| --echo 0 Expected
 | |
| 
 | |
| --Error ER_BAD_FIELD_ERROR
 | |
| SELECT ssl_capath = @@SESSION.ssl_capath;
 | |
| --echo Expected error 'Readonly variable'
 | |
| 
 | |
| 
 |