1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
--source include/have_log_bin.inc
--source include/not_windows.inc
-- source include/mysqlbinlog_raw_mode.inc
# Test --stop-never
# If exit code is good or bad then entry in raw_mode_exit table will be created
# Anything above exit code 1 is bad. We wait for this
CREATE TABLE raw_mode_exit (exit_code INT);
# Now jump some loops to have mysqlbinlog executed in the background
--write_file $MYSQL_TMP_DIR/mbl.sh
#!/bin/bash
(`$MYSQL_BINLOG --raw --read-from-remote-server --stop-never --user=root --host=127.0.0.1 --port=$MASTER_MYPORT --result-file=$MYSQL_TMP_DIR/ master-bin.000001 ; [ $? -le 1 ]` && $MYSQL -e "use test; INSERT INTO raw_mode_exit VALUES (1);") < /dev/null > /dev/null 2>&1 &
EOF
--chmod 0755 $MYSQL_TMP_DIR/mbl.sh
--exec $MYSQL_TMP_DIR/mbl.sh
let $wait_condition= SELECT id from information_schema.processlist where processlist.command like '%Binlog%' and state like '%Master has sent%';
--source include/wait_condition.inc
# Wait until creating binlog files by mysqlbinlog
--perl
$timeout= 30;
$binlog= $ENV{'MYSQL_TMP_DIR'} . '/master-bin.000003';
$binlog_exists= 0;
while ($timeout > 0 && $binlog_exists == 0)
{
if (-e $binlog)
{
$binlog_exists= 1;
}
sleep 1;
$timeout--;
}
if ($timeout == 0 && $binlog_exists == 0)
{
print "Timeout reached but binlog file $binlog was not created";
}
EOF
--diff_files $MYSQL_TMP_DIR/master-bin.000001 $MYSQLD_DATADIR/master-bin.000001
--diff_files $MYSQL_TMP_DIR/master-bin.000002 $MYSQLD_DATADIR/master-bin.000002
SELECT ((@id := id) - id) from information_schema.processlist where processlist.command like '%Binlog%' and state like '%Master has sent%';
# Test killing from mysql server
kill @id;
--let $wait_condition= SELECT count(*) = 1 FROM raw_mode_exit WHERE exit_code = 1;
--source include/wait_condition.inc
DROP TABLE raw_mode_exit;
--remove_file $MYSQL_TMP_DIR/master-bin.000001
--remove_file $MYSQL_TMP_DIR/master-bin.000002
--remove_file $MYSQL_TMP_DIR/master-bin.000003
--remove_file $MYSQL_TMP_DIR/mbl.sh
--echo End of tests
|