config root man

Current Path : /home/usr.opt/mysql57/mysql-test/suite/innodb/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/suite/innodb/t/innodb_page_size_func.test

# Purpose of this test:
#    Check that server and InnoDB behave correct and give the right messages in
#    case it is tried to restart the server with
#    - plain wrong
#    - too small
#    - unsupported between too small and too high
#    - too high
#    - legal but not to the size during first server startup fitting
#    innodb page size. So every restart attempt with such a value
#    has to fail.
#
# This test should pass with calls of mtr and the following assignments
#    --mysqld=--innodb-page-size=4k
#    --mysqld=--innodb-page-size=4096
#    --mysqld=--innodb-page-size=8k
#    --mysqld=--innodb-page-size=8192
#    --mysqld=--innodb-page-size=16k
#    --mysqld=--innodb-page-size=16384
#    <no assignment of innodb-page-size at all>
#
# The current test is placed within the suite "innodb" though many tests for
# system variables are stored within the suite "sys_vars". The reason is the
# following:
#    The test is adjusted to be used with different legal innodb page sizes
#    assigned on command line.
#    Our current test collections run the test suite
#    - sys_vars   without assignment of innodb-page-size
#    - innodb     with several different assignments of innodb-page-size
#    Therefore placing this test within the suite "innodb" is better.
#
# Created: 2011-11-11 mleich
#

# Set this variable to
# -   0 for standard test runs (file with expected results is made for such).
# -   1 for debugging.(a result difference will show up)
let $test_debug= 0;

--echo # 0. Check and generate prerequites
#-----------------------------------------
--source include/not_embedded.inc
--source include/have_innodb.inc

# InnoDb page size values in 2011-11
# - supported: 4k, 8k, 16k
# - default:  16k
let $minimal_page_size=  4096;
let $default_page_size= 16384;
--disable_warnings
let $maximal_page_size= 65536;
let $legal_page_size_list= $minimal_page_size,8192,16384,32768,$maximal_page_size;
let $start_page_size=
`SELECT variable_value FROM INFORMATION_SCHEMA.GLOBAL_STATUS
WHERE LOWER(variable_name) = 'innodb_page_size'`;
--enable_warnings
if(`SELECT $start_page_size NOT IN ($legal_page_size_list)`)
{
   --echo # ERROR: The current innodb page size ($start_page_size) is not in
   --echo #        the list of expected legal page sizes : $legal_page_size_list
   --echo #        abort
   exit;
}
let $other_page_size= $minimal_page_size;
if($start_page_size == $minimal_page_size)
{
   let $other_page_size= $maximal_page_size;
}
let $other_page_size_k=    `SELECT $other_page_size DIV 1024`;
let $other_page_size_nk=       `SELECT CONCAT($other_page_size_k,'k')`;
let $other_page_size_nkaramel= `SELECT CONCAT($other_page_size_k,'karamel')`;
let $other_page_size_ncaramel= `SELECT CONCAT($other_page_size_k,'caramel')`;
if ($start_page_size < $maximal_page_size)
{
   let $out_range_page_size= `SELECT $maximal_page_size * 4`;
   let $adjust_page_size = $maximal_page_size;
}
if ($start_page_size > $minimal_page_size)
{
   let $out_range_page_size= `SELECT $minimal_page_size DIV 2`;
   let $adjust_page_size = $minimal_page_size;
}
let $illegal_pagesize= `SELECT $minimal_page_size + 1`;
let $zero_test= 1;
if ($start_page_size == $minimal_page_size)
{
   let $zero_test= 0;
}
if ($test_debug)
{
   --echo # --- Set in test script --------------------------
   --echo # minimal_page_size :        $minimal_page_size
   --echo # default_page_size :        $default_page_size
   --echo # maximal_page_size :        $maximal_page_size
   --echo # legal_page_size_list :     $legal_page_size_list
   --echo # --- Calculated ---------------------------------
   --echo # start_page_size :          $start_page_size
   --echo # other_page_size_k :        $other_page_size_k
   --echo # other_page_size_nk :       $other_page_size_nk
   --echo # other_page_size_nkaramel : $other_page_size_nkaramel
   --echo # other_page_size_ncaramel : $other_page_size_ncaramel
   --echo # out_range_page_size :      $out_range_page_size
   --echo # adjust_page_size :         $adjust_page_size
   --echo # illegal_pagesize :         $illegal_pagesize
   --echo # zero_test :                $zero_test
}

# We let our server restart attempts write to the file $error_log.
let $error_log= $MYSQLTEST_VARDIR/log/my_restart.err;
# $error_log has to be processed by include/search_pattern_in_file.inc which
# contains Perl code requiring that the environment variable SEARCH_FILE points
# to this file.
let SEARCH_FILE= $error_log;

--source include/shutdown_mysqld.inc

let $mysqld=$MYSQLD_CMD --core-file --console > $error_log 2>&1 --innodb-page-size;

--echo # 1. Try to restart the server with some other legal innodb page size value.
--echo #    It must fail because we had a different value before.
#----------------------------------------------------------------------------------
--echo # 1.1 The value assigned is a number.
# Detailed explanations of what happens are placed nearby the checks.
--error 1,42
--exec $mysqld=$other_page_size
if ( $default_page_size != $other_page_size )
{
   # It gets detected that the assigned page size is not the default one
   let SEARCH_PATTERN= InnoDB: innodb-page-size has been changed from the default value $default_page_size to $other_page_size;
   --source include/search_pattern_in_file.inc
}
let SEARCH_PATTERN=Data file '.*ibdata1' uses page size $start_page_size, but the innodb_page_size start-up parameter is $other_page_size;
--source include/search_pattern_in_file.inc
# The server restart aborts
let SEARCH_PATTERN= \[ERROR\] Aborting;
--source include/search_pattern_in_file.inc
--echo # 1.2 The value assigned is a number followed by 'k'.
--error 1,42
--exec $mysqld=$other_page_size_nk
if ( $default_page_size != $other_page_size )
{
   # It gets detected that the assigned page size is not the default one
   let SEARCH_PATTERN= InnoDB: innodb-page-size has been changed from the default value $default_page_size to $other_page_size;
   --source include/search_pattern_in_file.inc
}

