mirror of
https://github.com/MariaDB/server.git
synced 2025-05-25 13:42:52 +03:00
Bind more InnoDB parameters directly to MYSQL_SYSVAR and remove "shadow variables". innodb_change_buffering: Declare as ENUM, not STRING. innodb_flush_method: Declare as ENUM, not STRING. innodb_log_buffer_size: Bind directly to srv_log_buffer_size, without rounding it to a multiple of innodb_page_size. LOG_BUFFER_SIZE: Remove. SysTablespace::normalize_size(): Renamed from normalize(). innodb_init_params(): A new function to initialize and validate InnoDB startup parameters. innodb_init(): Renamed from innobase_init(). Invoke innodb_init_params() before actually trying to start up InnoDB. srv_start(bool): Renamed from innobase_start_or_create_for_mysql(). Added the input parameter create_new_db. SRV_ALL_O_DIRECT_FSYNC: Define only for _WIN32. xb_normalize_init_values(): Merge to innodb_init_param().
107 lines
4.4 KiB
Plaintext
107 lines
4.4 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 1 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 1 Expected
|
|
|
|
|
|
|
|
|
|
--echo '#---------------------BS_STVARS_029_03----------------------#'
|
|
#################################################################
|
|
# Check if the value in GLOBAL Table matches value in variable #
|
|
#################################################################
|
|
|
|
--disable_warnings
|
|
SELECT @@GLOBAL.innodb_flush_method = VARIABLE_VALUE
|
|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
|
|
WHERE VARIABLE_NAME='innodb_flush_method';
|
|
--enable_warnings
|
|
--echo 1 Expected
|
|
|
|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
|
|
--echo 1 Expected
|
|
|
|
--disable_warnings
|
|
SELECT COUNT(VARIABLE_VALUE)
|
|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
|
|
WHERE VARIABLE_NAME='innodb_flush_method';
|
|
--enable_warnings
|
|
--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 1 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 1 Expected
|
|
|
|
--Error ER_BAD_FIELD_ERROR
|
|
SELECT innodb_flush_method = @@SESSION.innodb_flush_method;
|
|
--echo Expected error 'Readonly variable'
|
|
|
|
|