You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
274 lines
8.4 KiB
274 lines
8.4 KiB
--source include/big_test.inc
|
|
|
|
|
|
let BASEDIR= `select @@basedir`;
|
|
let DDIR=$MYSQL_TMP_DIR/installdb_test;
|
|
let MYSQLD_LOG=$MYSQL_TMP_DIR/server.log;
|
|
let extra_args=--no-defaults --innodb_dedicated_server=OFF --console --loose-skip-auto_generate_certs --loose-skip-sha256_password_auto_generate_rsa_keys --skip-ssl --basedir=$BASEDIR --lc-messages-dir=$MYSQL_SHAREDIR;
|
|
let BOOTSTRAP_SQL=$MYSQL_TMP_DIR/tiny_bootstrap.sql;
|
|
let PASSWD_FILE=$MYSQL_TMP_DIR/password_file.txt;
|
|
|
|
--echo # Save the count of columns in mysql
|
|
--let $mysql_cnt=`SELECT COUNT(COLUMN_NAME) FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA='mysql'`
|
|
|
|
--echo # shut server down
|
|
--exec echo "wait" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
|
|
--shutdown_server
|
|
--source include/wait_until_disconnected.inc
|
|
--echo # Server is down
|
|
|
|
--echo #
|
|
--echo # Try --initialize
|
|
--echo #
|
|
|
|
--echo # Run the server with --initialize
|
|
--exec $MYSQLD $extra_args --initialize --datadir=$DDIR --log-error-verbosity=1 > $MYSQLD_LOG 2>&1
|
|
|
|
--echo extract the root password
|
|
--perl
|
|
use strict;
|
|
my $log= $ENV{'MYSQLD_LOG'} or die;
|
|
my $passwd_file= $ENV{'PASSWD_FILE'} or die;
|
|
my $FILE;
|
|
open(FILE, "$log") or die;
|
|
while (my $row = <FILE>)
|
|
{
|
|
if ($row =~ m/.*A temporary password is generated for root.localhost: ([^ \n][^ \n]*)/)
|
|
{
|
|
my $passwd=$1;
|
|
print "password found\n";
|
|
my $OUT_FILE;
|
|
open(OUT_FILE, "> $passwd_file");
|
|
print OUT_FILE "delimiter lessprobability;\n";
|
|
print OUT_FILE "let new_pwd=$passwd";
|
|
print OUT_FILE "lessprobability\n";
|
|
print OUT_FILE "--delimiter ;\n";
|
|
close(OUT_FILE);
|
|
}
|
|
}
|
|
close(FILE);
|
|
EOF
|
|
|
|
source $passwd_file;
|
|
|
|
--echo # Restart the server against DDIR
|
|
--exec echo "restart:--datadir=$DDIR " > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
|
|
--enable_reconnect
|
|
--source include/wait_until_connected_again.inc
|
|
|
|
--echo # connect as root
|
|
connect(root_con,localhost,root,$new_pwd,mysql);
|
|
|
|
--echo # must fail due to password expiration
|
|
--error ER_MUST_CHANGE_PASSWORD
|
|
SELECT 1;
|
|
|
|
--echo # reset the password
|
|
SET PASSWORD='';
|
|
|
|
--echo # Check the count of columns in mysql
|
|
--let $cnt=`SELECT COUNT(COLUMN_NAME) FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA='mysql';`
|
|
if ($cnt != $mysql_cnt)
|
|
{
|
|
--echo # Column count doesn't match. mtr=$mysql_cnt server=$cnt
|
|
--echo list columns in I_S.COLUMNS for the mysql db
|
|
SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA='mysql' ORDER BY TABLE_NAME,ORDINAL_POSITION;
|
|
}
|
|
|
|
--echo # check the user account
|
|
SELECT user, host, plugin, LENGTH(authentication_string)
|
|
FROM mysql.user ORDER by user;
|
|
|
|
--echo # Check the sys schema exists with the right object counts
|
|
--echo #
|
|
--echo # If this value differs, also update SYS_PROCEDURE_COUNT within ./client/upgrade/program.cc
|
|
SELECT COUNT(*) FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA = 'sys' AND ROUTINE_TYPE = 'PROCEDURE';
|
|
--echo # If this value differs, also update SYS_FUNCTION_COUNT within ./client/upgrade/program.cc
|
|
SELECT COUNT(*) FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA = 'sys' AND ROUTINE_TYPE = 'FUNCTION';
|
|
--echo # If this value differs, also update SYS_TABLE_COUNT within ./client/upgrade/program.cc
|
|
SELECT COUNT(*) FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'sys' AND TABLE_TYPE = 'BASE TABLE';
|
|
--echo # If this value differs, also update SYS_VIEW_COUNT within ./client/upgrade/program.cc
|
|
SELECT COUNT(*) FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'sys' AND TABLE_TYPE = 'VIEW';
|
|
--echo # If this value differs, also update SYS_TRIGGER_COUNT within ./client/upgrade/program.cc
|
|
SELECT COUNT(*) FROM INFORMATION_SCHEMA.TRIGGERS WHERE TRIGGER_SCHEMA = 'sys';
|
|
|
|
CREATE DATABASE test;
|
|
|
|
--echo # shut server down
|
|
--exec echo "wait" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
|
|
--shutdown_server
|
|
--source include/wait_until_disconnected.inc
|
|
--echo # Server is down
|
|
|
|
--echo # close the test connection
|
|
connection default;
|
|
disconnect root_con;
|
|
|
|
--echo # remove the password file
|
|
remove_file $PASSWD_FILE;
|
|
|
|
--echo # delete mysqld log
|
|
remove_file $MYSQLD_LOG;
|
|
|
|
--echo # delete datadir
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Try --initialize-insecure --init-file
|
|
--echo #
|
|
|
|
--echo # create bootstrap file
|
|
write_file $BOOTSTRAP_SQL;
|
|
CREATE DATABASE test;
|
|
CREATE TABLE mysql.t1(a INT) ENGINE=innodb;
|
|
INSERT INTO mysql.t1 VALUES (1);
|
|
INSERT INTO mysql.t1 VALUES (2);
|
|
EOF
|
|
|
|
--echo # Run the server with --initialize-insecure --init-file
|
|
--exec $MYSQLD $extra_args --initialize-insecure --datadir=$DDIR --init-file=$BOOTSTRAP_SQL > $MYSQLD_LOG 2>&1
|
|
|
|
|
|
--echo # Restart the server against DDIR
|
|
--exec echo "restart:--datadir=$DDIR " > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
|
|
--enable_reconnect
|
|
--source include/wait_until_connected_again.inc
|
|
|
|
--echo # connect as root
|
|
connect(root_con,localhost,root,,mysql);
|
|
|
|
--echo # must pass: no password expiration
|
|
SELECT 1;
|
|
|
|
--echo # Check the count of columns in mysql
|
|
--let $cnt=`SELECT COUNT(COLUMN_NAME) FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA='mysql';`
|
|
--echo # Take out the extra t1 column
|
|
--dec $cnt
|
|
if ($cnt != $mysql_cnt)
|
|
{
|
|
--echo # Column count doesn't match. mtr=$mysql_cnt server=$cnt
|
|
--echo list columns in I_S.COLUMNS for the mysql db
|
|
SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA='mysql' ORDER BY TABLE_NAME,ORDINAL_POSITION;
|
|
}
|
|
|
|
--echo # check the user account
|
|
SELECT user, host, plugin, LENGTH(authentication_string)
|
|
FROM mysql.user ORDER BY user;
|
|
|
|
--echo # check the result of running --init-file
|
|
SELECT a FROM t1 ORDER BY a;
|
|
|
|
--echo # shut server down
|
|
--exec echo "wait" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
|
|
--shutdown_server
|
|
--source include/wait_until_disconnected.inc
|
|
--echo # Server is down
|
|
|
|
--echo # close the test connection
|
|
connection default;
|
|
disconnect root_con;
|
|
|
|
--echo # delete mysqld log
|
|
remove_file $MYSQLD_LOG;
|
|
|
|
--echo # delete bootstrap file
|
|
remove_file $BOOTSTRAP_SQL;
|
|
|
|
--echo # delete datadir
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Try --initialize-insecure --init-file=empty_file for error handling
|
|
--echo #
|
|
|
|
--echo # Run the server with --initialize-insecure --init-file=empty
|
|
--error 1
|
|
--exec $MYSQLD $extra_args --initialize-insecure --datadir=$DDIR --init-file=$NO_SUCH_BOOTSTRAP_SQL > $MYSQLD_LOG 2>&1
|
|
|
|
--echo # delete mysqld log
|
|
remove_file $MYSQLD_LOG;
|
|
|
|
--echo # delete datadir
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Try --initialize-insecure --init-file=relative_path for error handling
|
|
--echo #
|
|
|
|
--echo # Run the server with --initialize-insecure --init-file=haha.sql
|
|
--error 1
|
|
--exec $MYSQLD $extra_args --initialize-insecure --datadir=$DDIR --init-file=haha.sql > $MYSQLD_LOG 2>&1
|
|
|
|
--echo # delete mysqld log
|
|
remove_file $MYSQLD_LOG;
|
|
|
|
--echo # delete datadir
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Bug#22777039 - MYSQLD --INITIALIZE DOES NOT SUPPORT THE KEYRING_FILE_DATA OPTION
|
|
--echo #
|
|
--exec $MYSQLD $extra_args --datadir=$DDIR --initialize --early-plugin-load="keyring_file=$KEYRING_PLUGIN" --keyring_file_data=$MYSQL_TMP_DIR/keyring $KEYRING_PLUGIN_OPT > $MYSQLD_LOG 2>&1
|
|
|
|
--echo # delete mysqld log
|
|
remove_file $MYSQLD_LOG;
|
|
|
|
--echo # delete temp keyring file
|
|
remove_file $MYSQL_TMP_DIR/keyring;
|
|
|
|
--echo # delete datadir
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Bug#29584642 DATABASE INITIALISATION FAILURE WITH INNODB_DEFAULT_ROW_FORMAT=REDUNDANT
|
|
--echo #
|
|
--echo # The database initialization would fail without the fix.
|
|
--exec $MYSQLD $extra_args --datadir=$DDIR --initialize --innodb_default_row_format=redundant > $MYSQLD_LOG 2>&1
|
|
|
|
--echo # delete mysqld log
|
|
remove_file $MYSQLD_LOG;
|
|
|
|
--echo # delete datadir
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Bug#29780434 MYSQLD --INITIALIZE FAILS IF LOST+FOUND FROM FILESYSTEM IS IN DATADIR
|
|
--echo #
|
|
|
|
--echo # Create the data directory and subdirectories.
|
|
--mkdir $DDIR
|
|
--echo # Add a sub-directory in it with a name that is not ignored.
|
|
--mkdir $DDIR/subdir
|
|
--echo # Add a sub-directory in it with a name that is ignored.
|
|
--mkdir $DDIR/lost+found
|
|
--echo # Add a "hidden" sub-directory, starting with '.'.
|
|
--mkdir $DDIR/.hsubdir
|
|
|
|
--echo # Run the server with --initialize. Should fail due to 'subdir'.
|
|
--error 1
|
|
--exec $MYSQLD $extra_args --initialize --datadir=$DDIR > $MYSQLD_LOG 2>&1
|
|
|
|
--echo # Remove the subdirectory which is not accepted, and start the server with --initialize again.
|
|
--force-rmdir $DDIR/subdir
|
|
--exec $MYSQLD $extra_args --initialize --datadir=$DDIR > $MYSQLD_LOG 2>&1
|
|
|
|
--echo # Remove data dir and log file.
|
|
--remove_file $MYSQLD_LOG
|
|
--force-rmdir $DDIR
|
|
|
|
|
|
--echo #
|
|
--echo # Cleanup
|
|
--echo #
|
|
--echo # Restarting the server
|
|
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
|
|
--enable_reconnect
|
|
--source include/wait_until_connected_again.inc
|
|
|