mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +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.
		
			
				
	
	
		
			103 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
 | 
						|
 | 
						|
################## mysql-test\t\innodb_flush_method_basic.test ################
 | 
						|
#                                                                             #
 | 
						|
# Variable Name: innodb_flush_method                                          #
 | 
						|
# Scope: Global                                                               #
 | 
						|
# Access Type: Static                                                         #
 | 
						|
# Data Type: enumeration                                                      #
 | 
						|
#                                                                             #
 | 
						|
#                                                                             #
 | 
						|
# Creation Date: 2008-02-07                                                   #
 | 
						|
# Author : Sharique Abdullah                                                  #
 | 
						|
#                                                                             #
 | 
						|
#                                                                             #
 | 
						|
# Description:Test Cases of Dynamic System Variable innodb_flush_method       #
 | 
						|
#             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                                               #
 | 
						|
#                                                                             #
 | 
						|
###############################################################################
 | 
						|
 | 
						|
--source include/have_innodb.inc
 | 
						|
 | 
						|
--echo '#---------------------BS_STVARS_029_01----------------------#'
 | 
						|
####################################################################
 | 
						|
#   Displaying default value                                       #
 | 
						|
####################################################################
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
--echo 0 Expected
 | 
						|
 | 
						|
 | 
						|
--echo '#---------------------BS_STVARS_029_02----------------------#'
 | 
						|
####################################################################
 | 
						|
#   Check if Value can set                                         #
 | 
						|
####################################################################
 | 
						|
 | 
						|
--error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | 
						|
SET @@GLOBAL.innodb_flush_method=1;
 | 
						|
--echo Expected error 'Read only variable'
 | 
						|
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
--echo 0 Expected
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
--echo '#---------------------BS_STVARS_029_03----------------------#'
 | 
						|
#################################################################
 | 
						|
# Check if the value in GLOBAL Table matches value in variable  #
 | 
						|
#################################################################
 | 
						|
 | 
						|
SELECT @@GLOBAL.innodb_flush_method = VARIABLE_VALUE
 | 
						|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
 | 
						|
WHERE VARIABLE_NAME='innodb_flush_method';
 | 
						|
--echo 1 Expected
 | 
						|
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
--echo 0 Expected
 | 
						|
 | 
						|
SELECT COUNT(VARIABLE_VALUE)
 | 
						|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES 
 | 
						|
WHERE VARIABLE_NAME='innodb_flush_method';
 | 
						|
--echo 1 Expected
 | 
						|
 | 
						|
 | 
						|
 | 
						|
--echo '#---------------------BS_STVARS_029_04----------------------#'
 | 
						|
################################################################################
 | 
						|
#  Check if accessing variable with and without GLOBAL point to same variable  #
 | 
						|
################################################################################
 | 
						|
SELECT @@innodb_flush_method = @@GLOBAL.innodb_flush_method;
 | 
						|
--echo 1 Expected
 | 
						|
 | 
						|
 | 
						|
 | 
						|
--echo '#---------------------BS_STVARS_029_05----------------------#'
 | 
						|
################################################################################
 | 
						|
#   Check if innodb_flush_method can be accessed with and without @@ sign      #
 | 
						|
################################################################################
 | 
						|
 | 
						|
SELECT COUNT(@@innodb_flush_method);
 | 
						|
--echo 0 Expected
 | 
						|
 | 
						|
--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | 
						|
SELECT COUNT(@@local.innodb_flush_method);
 | 
						|
--echo Expected error 'Variable is a GLOBAL variable'
 | 
						|
 | 
						|
--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | 
						|
SELECT COUNT(@@SESSION.innodb_flush_method);
 | 
						|
--echo Expected error 'Variable is a GLOBAL variable'
 | 
						|
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
--echo 0 Expected
 | 
						|
 | 
						|
--Error ER_BAD_FIELD_ERROR
 | 
						|
SELECT innodb_flush_method = @@SESSION.innodb_flush_method;
 | 
						|
--echo Expected error 'Readonly variable'
 | 
						|
 | 
						|
 |