--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 --cluster-id=1 --cluster-start-index=1 --cluster-info='127.0.0.1:23200@1'; let PASSWD_FILE=$MYSQL_TMP_DIR/password_file.txt; --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 # Bug #21680457: REDUCE THE NEW PASSWORD PRINTED BY --echo # --INITIALIZE TO A NOTE, NOT A WARNING. --echo # --echo # Run the server with --initialize --exec $MYSQLD $extra_args --initialize --datadir=$DDIR > $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 = ) { if ($row =~ m/.*\[Note\] \[[^]]*\] \[[^]]*\] 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 # reset the password SET PASSWORD=''; 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 # Bug #27675647: INVALID INITIALIZATION COMMAND ALLOWED TO DO TOO MUCH WORK --echo # --echo # Run server with --initialize insecure --error 1 --exec $MYSQLD $extra_args --datadir=$DDIR --initialize insecure > $MYSQLD_LOG 2>&1 --echo # check for unusable directory log message --let $grep_file=$MYSQLD_LOG --let $grep_pattern=The newly created data directory .* by --initialize is unusable. You can remove it. --let $grep_output=boolean --source include/grep_pattern.inc --echo # delete mysqld log remove_file $MYSQLD_LOG; --echo # delete datadir --force-rmdir $DDIR --echo # End of the test for bug #27675647 --echo # --echo # Bug #29594082: INCORRECT AND DANGEROUS ERROR MESSAGE FROM MY-013236 --echo # --echo # Run server with --initialize insecure on an existing empty directory mkdir $DDIR; --error 1 --exec $MYSQLD $extra_args --datadir=$DDIR --initialize insecure > $MYSQLD_LOG 2>&1 --echo # check for unusable existing directory log message --let $grep_file=$MYSQLD_LOG --let $grep_pattern=The designated data directory .* is unusable. You can remove all files that the server added to it. --let $grep_output=boolean --source include/grep_pattern.inc --echo # delete mysqld log remove_file $MYSQLD_LOG; --echo # delete datadir --force-rmdir $DDIR --echo # End of the test for bug #29594082 --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