mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 07:13:33 +03:00
Backport from 6.0 to 5.1.
Only those sync points are included, which are used in debug_sync.test.
The Debug Sync Facility allows to place synchronization points
in the code:
open_tables(...)
DEBUG_SYNC(thd, "after_open_tables");
lock_tables(...)
When activated, a sync point can
- Send a signal and/or
- Wait for a signal
Nomenclature:
- signal: A value of a global variable that persists
until overwritten by a new signal. The global
variable can also be seen as a "signal post"
or "flag mast". Then the signal is what is
attached to the "signal post" or "flag mast".
- send a signal: Assign the value (the signal) to the global
variable ("set a flag") and broadcast a
global condition to wake those waiting for
a signal.
- wait for a signal: Loop over waiting for the global condition until
the global value matches the wait-for signal.
Please find more information in the top comment in debug_sync.cc
or in the worklog entry.
.bzrignore:
WL#4259 - Debug Sync Facility
Added the symbolic link libmysqld/debug_sync.cc.
CMakeLists.txt:
WL#4259 - Debug Sync Facility
Added definition for ENABLED_DEBUG_SYNC.
configure.in:
WL#4259 - Debug Sync Facility
Added definition for ENABLED_DEBUG_SYNC.
include/my_sys.h:
WL#4259 - Debug Sync Facility
Added definition for the DEBUG_SYNC_C macro.
libmysqld/CMakeLists.txt:
WL#4259 - Debug Sync Facility
Added sql/debug_sync.cc.
libmysqld/Makefile.am:
WL#4259 - Debug Sync Facility
Added sql/debug_sync.cc.
mysql-test/include/have_debug_sync.inc:
WL#4259 - Debug Sync Facility
New include file.
mysql-test/mysql-test-run.pl:
WL#4259 - Debug Sync Facility
Added option --debug_sync_timeout.
mysql-test/r/debug_sync.result:
WL#4259 - Debug Sync Facility
New test result.
mysql-test/r/have_debug_sync.require:
WL#4259 - Debug Sync Facility
New require file.
mysql-test/t/debug_sync.test:
WL#4259 - Debug Sync Facility
New test file.
mysys/my_static.c:
WL#4259 - Debug Sync Facility
Added definition for debug_sync_C_callback_ptr.
mysys/thr_lock.c:
WL#4259 - Debug Sync Facility
Added sync point "wait_for_lock".
sql/CMakeLists.txt:
WL#4259 - Debug Sync Facility
Added debug_sync.cc and debug_sync.h.
sql/Makefile.am:
WL#4259 - Debug Sync Facility
Added debug_sync.cc and debug_sync.h.
sql/debug_sync.cc:
WL#4259 - Debug Sync Facility
New source file.
sql/debug_sync.h:
WL#4259 - Debug Sync Facility
New header file.
sql/mysqld.cc:
WL#4259 - Debug Sync Facility
Added opt_debug_sync_timeout.
Added calls to debug_sync_init() and debug_sync_end().
Fixed a purecov comment (unrelated).
sql/set_var.cc:
WL#4259 - Debug Sync Facility
Added server variable "debug_sync".
sql/set_var.h:
WL#4259 - Debug Sync Facility
Added declaration for server variable "debug_sync".
sql/share/errmsg.txt:
WL#4259 - Debug Sync Facility
Added error messages ER_DEBUG_SYNC_TIMEOUT and ER_DEBUG_SYNC_HIT_LIMIT.
sql/sql_base.cc:
WL#4259 - Debug Sync Facility
Added sync points "after_flush_unlock" and "before_lock_tables_takes_lock".
sql/sql_class.cc:
WL#4259 - Debug Sync Facility
Added initialization for debug_sync_control to THD::THD.
Added calls to debug_sync_init_thread() and debug_sync_end_thread().
sql/sql_class.h:
WL#4259 - Debug Sync Facility
Added element debug_sync_control to THD.
storage/myisam/myisamchk.c:
Fixed a typo in an error message string (unrelated).
421 lines
14 KiB
Plaintext
421 lines
14 KiB
Plaintext
###################### t/debug_sync.test ###############################
|
|
# #
|
|
# Testing of the Debug Sync Facility. #
|
|
# #
|
|
# There is important documentation within sql/debug_sync.cc #
|
|
# #
|
|
# Used objects in this test case: #
|
|
# p0 - synchronization point 0. Non-existent dummy sync point. #
|
|
# s1 - signal 1. #
|
|
# s2 - signal 2. #
|
|
# #
|
|
# Creation: #
|
|
# 2008-02-18 istruewing #
|
|
# #
|
|
########################################################################
|
|
|
|
#
|
|
# We need the Debug Sync Facility.
|
|
#
|
|
--source include/have_debug_sync.inc
|
|
|
|
#
|
|
# We are checking privileges, which the embedded server cannot do.
|
|
#
|
|
--source include/not_embedded.inc
|
|
|
|
#
|
|
# Preparative cleanup.
|
|
#
|
|
--disable_warnings
|
|
SET DEBUG_SYNC= 'RESET';
|
|
DROP TABLE IF EXISTS t1;
|
|
--enable_warnings
|
|
|
|
#
|
|
# Show the special system variable.
|
|
# It shows ON or OFF depending on the command line option --debug-sync.
|
|
# The test case assumes it is ON (command line option present).
|
|
#
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
|
|
#
|
|
# Syntax. Valid forms.
|
|
#
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 EXECUTE 2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 EXECUTE 2';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 EXECUTE 2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 EXECUTE 2';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 EXECUTE 2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 EXECUTE 2';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2';
|
|
SET DEBUG_SYNC='p0 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC='p0 CLEAR';
|
|
SET DEBUG_SYNC='p0 TEST';
|
|
SET DEBUG_SYNC='RESET';
|
|
|
|
#
|
|
# Syntax. Valid forms. Lower case.
|
|
#
|
|
set debug_sync='p0 signal s1 wait_for s2 timeout 6 execute 2 hit_limit 3';
|
|
set debug_sync='p0 signal s1 wait_for s2 timeout 6 execute 2';
|
|
set debug_sync='p0 signal s1 wait_for s2 timeout 6 hit_limit 3';
|
|
set debug_sync='p0 signal s1 wait_for s2 timeout 6';
|
|
set debug_sync='p0 signal s1 wait_for s2 execute 2 hit_limit 3';
|
|
set debug_sync='p0 signal s1 wait_for s2 execute 2';
|
|
set debug_sync='p0 signal s1 wait_for s2 hit_limit 3';
|
|
set debug_sync='p0 signal s1 wait_for s2';
|
|
set debug_sync='p0 signal s1 execute 2 hit_limit 3';
|
|
set debug_sync='p0 signal s1 execute 2';
|
|
set debug_sync='p0 signal s1 hit_limit 3';
|
|
set debug_sync='p0 signal s1';
|
|
set debug_sync='p0 wait_for s2 timeout 6 execute 2 hit_limit 3';
|
|
set debug_sync='p0 wait_for s2 timeout 6 execute 2';
|
|
set debug_sync='p0 wait_for s2 timeout 6 hit_limit 3';
|
|
set debug_sync='p0 wait_for s2 timeout 6';
|
|
set debug_sync='p0 wait_for s2 execute 2 hit_limit 3';
|
|
set debug_sync='p0 wait_for s2 execute 2';
|
|
set debug_sync='p0 wait_for s2 hit_limit 3';
|
|
set debug_sync='p0 wait_for s2';
|
|
set debug_sync='p0 hit_limit 3';
|
|
set debug_sync='p0 clear';
|
|
set debug_sync='p0 test';
|
|
set debug_sync='reset';
|
|
|
|
#
|
|
# Syntax. Valid forms. Line wrap, leading, mid, trailing space.
|
|
#
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6
|
|
EXECUTE 2 HIT_LIMIT 3';
|
|
SET DEBUG_SYNC=' p0 SIGNAL s1 WAIT_FOR s2';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2';
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 ';
|
|
SET DEBUG_SYNC=' p0 SIGNAL s1 WAIT_FOR s2 ';
|
|
SET DEBUG_SYNC=' p0 SIGNAL s1 WAIT_FOR s2 ';
|
|
|
|
#
|
|
# Syntax. Invalid forms.
|
|
#
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC=' ';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TIMEOUT 6 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TIMEOUT 6';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 SIGNAL s1';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 SIGNAL s1 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 SIGNAL s1 TIMEOUT 6 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 SIGNAL s1 TIMEOUT 6';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6 SIGNAL s1 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6 SIGNAL s1';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TIMEOUT 6 WAIT_FOR s2 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TIMEOUT 6 WAIT_FOR s2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 TIMEOUT 6 EXECUTE 2';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 TIMEOUT 6';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 EXECUTE 2 SIGNAL s1 TIMEOUT 6';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TIMEOUT 6 SIGNAL s1';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 EXECUTE 2 TIMEOUT 6 SIGNAL s1';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 CLEAR HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='CLEAR';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 CLEAR p0';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='TEST';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TEST p0';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 RESET';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='RESET p0';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 RESET p0';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL ';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR ';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 EXECUTE ';
|
|
|
|
#
|
|
# Syntax. Invalid keywords used.
|
|
#
|
|
--error ER_UNKNOWN_SYSTEM_VARIABLE
|
|
SET DEBUG_SYNCx='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAx s1 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOx s2 TIMEOUT 6 EXECUTE 2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUx 0 EXECUTE 2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6 EXECUTx 2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 SIGNAL s1 WAIT_FOR s2 TIMEOUT 6 EXECUTE 2 HIT_LIMIx 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 CLEARx';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 TESTx';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='RESETx';
|
|
|
|
#
|
|
# Syntax. Invalid numbers. Decimal only.
|
|
#
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 0x6 EXECUTE 2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 6 EXECUTE 0x2 HIT_LIMIT 3';
|
|
--error ER_PARSE_ERROR
|
|
SET DEBUG_SYNC='p0 WAIT_FOR s2 TIMEOUT 7 EXECUTE 2 HIT_LIMIT 0x3';
|
|
|
|
#
|
|
# Syntax. Invalid value type.
|
|
#
|
|
--error ER_WRONG_TYPE_FOR_VAR
|
|
SET DEBUG_SYNC= 7;
|
|
|
|
#
|
|
# Syntax. DEBUG_SYNC is a SESSION-only variable.
|
|
#
|
|
--error ER_LOCAL_VARIABLE
|
|
SET GLOBAL DEBUG_SYNC= 'p0 CLEAR';
|
|
|
|
#
|
|
# Syntax. The variable value does not need to be a string literal.
|
|
#
|
|
SET @myvar= 'now SIGNAL from_myvar';
|
|
SET DEBUG_SYNC= @myvar;
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
#
|
|
SET DEBUG_SYNC= LEFT('now SIGNAL from_function_cut_here', 24);
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
|
|
#
|
|
# Functional tests.
|
|
#
|
|
# NOTE: There is the special synchronization point 'now'. It is placed
|
|
# immediately after setting of the DEBUG_SYNC variable.
|
|
# So it is executed before the SET statement ends.
|
|
#
|
|
# NOTE: There is only one global signal (say "signal post" or "flag mast").
|
|
# A SIGNAL action writes its signal into it ("sets a flag").
|
|
# The signal persists until explicitly overwritten.
|
|
# To avoid confusion for later tests, it is recommended to clear
|
|
# the signal by signalling "empty" ("setting the 'empty' flag"):
|
|
# SET DEBUG_SYNC= 'now SIGNAL empty';
|
|
# Preferably you can reset the whole facility with:
|
|
# SET DEBUG_SYNC= 'RESET';
|
|
# The signal is then '' (really empty) which connot be done otherwise.
|
|
#
|
|
|
|
#
|
|
# Time out immediately. This gives just a warning.
|
|
#
|
|
SET DEBUG_SYNC= 'now SIGNAL something';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
# Suppress warning number
|
|
--replace_column 2 ####
|
|
SET DEBUG_SYNC= 'now WAIT_FOR nothing TIMEOUT 0';
|
|
#
|
|
# If signal is present already, TIMEOUT 0 does not give a warning.
|
|
#
|
|
SET DEBUG_SYNC= 'now SIGNAL nothing';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'now WAIT_FOR nothing TIMEOUT 0';
|
|
|
|
#
|
|
# EXECUTE 0 is effectively a no-op.
|
|
#
|
|
SET DEBUG_SYNC= 'now SIGNAL something EXECUTE 0';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'now WAIT_FOR anotherthing TIMEOUT 0 EXECUTE 0';
|
|
|
|
#
|
|
# Run into HIT_LIMIT. This gives an error.
|
|
#
|
|
--error ER_DEBUG_SYNC_HIT_LIMIT
|
|
SET DEBUG_SYNC= 'now HIT_LIMIT 1';
|
|
|
|
#
|
|
# Many actions. Watch the array growing and shrinking in the debug trace:
|
|
# egrep 'query:|debug_sync_action:' mysql-test/var/log/master.trace
|
|
#
|
|
SET DEBUG_SYNC= 'RESET';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p1abcd SIGNAL s1 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p2abc SIGNAL s2 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p9abcdef SIGNAL s9 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p4a SIGNAL s4 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p5abcde SIGNAL s5 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p6ab SIGNAL s6 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p7 SIGNAL s7 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p8abcdef SIGNAL s8 EXECUTE 2';
|
|
SET DEBUG_SYNC= 'p3abcdef SIGNAL s3 EXECUTE 2';
|
|
#
|
|
# Execute some actions to show they exist. Each sets a distinct signal.
|
|
#
|
|
SET DEBUG_SYNC= 'p4a TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p1abcd TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p7 TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p9abcdef TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p3abcdef TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
#
|
|
# Clear the actions.
|
|
#
|
|
SET DEBUG_SYNC= 'p1abcd CLEAR';
|
|
SET DEBUG_SYNC= 'p2abc CLEAR';
|
|
SET DEBUG_SYNC= 'p5abcde CLEAR';
|
|
SET DEBUG_SYNC= 'p6ab CLEAR';
|
|
SET DEBUG_SYNC= 'p8abcdef CLEAR';
|
|
SET DEBUG_SYNC= 'p9abcdef CLEAR';
|
|
SET DEBUG_SYNC= 'p3abcdef CLEAR';
|
|
SET DEBUG_SYNC= 'p4a CLEAR';
|
|
SET DEBUG_SYNC= 'p7 CLEAR';
|
|
#
|
|
# Execute some actions to show they have gone.
|
|
#
|
|
SET DEBUG_SYNC= 'p1abcd TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p7 TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
SET DEBUG_SYNC= 'p9abcdef TEST';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
#
|
|
# Now cleanup. Actions are clear already, but signal needs to be cleared.
|
|
#
|
|
SET DEBUG_SYNC= 'RESET';
|
|
SHOW VARIABLES LIKE 'DEBUG_SYNC';
|
|
|
|
#
|
|
# Facility requires SUPER privilege.
|
|
#
|
|
CREATE USER mysqltest_1@localhost;
|
|
GRANT SUPER ON *.* TO mysqltest_1@localhost;
|
|
--echo connection con1, mysqltest_1
|
|
connect (con1,localhost,mysqltest_1,,);
|
|
SET DEBUG_SYNC= 'RESET';
|
|
disconnect con1;
|
|
--echo connection default
|
|
connection default;
|
|
DROP USER mysqltest_1@localhost;
|
|
#
|
|
CREATE USER mysqltest_2@localhost;
|
|
GRANT ALL ON *.* TO mysqltest_2@localhost;
|
|
REVOKE SUPER ON *.* FROM mysqltest_2@localhost;
|
|
--echo connection con1, mysqltest_2
|
|
connect (con1,localhost,mysqltest_2,,);
|
|
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
|
SET DEBUG_SYNC= 'RESET';
|
|
disconnect con1;
|
|
--echo connection default
|
|
connection default;
|
|
DROP USER mysqltest_2@localhost;
|
|
|
|
#
|
|
# Example 1.
|
|
#
|
|
# Preparative cleanup.
|
|
--disable_warnings
|
|
SET DEBUG_SYNC= 'RESET';
|
|
DROP TABLE IF EXISTS t1;
|
|
--enable_warnings
|
|
#
|
|
# Test.
|
|
CREATE TABLE t1 (c1 INT);
|
|
--echo connection con1
|
|
connect (con1,localhost,root,,);
|
|
SET DEBUG_SYNC= 'before_lock_tables_takes_lock
|
|
SIGNAL opened WAIT_FOR flushed';
|
|
send INSERT INTO t1 VALUES(1);
|
|
--echo connection default
|
|
connection default;
|
|
SET DEBUG_SYNC= 'now WAIT_FOR opened';
|
|
SET DEBUG_SYNC= 'after_flush_unlock SIGNAL flushed';
|
|
FLUSH TABLE t1;
|
|
--echo connection con1
|
|
connection con1;
|
|
reap;
|
|
disconnect con1;
|
|
--echo connection default
|
|
connection default;
|
|
DROP TABLE t1;
|
|
|
|
#
|
|
# Example 2.
|
|
#
|
|
# Preparative cleanup.
|
|
--disable_warnings
|
|
SET DEBUG_SYNC= 'RESET';
|
|
DROP TABLE IF EXISTS t1;
|
|
--enable_warnings
|
|
#
|
|
# Test.
|
|
CREATE TABLE t1 (c1 INT);
|
|
LOCK TABLE t1 WRITE;
|
|
--echo connection con1
|
|
connect (con1,localhost,root,,);
|
|
# Retain action after use. First used by general_log.
|
|
SET DEBUG_SYNC= 'wait_for_lock SIGNAL locked EXECUTE 2';
|
|
send INSERT INTO t1 VALUES (1);
|
|
--echo connection default
|
|
connection default;
|
|
# Wait until INSERT waits for lock.
|
|
SET DEBUG_SYNC= 'now WAIT_FOR locked';
|
|
# let INSERT continue.
|
|
UNLOCK TABLES;
|
|
--echo connection con1
|
|
connection con1;
|
|
--echo retrieve INSERT result.
|
|
reap;
|
|
disconnect con1;
|
|
--echo connection default
|
|
connection default;
|
|
DROP TABLE t1;
|
|
|
|
#
|
|
# Cleanup after test case.
|
|
# Otherwise signal would contain 'flushed' here,
|
|
# which could confuse the next test.
|
|
#
|
|
SET DEBUG_SYNC= 'RESET';
|
|
|