2017-08-29 10:52:52 +03:00
|
|
|
# ==== Usage ====
|
|
|
|
#
|
2020-08-20 15:32:35 +03:00
|
|
|
# [--let $shutdown_timeout= 60]
|
2017-08-29 10:52:52 +03:00
|
|
|
# [--let $allow_rpl_inited= 1]
|
|
|
|
# --source include/shutdown_mysqld.inc
|
|
|
|
|
|
|
|
# The default value is empty
|
|
|
|
--let $server_shutdown_timeout=
|
|
|
|
|
|
|
|
if ($shutdown_timeout)
|
|
|
|
{
|
|
|
|
--let $server_shutdown_timeout= $shutdown_timeout
|
|
|
|
}
|
|
|
|
|
2015-04-30 10:23:36 -04:00
|
|
|
# This is the first half of include/restart_mysqld.inc.
|
|
|
|
if ($rpl_inited)
|
|
|
|
{
|
|
|
|
if (!$allow_rpl_inited)
|
|
|
|
{
|
|
|
|
--die ERROR IN TEST: When using the replication test framework (master-slave.inc, rpl_init.inc etc), use rpl_restart_server.inc instead of restart_mysqld.inc. If you know what you are doing and you really have to use restart_mysqld.inc, set allow_rpl_inited=1 before you source restart_mysqld.inc
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Write file to make mysql-test-run.pl expect the "crash", but don't start it
|
MDEV-27912 Fixing inconsistency w.r.t. expect files in tests.
mtr uses group suffix, but some existing inc and test files use
server_id for expect files. This patch aims to fix that.
For spider:
With this change we will not have to maintain a separate version of
restart_mysqld.inc for spider, that duplicates code, just because
spider tests use different names for expect files, and shutdown_mysqld
requires magical names for them.
With this change spider tests will also be able to use other features
provided by restart_mysqld.inc without code duplication, like the
parameter $restart_parameters (see e.g. the testcase mdev_29904.test
in commit ef1161e5d4f).
Tests run after this change: default, spider, rocksdb, galera, using
the following command
mtr --parallel=auto --force --max-test-fail=0 --skip-core-file
mtr --suite spider,spider/*,spider/*/* \
--skip-test="spider/oracle.*|.*/t\..*" --parallel=auto --big-test \
--force --max-test-fail=0 --skip-core-file
mtr --suite galera --parallel=auto
mtr --suite rocksdb --parallel=auto
2023-01-18 11:51:28 +11:00
|
|
|
--let $_expect_file_name= `select regexp_replace(@@tmpdir, '^.*/','')`
|
|
|
|
--let $_expect_file_name= $MYSQLTEST_VARDIR/tmp/$_expect_file_name.expect
|
MDEV-16944 Fix file sharing issues on Windows in mysqltest
On Windows systems, occurrences of ERROR_SHARING_VIOLATION due to
conflicting share modes between processes accessing the same file can
result in CreateFile failures.
mysys' my_open() already incorporates a workaround by implementing
wait/retry logic on Windows.
But this does not help if files are opened using shell redirection like
mysqltest traditionally did it, i.e via
--echo exec "some text" > output_file
In such cases, it is cmd.exe, that opens the output_file, and it
won't do any sharing-violation retries.
This commit addresses the issue by introducing a new built-in command,
'write_line', in mysqltest. This new command serves as a brief alternative
to 'write_file', with a single line output, that also resolves variables
like "exec" would.
Internally, this command will use my_open(), and therefore retry-on-error
logic.
Hopefully this will eliminate the very sporadic "can't open file because
it is used by another process" error on CI.
2024-04-15 15:46:50 +02:00
|
|
|
--write_line wait $_expect_file_name
|
2015-04-30 10:23:36 -04:00
|
|
|
|
2019-08-12 15:47:24 +03:00
|
|
|
# Avoid warnings from connection threads that does not have time to exit
|
|
|
|
--disable_query_log
|
|
|
|
set @@global.log_warnings=0;
|
|
|
|
--enable_query_log
|
|
|
|
|
2024-03-27 22:30:29 +01:00
|
|
|
--source include/slow_environ.inc
|
|
|
|
--let $server_shutdown_timeout= 60$_timeout_adjustment
|
2019-08-12 15:47:24 +03:00
|
|
|
|
2017-08-11 18:21:53 +02:00
|
|
|
if ($shutdown_timeout)
|
|
|
|
{
|
|
|
|
--let $server_shutdown_timeout= $shutdown_timeout
|
|
|
|
}
|
|
|
|
if ($shutdown_timeout == 0)
|
|
|
|
{
|
|
|
|
--let $server_shutdown_timeout= 0
|
|
|
|
}
|
|
|
|
|
2015-04-30 10:23:36 -04:00
|
|
|
# Send shutdown to the connected server
|
2017-08-11 18:21:53 +02:00
|
|
|
--shutdown_server $server_shutdown_timeout
|
2015-04-30 10:23:36 -04:00
|
|
|
--source include/wait_until_disconnected.inc
|
|
|
|
|