mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
upmerge 31602,47389,50618
This commit is contained in:
@ -489,6 +489,8 @@ void free_replace();
|
|||||||
void do_get_replace_regex(struct st_command *command);
|
void do_get_replace_regex(struct st_command *command);
|
||||||
void free_replace_regex();
|
void free_replace_regex();
|
||||||
|
|
||||||
|
/* Used by sleep */
|
||||||
|
void check_eol_junk_line(const char *eol);
|
||||||
|
|
||||||
void free_all_replace(){
|
void free_all_replace(){
|
||||||
free_replace();
|
free_replace();
|
||||||
@ -1035,7 +1037,7 @@ void check_command_args(struct st_command *command,
|
|||||||
}
|
}
|
||||||
/* Check for too many arguments passed */
|
/* Check for too many arguments passed */
|
||||||
ptr= command->last_argument;
|
ptr= command->last_argument;
|
||||||
while(ptr <= command->end)
|
while(ptr <= command->end && *ptr != '#')
|
||||||
{
|
{
|
||||||
if (*ptr && *ptr != ' ')
|
if (*ptr && *ptr != ' ')
|
||||||
die("Extra argument '%s' passed to '%.*s'",
|
die("Extra argument '%s' passed to '%.*s'",
|
||||||
@ -4173,10 +4175,19 @@ void do_let(struct st_command *command)
|
|||||||
int do_sleep(struct st_command *command, my_bool real_sleep)
|
int do_sleep(struct st_command *command, my_bool real_sleep)
|
||||||
{
|
{
|
||||||
int error= 0;
|
int error= 0;
|
||||||
char *p= command->first_argument;
|
char *sleep_start, *sleep_end;
|
||||||
char *sleep_start, *sleep_end= command->end;
|
|
||||||
double sleep_val;
|
double sleep_val;
|
||||||
|
char *p;
|
||||||
|
static DYNAMIC_STRING ds_sleep;
|
||||||
|
const struct command_arg sleep_args[] = {
|
||||||
|
{ "sleep_delay", ARG_STRING, TRUE, &ds_sleep, "Number of seconds to sleep." }
|
||||||
|
};
|
||||||
|
check_command_args(command, command->first_argument, sleep_args,
|
||||||
|
sizeof(sleep_args)/sizeof(struct command_arg),
|
||||||
|
' ');
|
||||||
|
|
||||||
|
p= ds_sleep.str;
|
||||||
|
sleep_end= ds_sleep.str + ds_sleep.length;
|
||||||
while (my_isspace(charset_info, *p))
|
while (my_isspace(charset_info, *p))
|
||||||
p++;
|
p++;
|
||||||
if (!*p)
|
if (!*p)
|
||||||
@ -4185,11 +4196,13 @@ int do_sleep(struct st_command *command, my_bool real_sleep)
|
|||||||
/* Check that arg starts with a digit, not handled by my_strtod */
|
/* Check that arg starts with a digit, not handled by my_strtod */
|
||||||
if (!my_isdigit(charset_info, *sleep_start))
|
if (!my_isdigit(charset_info, *sleep_start))
|
||||||
die("Invalid argument to %.*s \"%s\"", command->first_word_len,
|
die("Invalid argument to %.*s \"%s\"", command->first_word_len,
|
||||||
command->query,command->first_argument);
|
command->query, sleep_start);
|
||||||
sleep_val= my_strtod(sleep_start, &sleep_end, &error);
|
sleep_val= my_strtod(sleep_start, &sleep_end, &error);
|
||||||
|
check_eol_junk_line(sleep_end);
|
||||||
if (error)
|
if (error)
|
||||||
die("Invalid argument to %.*s \"%s\"", command->first_word_len,
|
die("Invalid argument to %.*s \"%s\"", command->first_word_len,
|
||||||
command->query, command->first_argument);
|
command->query, command->first_argument);
|
||||||
|
dynstr_free(&ds_sleep);
|
||||||
|
|
||||||
/* Fixed sleep time selected by --sleep option */
|
/* Fixed sleep time selected by --sleep option */
|
||||||
if (opt_sleep >= 0 && !real_sleep)
|
if (opt_sleep >= 0 && !real_sleep)
|
||||||
@ -4198,7 +4211,6 @@ int do_sleep(struct st_command *command, my_bool real_sleep)
|
|||||||
DBUG_PRINT("info", ("sleep_val: %f", sleep_val));
|
DBUG_PRINT("info", ("sleep_val: %f", sleep_val));
|
||||||
if (sleep_val)
|
if (sleep_val)
|
||||||
my_sleep((ulong) (sleep_val * 1000000L));
|
my_sleep((ulong) (sleep_val * 1000000L));
|
||||||
command->last_argument= sleep_end;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -945,6 +945,11 @@ sub command_line_setup {
|
|||||||
|
|
||||||
# Find the absolute path to the test directory
|
# Find the absolute path to the test directory
|
||||||
$glob_mysql_test_dir= cwd();
|
$glob_mysql_test_dir= cwd();
|
||||||
|
if ($glob_mysql_test_dir =~ / /)
|
||||||
|
{
|
||||||
|
die("Working directory \"$glob_mysql_test_dir\" contains space\n".
|
||||||
|
"Bailing out, cannot function properly with space in path");
|
||||||
|
}
|
||||||
if (IS_CYGWIN)
|
if (IS_CYGWIN)
|
||||||
{
|
{
|
||||||
# Use mixed path format i.e c:/path/to/
|
# Use mixed path format i.e c:/path/to/
|
||||||
@ -1481,6 +1486,12 @@ sub collect_mysqld_features {
|
|||||||
mtr_add_arg($args, "--verbose");
|
mtr_add_arg($args, "--verbose");
|
||||||
mtr_add_arg($args, "--help");
|
mtr_add_arg($args, "--help");
|
||||||
|
|
||||||
|
# Need --user=root if running as *nix root user
|
||||||
|
if (!IS_WINDOWS and $> == 0)
|
||||||
|
{
|
||||||
|
mtr_add_arg($args, "--user=root");
|
||||||
|
}
|
||||||
|
|
||||||
my $exe_mysqld= find_mysqld($basedir);
|
my $exe_mysqld= find_mysqld($basedir);
|
||||||
my $cmd= join(" ", $exe_mysqld, @$args);
|
my $cmd= join(" ", $exe_mysqld, @$args);
|
||||||
my $list= `$cmd`;
|
my $list= `$cmd`;
|
||||||
|
@ -147,9 +147,10 @@ hello
|
|||||||
hello
|
hello
|
||||||
;;;;;;;;
|
;;;;;;;;
|
||||||
# MySQL: -- The
|
# MySQL: -- The
|
||||||
mysqltest: At line 1: End of line junk detected: "6"
|
mysqltest: At line 1: Extra argument '6' passed to 'sleep'
|
||||||
mysqltest: At line 1: End of line junk detected: "6"
|
mysqltest: At line 1: Extra argument '6' passed to 'sleep'
|
||||||
mysqltest: At line 1: Missing delimiter
|
mysqltest: At line 1: Extra argument 'A comment
|
||||||
|
show status' passed to 'sleep'
|
||||||
mysqltest: At line 1: End of line junk detected: "sleep 7
|
mysqltest: At line 1: End of line junk detected: "sleep 7
|
||||||
# Another comment
|
# Another comment
|
||||||
"
|
"
|
||||||
@ -354,8 +355,10 @@ here is the sourced script
|
|||||||
here is the sourced script
|
here is the sourced script
|
||||||
"hello"
|
"hello"
|
||||||
"hello"
|
"hello"
|
||||||
mysqltest: At line 1: Missing argument to sleep
|
mysqltest: At line 2: Invalid argument to sleep "xyz"
|
||||||
mysqltest: At line 1: Missing argument to real_sleep
|
mysqltest: At line 2: Invalid argument to real_sleep "xyz"
|
||||||
|
mysqltest: At line 1: Missing required argument 'sleep_delay' to command 'sleep'
|
||||||
|
mysqltest: At line 1: Missing required argument 'sleep_delay' to command 'real_sleep'
|
||||||
mysqltest: At line 1: Invalid argument to sleep "abc"
|
mysqltest: At line 1: Invalid argument to sleep "abc"
|
||||||
mysqltest: At line 1: Invalid argument to real_sleep "abc"
|
mysqltest: At line 1: Invalid argument to real_sleep "abc"
|
||||||
1
|
1
|
||||||
|
@ -920,6 +920,28 @@ sleep 0.5;
|
|||||||
sleep 1;
|
sleep 1;
|
||||||
real_sleep 1;
|
real_sleep 1;
|
||||||
|
|
||||||
|
# Parameter from variable, legal and illegal
|
||||||
|
let $sleep_var= 0.1;
|
||||||
|
sleep $sleep_var;
|
||||||
|
let $sleep_var= 1;
|
||||||
|
--real_sleep $sleep_var
|
||||||
|
|
||||||
|
--write_file $MYSQL_TMP_DIR/sleep.inc
|
||||||
|
let $sleep_var= xyz;
|
||||||
|
--sleep $sleep_var
|
||||||
|
EOF
|
||||||
|
--error 1
|
||||||
|
--exec $MYSQL_TEST < $MYSQL_TMP_DIR/sleep.inc 2>&1
|
||||||
|
--remove_file $MYSQL_TMP_DIR/sleep.inc
|
||||||
|
|
||||||
|
--write_file $MYSQL_TMP_DIR/sleep.inc
|
||||||
|
let $sleep_var= xyz;
|
||||||
|
real_sleep $sleep_var;
|
||||||
|
EOF
|
||||||
|
--error 1
|
||||||
|
--exec $MYSQL_TEST < $MYSQL_TMP_DIR/sleep.inc 2>&1
|
||||||
|
--remove_file $MYSQL_TMP_DIR/sleep.inc
|
||||||
|
|
||||||
# Missing parameter
|
# Missing parameter
|
||||||
--error 1
|
--error 1
|
||||||
--exec echo "sleep ;" | $MYSQL_TEST 2>&1
|
--exec echo "sleep ;" | $MYSQL_TEST 2>&1
|
||||||
|
Reference in New Issue
Block a user