config root man

Current Path : /home/usr.opt/mysql57/mysql-test/t/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : /home/usr.opt/mysql57/mysql-test/t/table_open_cache_functionality.test

###############################################################################
#                                                                             #
# Variable Name: table_open_cache                                             #
# Scope: Global                                                               #
# Access Type: Dynamic                                                         #
# Data Type: numeric                                                          #
#                                                                             #
#                                                                             #
# Creation Date: 2012-08-31                                                   #
# Author : Tanjot Singh Uppal                                                 #
#                                                                             #
#                                                                             #
# Description:Test Cases of Dynamic System Variable table_open_cache           #
#             that checks the behavior of this variable in the following ways #
#              * Value Check                                                  #
#              * Scope Check                                                  #
#              * Functionality Check                                          #
#              * Accessability Check                                          #
#                                                                             #               
# This test does not perform the crash recovery on this variable              # 
# For crash recovery test on default change please run the ibtest             #
###############################################################################

-- source include/have_innodb.inc
-- source include/not_embedded.inc
-- source include/have_innodb_16k.inc

CALL mtr.add_suppression("innodb_open_files should not be greater than the open_files_limit.");
CALL mtr.add_suppression("You must raise the value of innodb_open_files in my.cnf! Remember that InnoDB keeps all");
CALL mtr.add_suppression("log files and all system tablespace files open for the whole time mysqld is running, and");
CALL mtr.add_suppression("needs to open also some .ibd files if the file-per-table storage model is used. Current open files .*, max allowed open files 1.");
CALL mtr.add_suppression("Too many (.*) files stay open while the maximum allowed value would be 1. You may need to raise the value of innodb_open_files in my.cnf.");

if (`select $PS_PROTOCOL != 0`)
{
   --skip Test requires: ps-protocol disabled
}



echo '#________________________VAR_05_table_open_cache__________________#'
echo '##'
--echo '#---------------------WL6372_VAR_5_01----------------------#'
####################################################################
#   Checking default value                                         #
####################################################################
SELECT COUNT(@@GLOBAL.table_open_cache);
--echo 1 Expected

SELECT IF(@@open_files_limit < 5000, 2000, @@GLOBAL.table_open_cache);
--echo 2000 Expected


--echo '#---------------------WL6372_VAR_5_02----------------------#'
#################################################################################
# Checking the Default value post starting the server with other value          #
#################################################################################
--echo # Restart server with table_open_cache 1

let $restart_file= $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
--exec echo "wait" > $restart_file
--shutdown_server 
--source include/wait_until_disconnected.inc
-- exec echo "restart:--table_open_cache=1  " > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
-- enable_reconnect
-- source include/wait_until_connected_again.inc

SELECT @@GLOBAL.table_open_cache;
--echo 1 Expected

SET @@GLOBAL.table_open_cache=DEFAULT;
SELECT @@GLOBAL.table_open_cache;
--echo 2000 Expected


--echo '#---------------------WL6372_VAR_5_03----------------------#'
####################################################################
#   Checking Value can be set - Dynamic                            #
####################################################################

--error ER_GLOBAL_VARIABLE
SET @@local.table_open_cache=1;
--echo Expected error 'Global variable'

--error ER_GLOBAL_VARIABLE
SET @@session.table_open_cache=1;
--echo Expected error 'Global variable'

SET @@GLOBAL.table_open_cache=1;
SET @@GLOBAL.table_open_cache=DEFAULT;


SELECT @@GLOBAL.table_open_cache;
--echo 2000 Expected

--echo '#---------------------WL6372_VAR_5_04----------------------#'
#################################################################
# Check if the value in GLOBAL Table matches value in variable  #
#################################################################
--disable_warnings
SELECT @@GLOBAL.table_open_cache = VARIABLE_VALUE
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
WHERE VARIABLE_NAME='table_open_cache';
--echo 1 Expected

SELECT COUNT(@@GLOBAL.table_open_cache);
--echo 1 Expected

SELECT COUNT(VARIABLE_VALUE)
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES 
WHERE VARIABLE_NAME='table_open_cache';
--enable_warnings
--echo 1 Expected



--echo '#---------------------WL6372_VAR_5_05----------------------#'
################################################################################
#  Checking Variable Scope                                                     #
################################################################################
SELECT @@table_open_cache = @@GLOBAL.table_open_cache;
--echo 1 Expected

--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
SELECT COUNT(@@local.table_open_cache);
--echo Expected error 'Variable is a GLOBAL variable'

--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
SELECT COUNT(@@SESSION.table_open_cache);
--echo Expected error 'Variable is a GLOBAL variable'

SELECT COUNT(@@GLOBAL.table_open_cache);
--echo 1 Expected

--Error ER_BAD_FIELD_ERROR
SELECT table_open_cache = @@SESSION.table_open_cache;
--echo Expected error 'Unknown column table_open_cache in field list'



--echo '#---------------------WL6372_VAR_5_06----------------------#'
###############################################################################
# Checking the /Var  directory size                                           #
###############################################################################
-- source include/vardir_size_check.inc
--echo TRUE Expected

