mirror of
https://github.com/MariaDB/server.git
synced 2025-01-23 23:34:34 +01:00
e438f9f29d
The problem is that relying on the output of the 'ls' command is not portable as its behavior is not the same between systems and it might even not be available at all in (Windows). So I added list_files that relies on the portable mysys library instead. (and also list_files_write_file and list_files_append_file, since the test was using '--exec ls' in that way.)
74 lines
3.3 KiB
PHP
74 lines
3.3 KiB
PHP
################################################################################
|
|
# inc/partition_layout_check1.inc #
|
|
# #
|
|
# Purpose: #
|
|
# Store the SHOW CREATE TABLE output and the list of files belonging to #
|
|
# this table + print this into the protocol #
|
|
# This script is only usefule when sourced within the partitioning tests. #
|
|
# #
|
|
# Attention: The routine inc/partition_layout_check2.inc is very similar #
|
|
# to this one. So if something has to be changed here it #
|
|
# might be necessary to do it also there #
|
|
# #
|
|
#------------------------------------------------------------------------------#
|
|
# Original Author: mleich #
|
|
# Original Date: 2006-03-05 #
|
|
# Change Author: pcrews #
|
|
# Change Date: 2008-04-15 #
|
|
# Change: Added --replace_result to account for Windows' use of '\r' #
|
|
################################################################################
|
|
|
|
if ($no_debug)
|
|
{
|
|
--disable_query_log
|
|
}
|
|
# Clean the table holding the definition of t1
|
|
DELETE FROM t0_definition;
|
|
|
|
# Dump the current definition of the table t1 to tmp1
|
|
# This complicated method - let another mysqltest collect the output - is used
|
|
# because of two reasons
|
|
# - SHOW CREATE TABLE t1 is at least currently most probably more reliable than
|
|
# the corresponding SELECT on the INFORMATION_SCHEMA
|
|
# - SHOW CREATE TABLE .. cannot write its out put into a file like SELECT
|
|
let $show_file= $MYSQLTEST_VARDIR/master-data/test/tmp1;
|
|
--exec echo "SHOW CREATE TABLE t1;" | $MYSQL_TEST > $show_file 2>&1 || true
|
|
|
|
if ($do_file_tests)
|
|
{
|
|
# List the files belonging to the table t1
|
|
let $ls_file= $MYSQLTEST_VARDIR/master-data/test/tmp2;
|
|
--list_files_write_file $ls_file $MYSQLTEST_VARDIR/master-data/test t1*
|
|
--chmod 0644 $ls_file
|
|
if ($with_directories)
|
|
{
|
|
--list_files_append_file $ls_file $MYSQLTEST_VARDIR/mysql-test-data-dir t1*
|
|
--list_files_append_file $ls_file $MYSQLTEST_VARDIR/mysql-test-idx-dir t1*
|
|
}
|
|
eval SET @aux = load_file('$ls_file');
|
|
}
|
|
if (!$do_file_tests)
|
|
{
|
|
SET @aux = '--- not determined ---';
|
|
}
|
|
|
|
# Insert the current definition of the table t1 into t0_definition
|
|
eval INSERT INTO t0_definition SET state = 'old',
|
|
create_command = load_file('$show_file'),
|
|
file_list = @aux;
|
|
|
|
# Print the create table statement into the protocol
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR '\r' ''
|
|
SELECT create_command FROM t0_definition WHERE state = 'old';
|
|
if ($do_file_tests)
|
|
{
|
|
# We stored the list of files, therefore printing the content makes sense
|
|
if ($ls)
|
|
{
|
|
# Print the list of files into the protocol
|
|
eval SELECT REPLACE(@aux,'$MYSQLTEST_VARDIR','\$MYSQLTEST_VARDIR')
|
|
AS "unified filelist"
|
|
FROM t0_definition WHERE state = 'old';
|
|
}
|
|
}
|
|
--enable_query_log
|