mirror of
https://github.com/MariaDB/server.git
synced 2025-01-21 22:34:18 +01:00
4d57b851a0
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).
420 lines
14 KiB
Text
420 lines
14 KiB
Text
###################### 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';
|
|
|