let SEARCH_PATTERN=Data file '.*ibdata1' uses page size $start_page_size, but the innodb_page_size start-up parameter is $other_page_size;
--source include/search_pattern_in_file.inc

# The server restart aborts
let SEARCH_PATTERN= \[ERROR\] Aborting;
--source include/search_pattern_in_file.inc


--echo # 2. Try to restart the server with some innodb page size.which is either
--echo #    bigger than the maximum or smaller than the minimum supported one.
--echo #    It must fail because we had a different value before.
#-------------------------------------------------------------------------------
# Properties of the value:
# 1. not supported
# 2. below the smallest supported one
# The restart attempt has to fail.
--error 1,42
--exec $mysqld=$out_range_page_size
# The innodb page size gets raised to the lowest or biggest legal value.
let SEARCH_PATTERN= \[Warning\] option 'innodb-page-size': unsigned value $out_range_page_size adjusted to $adjust_page_size;
--source include/search_pattern_in_file.inc
if ( $default_page_size != $adjust_page_size )
{
   # It gets detected that the assigned page size is not the default one
   let SEARCH_PATTERN= InnoDB: innodb-page-size has been changed from the default value $default_page_size to $adjust_page_size;
   --source include/search_pattern_in_file.inc
}
# Some checks omitted because they are already in 1.


--echo # 3. Try to restart the server with the plain wrong innodb page size value "garbage".
--echo #    The restart attempt has to
--echo #    - fail in case start of test page size <> the minimal legal page size.
--echo #    - to be successful in case start of test page size = minimal legal page size.
--echo #      In this case we omit the execution of the current sub test!
#-------------------------------------------------------------------------------------------
if ($zero_test)
{
   if ($test_debug)
   {
     --echo # We do not omit the test.
   }
--error 1,42
--exec $mysqld=garbage
# General server properties cause that
# - the plain wrong value "garbage" assigned to innodb page size gets
#   mangled to 0.
# - the 0 which is below the smallest possible page size is adjusted
#   to the smallest possible page size
let SEARCH_PATTERN= \[Warning\] option 'innodb-page-size': unsigned value 0 adjusted to $minimal_page_size;
--source include/search_pattern_in_file.inc
# It gets detected that the innodb page size has been changed.
let SEARCH_PATTERN= InnoDB: innodb-page-size has been changed from the default value $default_page_size to $minimal_page_size;
--source include/search_pattern_in_file.inc
# Some checks omitted because they are already in 1.
}


--echo # 4. Try to restart the server with some illegal innodb page size value
--echo #    being between minimum and maximum legal page size value.
--echo #    The restart attempt has to fail.
#------------------------------------------------------------------------------
# Properties of the value:
# 1. not supported
# 2. between smallest (4k) and biggest (16k) supported one
--error 1
--exec $mysqld=$illegal_pagesize
# InnoDB cannot handle this value.
let SEARCH_PATTERN= \[ERROR\] InnoDB: Invalid page size=$illegal_pagesize;
--source include/search_pattern_in_file.inc
# Some checks omitted because they are already in 1.


--echo # 5. Try to restart the server with wrong innodb page size <number>karamel.
--echo #    <number>k is a legal page size.
#---------------------------------------------------------------------------------
# The restart attempt has to fail.
--error 1,42
--exec $mysqld=$other_page_size_nkaramel
# The plain wrong value "<number>karamel" assigned to innodb page size seems
# to get mangled to "<number>k" which is a legal value.
if ( $default_page_size != $adjust_page_size )
{
   # It gets detected that the assigned page size is not the default one
   let SEARCH_PATTERN= InnoDB: innodb-page-size has been changed from the default value $default_page_size to $other_page_size;
   --source include/search_pattern_in_file.inc
}
# But this change does not fit to the history of the data.
# Some checks omitted because they are already in 1.


--echo # 6. Try to restart the server with the plain wrong innodb page size <number>caramel
--echo #    <number>k is a legal page size.
--echo #    The restart attempt has to
--echo #    - fail in case start of test page size <> the minimal legal page size.
--echo #    - to be successful in case start of test page size = minimal legal page size.
--echo #      In this case we omit the execution of the current sub test!
#------------------------------------------------------------------------------------------
if ($zero_test)
{
   if ($test_debug)
   {
     --echo # We do not omit the test.
   }
--error 1
--exec $mysqld=$other_page_size_ncaramel
# The server dislikes the assigned value.
let SEARCH_PATTERN= Unknown suffix 'c' used for variable 'innodb-page-size' \(value '$other_page_size_ncaramel'\);
--source include/search_pattern_in_file.inc
# The plain wrong value "<number>caramel" assigned to innodb page size gets
# mangled to 0.
let SEARCH_PATTERN= \[Warning\] option 'innodb-page-size': unsigned value 0 adjusted to $minimal_page_size;
--source include/search_pattern_in_file.inc
# Some other layer has also something to tell.
let SEARCH_PATTERN= mysqld.*: Error while setting value '$other_page_size_ncaramel' to 'innodb-page-size';
--source include/search_pattern_in_file.inc
}

--echo # 7. Restart the server and cleanup
#-----------------------------------------
--remove_file $error_log
--source include/start_mysqld.inc

Man Man