--echo '#---------------------WL6372_VAR_5_07----------------------#'
#################################################################################
# Checking the size of table cache functionality                                #
#################################################################################
--echo # create 3 tables and insert 1 row each
--disable_warnings
DROP TABLE IF EXISTS tab1;
DROP TABLE IF EXISTS tab2;
DROP TABLE IF EXISTS tab3;
--enable_warnings

let $i = 1;

let $table = tab1;
--source include/create_table.inc
--source include/Load_data.inc

let $table = tab2;
--source include/create_table.inc
--source include/Load_data.inc

let $table = tab3;
--source include/create_table.inc
--source include/Load_data.inc
flush tables;
flush status;
set @@GLOBAL.table_open_cache=2;
--echo # open two tables

select 1 from tab1;
--echo 1 Expected

select 1 from tab2;
--echo 1 Expected

--disable_warnings
set @opened_tables = (select variable_value from information_schema.session_status where variable_name ='Opened_tables');
set @open_cache_hits = (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_hits');
set @open_cache_miss = (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_misses');
set @open_cache_overflow = (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_overflows');
--enable_warnings

--echo # table_open_cache hit 1
select 1 from tab1;
--echo 1 Expected

--echo # table_open_cache hit 2
select 1 from tab2;
--echo 1 Expected

--disable_warnings
select (select variable_value from information_schema.session_status where variable_name ='Opened_tables') = @opened_tables;
--echo 1 Expected
select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_hits') = @open_cache_hits + 2;
--echo 1 Expected
select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_misses') = @open_cache_miss;
--echo 1 Expected
select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_overflows') = @open_cache_overflow;
--enable_warnings
--echo 1 Expected

--echo # open third table
select 1 from tab3;
--echo 1 Expected

--disable_warnings
select (select variable_value from information_schema.session_status where variable_name ='Opened_tables') = @opened_tables + 1;
--echo 1 Expected
select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_hits') = @open_cache_hits + 2;
--echo 1 Expected
select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_misses') = @open_cache_miss + 1;
--echo 1 Expected
select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_overflows') = @open_cache_overflow + 1;
--enable_warnings
--echo 1 Expected

flush status;

--disable_warnings
set @global_opened_tables = (select variable_value from information_schema.global_status where variable_name ='Opened_tables');
set @global_open_cache_hits = (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_hits');
set @global_open_cache_miss = (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_misses');
set @global_open_cache_overflow = (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_overflows');
--enable_warnings


--echo # opening table 2 from another client session
connect (con1,localhost,root,,);

--disable_warnings
set @opened_tables = (select variable_value from information_schema.session_status where variable_name ='Opened_tables');
set @open_cache_hits = (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_hits');
set @open_cache_miss = (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_misses');
set @open_cache_overflow = (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_overflows');
--enable_warnings

select 1 from tab2;
--echo 1 Expected

--disable_warnings
select (select variable_value from information_schema.session_status where variable_name ='Opened_tables') = @opened_tables;
--echo 1 Expected

select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_hits') = @open_cache_hits + 1;
--echo 1 Expected

select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_misses') = @open_cache_miss;
--echo 1 Expected

select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_overflows') = @open_cache_overflow;
--enable_warnings
--echo 1 Expected

flush status;

connection default;

--disable_warnings
select (select variable_value from information_schema.global_status where variable_name ='Opened_tables') = @global_opened_tables;
--echo 1 Expected

select (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_hits') = @global_open_cache_hits + 1;
--echo 1 Expected

select (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_misses') = @global_open_cache_miss;
--echo 1 Expected

select (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_overflows') = @global_open_cache_overflow;
--enable_warnings
--echo 1 Expected


connection con1;

select 1 from tab1;
--echo 1 Expected

--disable_warnings
select (select variable_value from information_schema.session_status where variable_name ='Opened_tables') = @opened_tables + 1;
--echo 1 Expected

select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_hits') = @open_cache_hits;
--echo 1 Expected

select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_misses') = @open_cache_miss + 1;
--echo 1 Expected

select (select variable_value from information_schema.session_status where variable_name ='Table_open_cache_overflows') = @open_cache_overflow + 1;
--enable_warnings

flush status;
connection default;

--disable_warnings
select (select variable_value from information_schema.global_status where variable_name ='Opened_tables') = @global_opened_tables + 1;
--echo 1 Expected

select (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_hits') = @global_open_cache_hits + 1;
--echo 1 Expected

select (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_misses') = @global_open_cache_miss + 1;
--echo 1 Expected

select (select variable_value from information_schema.global_status where variable_name ='Table_open_cache_overflows') = @global_open_cache_overflow + 1;
--enable_warnings
--echo 1 Expected

disconnect con1;

--echo #cleanup
connection default;

DROP TABLE IF EXISTS tab1;
DROP TABLE IF EXISTS tab2;
DROP TABLE IF EXISTS tab3;
set @@GLOBAL.table_open_cache=DEFAULT;


Man Man