config root man

Current Path : /usr/opt/mysql57/mysql-test/r/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : //usr/opt/mysql57/mysql-test/r/user_lock.result

#
# Coverage for GET_LOCK, RELEASE_LOCK, RELEASE_ALL_LOCKS,
# IS_USED_LOCK and IS_FREE_LOCK functions.
#
# Tests for WL#1159 "Allow multiple locks in GET_LOCK()".
#
# FT-1: The current connection has no user-level lock aquired at all.
#       There is no parallel connection holding the lock 'test'.
# FT-1.1: IS_USED_LOCK returns NULL if the lock is unused.
SELECT IS_USED_LOCK('test') IS NULL AS expect_1;
expect_1
1
# FT-1.2: IS_FREE_LOCK returns 1 if the lock is unused.
SELECT IS_FREE_LOCK('test') = 1 AS expect_1;
expect_1
1
# FT-1.3: RELEASE_LOCK returns NULL when none of the existing connections
#         holds the lock 'test'.
SELECT RELEASE_LOCK('test') IS NULL AS expect_1;
expect_1
1
# FT-1.4: RELEASE_ALL_LOCKS returns the number of own locks freed.
#         This is 0 because the connection had no locks acquired.
SELECT RELEASE_ALL_LOCKS() = 0 AS expect_1;
expect_1
1
# FT-2: The current connection has success in aquiring a user level lock.
# FT-2.1: GET_LOCK returns 1 if it manages to acquire a lock.
SELECT GET_LOCK('test', 0) = 1 AS expect_1;
expect_1
1
# FT-2.2: IS_USED_LOCK returns our connection id because its our lock.
SELECT IS_USED_LOCK('test') = CONNECTION_ID() AS expect_1;
expect_1
1
# FT-2.3: IS_FREE_LOCK returns 0 because the lock is held by our connection.
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
connect  con1,localhost,root,,;
connection con1;
# FT-3: Another connection holds a user-level lock.
# FT-3.1: IS_USED_LOCK returns the id of the other connection default
#         which holds that lock. The result fits to FT-2.2.
SET @aux = <default_id>;
SELECT IS_USED_LOCK('test') = @aux AS expect_1;
expect_1
1
# FT-3.2: IS_FREE_LOCK returns 0 because the lock is held by the other
#         connection default.
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
# FT-3.3: GET_LOCK returns 0 if it can't acquire a lock (wait timeout).
SELECT GET_LOCK('test', 0) = 0 expect_1;
expect_1
1
# FT-3.4: RELEASE_LOCK returns 0 if the lock belongs to another connection.
SELECT RELEASE_LOCK('test') = 0 AS expect_1;
expect_1
1
# FT-3.5: RELEASE_ALL_LOCKS returns the number of own locks freed.
#         This is 0 because the connection had no locks acquired and
#         we also cannot free locks held by others.
SELECT RELEASE_ALL_LOCKS() = 0 AS expect_1;
expect_1
1
connection default;
# FT-4.1: RELEASE_LOCK returns 1 if it successfully releases a lock.
SELECT RELEASE_LOCK('test') = 1 AS expect_1;
expect_1
1
# FT-4.2: RELEASE_LOCK returns NULL if it doesn't release a lock and
#         and there is no such lock. It also does not matter that we
#         held that lock somewhere before.
SELECT RELEASE_LOCK('test') IS NULL;
RELEASE_LOCK('test') IS NULL
1
# FT-5: A connection can hold multiple user-level locks.
# FT-5.1: Several statements aquiring one lock per statement. 
SELECT GET_LOCK('test1',0);
GET_LOCK('test1',0)
1
SELECT GET_LOCK('test2',0);
GET_LOCK('test2',0)
1
#         The connection holds two locks.
SELECT IS_USED_LOCK('test1') = CONNECTION_ID()
AND IS_USED_LOCK('test2') = CONNECTION_ID() AS expect_1;
expect_1
1
# FT-5.2: RELEASE_LOCK() frees the assigned user level lock only.
SELECT RELEASE_LOCK('test1') = 1 AS expect_1;
expect_1
1
SELECT IS_FREE_LOCK('test1') = 1 AS expect_1;
expect_1
1
SELECT IS_FREE_LOCK('test2') = 0 AS expect_1;
expect_1
1
SELECT RELEASE_LOCK('test2') = 1 AS expect_1;
expect_1
1
# FT-5.3: RELEASE_ALL_LOCKS frees all locks all at once
#         and returns the number of locks freed.
SELECT GET_LOCK('test1',0);
GET_LOCK('test1',0)
1
SELECT GET_LOCK('test2',0);
GET_LOCK('test2',0)
1
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
SELECT IS_FREE_LOCK('test1') AND IS_FREE_LOCK('test2') AS expect_1;
expect_1
1
# FT-5.4: One statement aquiring more than one lock works the same way.
# FT-5.4.1: More than one result expression with GET_LOCK, one row.
SELECT GET_LOCK('test1',0), GET_LOCK('test2',0);
GET_LOCK('test1',0)	GET_LOCK('test2',0)
1	1
#         The connections holds two locks.
SELECT IS_USED_LOCK('test1') = CONNECTION_ID()
AND IS_USED_LOCK('test2') = CONNECTION_ID() AS expect_1;
expect_1
1
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
SELECT IS_USED_LOCK('test1') IS NULL AND IS_USED_LOCK('test2') IS NULL AS expect_1;
expect_1
1
# FT-5.4.2: More than one time GET_LOCK somewhere, one row.
SELECT GET_LOCK('test1',0) FROM (SELECT 1 AS col1) AS my_tab
WHERE GET_LOCK('test2',0) = 1;
GET_LOCK('test1',0)
1
SELECT IS_USED_LOCK('test1') = CONNECTION_ID()
AND IS_USED_LOCK('test2') = CONNECTION_ID() AS expect_1;
expect_1
1
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
SELECT IS_USED_LOCK('test1') IS NULL AND IS_USED_LOCK('test2') IS NULL AS expect_1;
expect_1
1
# FT-5.4.3: One result expression with GET_LOCK, more than one result row.
SELECT GET_LOCK(col1,0) FROM (SELECT 'test1' AS col1 UNION SELECT 'test2') AS my_tab;
GET_LOCK(col1,0)
1
1
SELECT IS_USED_LOCK('test1') = CONNECTION_ID()
AND IS_USED_LOCK('test2') = CONNECTION_ID() AS expect_1;
expect_1
1
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
SELECT IS_USED_LOCK('test1') IS NULL AND IS_USED_LOCK('test2') IS NULL AS expect_1;
expect_1
1
# FT-6: A connection can hold multiple user-level locks with same name.
# FT-6.1: GET_LOCK() and RELEASE_LOCK() work recursively.
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
#         Once the last instance of the lock is released,
#         the next call returns NULL.
SELECT RELEASE_LOCK('test') IS NULL AS expect_1;
expect_1
1
# FT-6.2: Counting in RELEASE_ALL_LOCKS() for recursive locks is correct.
SELECT GET_LOCK('test', 0), GET_LOCK('test', 0);
GET_LOCK('test', 0)	GET_LOCK('test', 0)
1	1
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
# FT-7: Check a statement with GET_LOCK() getting killed.
# FT-7.1: KILL arrives when waiting for the user lock
#         The statement must return ER_QUERY_INTERRUPTED.
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
connection con1;
# Send statement and reap result later.
SELECT GET_LOCK('test', 7200);
connection default;
SET @aux = <con1_id>;
KILL QUERY @aux;
connection con1;
# Reap result of "SELECT GET_LOCK('test', 7200)".
ERROR 70100: Query execution was interrupted
# Check that Connection con1 sees the right state.
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
SELECT IS_USED_LOCK('test') <> CONNECTION_ID() AS expect_1;
expect_1
1
connection default;
SELECT RELEASE_LOCK('test') = 1 AS expect_1;
expect_1
1
# FT-7.2: The lock is not held by some other connection.
#         KILL arrives during the SLEEP phase after the lock is taken.
connection con1;
# Send statement and reap result later.
SELECT GET_LOCK('test', 7200), SLEEP(10);
connection default;
SET @aux = <con1_id>;
KILL QUERY @aux;
# Connection con1 has got the lock.
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
connection con1;
# Reap result of "SELECT GET_LOCK('test', 7200), SLEEP(10)".
# We intentionally do not print the result.
# If a statement killed in the 'user sleep' phase harvests finally
# success or ER_QUERY_INTERRUPTED is NOT in the scope of current check.
# The essential is that the connection con1 has got that lock.
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
SELECT IS_USED_LOCK('test') = CONNECTION_ID() AS expect_1;
expect_1
1
connection default;
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
connection con1;
SELECT RELEASE_LOCK('test') = 1 AS expect_1;
expect_1
1
# FT-8: Check that user locks disappear if the session is killed.
connection con1;
SELECT GET_LOCK('test1', 0);
GET_LOCK('test1', 0)
1
SELECT GET_LOCK('test1', 0);
GET_LOCK('test1', 0)
1
connection default;
SELECT IS_FREE_LOCK('test1') = 0 AS expect_1;
expect_1
1
SET @aux = <con1_id>;
KILL @aux;
SELECT IS_FREE_LOCK('test1') = 1 AS expect_1;
expect_1
1
connection con1;
disconnect con1;
connect  con1,localhost,root,,;
# FT-9: Check that Deadlocks are detected e.g. in case of a mutual wait.
connection default;
SELECT GET_LOCK('test1', 0);
GET_LOCK('test1', 0)
1
connection con1;
SELECT GET_LOCK('test2', 0);
GET_LOCK('test2', 0)
1
# Send statement and reap result later.
SELECT GET_LOCK('test1', 7200);
connection default;
SELECT GET_LOCK('test2', 7200);
ERROR HY000: Deadlock found when trying to get user-level lock; try rolling back transaction/releasing locks and restarting lock acquisition.
SELECT RELEASE_LOCK('test1');
RELEASE_LOCK('test1')
1
connection con1;
# Reap result of "SELECT GET_LOCK('test1', 7200)".
GET_LOCK('test1', 7200)
1
#       Two RELEASE_LOCK in one statement must work too.
SELECT RELEASE_LOCK('test2') + RELEASE_LOCK('test1') = 2 AS expect_1;
expect_1
1
# FT-10: Non user lock related locking/unlocking does not free
#        user locks.
# FT-10.1: LOCK/UNLOCK TABLES
connection default;
CREATE TABLE t1 (id INT);
SELECT GET_LOCK('test1', 0);
GET_LOCK('test1', 0)
1
LOCK TABLE t1 WRITE;
SELECT GET_LOCK('test2', 0);
GET_LOCK('test2', 0)
1
UNLOCK TABLES;
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
# FT-10.2: GLOBAL READ LOCK
SELECT GET_LOCK('test1', 0);
GET_LOCK('test1', 0)
1
FLUSH TABLES WITH READ LOCK;
SELECT GET_LOCK('test2', 0);
GET_LOCK('test2', 0)
1
UNLOCK TABLES;
SELECT (RELEASE_LOCK('test1') = 1) AND (RELEASE_LOCK('test3') IS NULL)
AND (RELEASE_LOCK('test2') = 1) AS expect_1;
expect_1
1
# FT-10.3: BEGIN/COMMIT/ROLLBACK don't unlock user locks.
DELETE FROM t1;
BEGIN;
INSERT INTO t1 SET id = 1;
SELECT GET_LOCK('test1', 0);
GET_LOCK('test1', 0)
1
COMMIT;
BEGIN;
INSERT INTO t1 SET id = 2;
SELECT GET_LOCK('test2', 0);
GET_LOCK('test2', 0)
1
ROLLBACK;
SELECT RELEASE_ALL_LOCKS() = 2 AS expect_1;
expect_1
1
SELECT id FROM t1 ORDER BY id;
id
1
DELETE FROM t1;
# FT-11: Deadlocks between user locks and other metadata locks
#        are correctly detected.
#
# FT-11.1: Waits for user-level locks are preferred as victim over DDL.
#          Without any user locks : "default" waits till "con1" COMMITs.
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
connection con1;
BEGIN;
INSERT INTO t1 VALUES (1);
# Send statement and reap result later.
SELECT GET_LOCK('test', 7200);
connection default;
# Send statement and reap result later.
RENAME TABLE t1 TO t2;
connection con1;
# Reap result of "SELECT GET_LOCK('test', 7200)".
ERROR HY000: Deadlock found when trying to get user-level lock; try rolling back transaction/releasing locks and restarting lock acquisition.
#          When user-level lock wait is aborted due to deadlock the
#          transaction is not rolled back.
COMMIT;
connection default;
# Reap result of "RENAME TABLE t1 TO t2".
RENAME TABLE t2 TO t1;
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
connection con1;
#          The row inserted in the committed transaction must exist.
SELECT COUNT(*) = 1 AS expect_1 FROM t1 WHERE id = 1;
expect_1
1
connection default;
# FT-11.2: Waits for DML locks are preferred as victim over waits for
#          user-level locks.
#          Without any user locks : "default" waits till MDL lock timout kicks in.
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
connection con1;
LOCK TABLE t1 WRITE;
# Send statement and reap result later.
SELECT GET_LOCK('test', 7200);
connection default;
SELECT COUNT(*) FROM t1;
ERROR 40001: Deadlock found when trying to get lock; try restarting transaction
#          User-level lock is not released even though transaction/statement
#          is rolled back in this case.
SELECT RELEASE_LOCK('test') = 1 AS expect_1;
expect_1
1
connection con1;
# Reap result of "SELECT GET_LOCK('test', 7200)".
GET_LOCK('test', 7200)
1
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
UNLOCK TABLES;
# FT-12: GET_LOCK in some scenarios of interest.
#        The user-level lock related functions work well.
#        The "main" property of interest seen is:
#        Some failing statement might have taken user-level locks
#        and these locks will not get freed because the statement
#        failed.
# FT-12.1: GET_LOCK within some TRIGGER, User locks stay recursive
connection default;
DELETE FROM t1;
#        Warning: The trigger definition used is "evil" and not for use
#                 some production environment.
CREATE TRIGGER trig_t1_ins BEFORE INSERT ON t1 FOR EACH ROW
SET @aux = GET_LOCK(new.id,7200);
SELECT GET_LOCK(CAST(2 AS CHAR),0);
GET_LOCK(CAST(2 AS CHAR),0)
1
#          Success == No collision with own user lock.
#          Get a second with same name and two with other names.
INSERT INTO t1 VALUES(1),(2),(3);
SELECT RELEASE_LOCK(1) = 1 AS expect_1;
expect_1
1
SELECT RELEASE_LOCK(2) = 1 AS expect_1;
expect_1
1
# Get again 1.
SELECT RELEASE_LOCK(2) = 1 AS expect_1;
expect_1
1
SELECT RELEASE_LOCK(3) = 1 AS expect_1;
expect_1
1
SELECT RELEASE_ALL_LOCKS() = 0 AS expect_1;
expect_1
1
SELECT COUNT(*) FROM t1;
COUNT(*)
3
# FT-12.2: GET_LOCK in an INSERT TRIGGER loses against a MDL lock request.
connection default;
DELETE FROM t1;
SELECT GET_LOCK(2,0);
GET_LOCK(2,0)
1
connection con1;
# Send statement and reap result later.
INSERT INTO t1 VALUES(1),(2),(3);
connection default;
RENAME TABLE t1 TO t1x;
RENAME TABLE t1x TO t1;
connection con1;
# Reap result of "INSERT INTO t1 VALUES(1),(2),(3)".
ERROR HY000: Deadlock found when trying to get user-level lock; try rolling back transaction/releasing locks and restarting lock acquisition.
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
1
SELECT COUNT(*) FROM t1;
COUNT(*)
0
connection default;
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
1
# FT-12.3: GET_LOCK in a better designed INSERT TRIGGER loses.
# FT-12.3.1: Session with INSERT loses via user lock deadlock.
connection default;
DELETE FROM t1;
DROP TRIGGER trig_t1_ins;
CREATE TRIGGER trig_t1_ins BEFORE INSERT ON t1 FOR EACH ROW
BEGIN
SET @aux = GET_LOCK(2,1);
IF @aux <> 1 THEN
SIGNAL SQLSTATE '45000'
      SET MESSAGE_TEXT = 'LOCK 2 not got. Abort.', MYSQL_ERRNO = 9999;
END IF;
END;|
SELECT GET_LOCK(CAST(2 AS CHAR),0);
GET_LOCK(CAST(2 AS CHAR),0)
1
connection con1;
SELECT GET_LOCK(CAST(1 AS CHAR),0);
GET_LOCK(CAST(1 AS CHAR),0)
1
connection default;
# Send statement and reap result later.
SELECT GET_LOCK(CAST(1 AS CHAR),7200);
connection con1;
INSERT INTO t1 VALUES(1),(2),(3);
ERROR HY000: Deadlock found when trying to get user-level lock; try rolling back transaction/releasing locks and restarting lock acquisition.
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
1
SELECT COUNT(*) FROM t1;
COUNT(*)
0
connection default;
# Reap result of "SELECT GET_LOCK(CAST(1 AS CHAR),7200)".
GET_LOCK(CAST(1 AS CHAR),7200)
1
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
2
# FT-12.3.2: INSERT fails in TRIGGER because not getting a user lock in time.
connection default;
DELETE FROM t1;
SELECT GET_LOCK(CAST(2 AS CHAR),0);
GET_LOCK(CAST(2 AS CHAR),0)
1
connection con1;
INSERT INTO t1 VALUES(1),(2),(3);
ERROR 45000: LOCK 2 not got. Abort.
SELECT @aux;
@aux
0
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
0
SELECT COUNT(*) FROM t1;
COUNT(*)
0
connection default;
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
1
DROP TRIGGER trig_t1_ins;
# FT-12.4: User locks and violation of uniqueness.
connection default;
CREATE TABLE t2 (col1 INT, col2 INT, PRIMARY KEY(col1));
DELETE FROM t1;
INSERT INTO t1 VALUES(1),(2),(1);
INSERT INTO t2 SELECT id, GET_LOCK(id,0) FROM t1;
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
3
SELECT * FROM t2;
col1	col2
DELETE FROM t1;
DELETE FROM t2;
INSERT INTO t1 VALUES(1),(1),(2);
INSERT INTO t2 SELECT id, GET_LOCK(id,0) FROM t1;
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
2
SELECT * FROM t2;
col1	col2
DROP TABLE t2;
# FT-12.5: GET_LOCK in a statement having wrong syntax anyway.
#          We get no lock because full syntax check comes first.
SELECT GET_LOCK('test', 0) ORDER BY oscar;
ERROR 42S22: Unknown column 'oscar' in 'order clause'
SELECT RELEASE_ALL_LOCKS() = 0 AS expect_1;
expect_1
1
# Cleanup.
connection default;
DROP TABLE t1;
# FT-12.6: Mix of GET_LOCK and RELEASE*LOCK*
#          Execution is from the left to the right.
SELECT GET_LOCK('test', 0), RELEASE_LOCK('test');
GET_LOCK('test', 0)	RELEASE_LOCK('test')
1	1
SELECT IS_FREE_LOCK('test') = 1 AS expect_1;
expect_1
1
SELECT GET_LOCK('test', 0), RELEASE_LOCK('test'), GET_LOCK('test', 0);
GET_LOCK('test', 0)	RELEASE_LOCK('test')	GET_LOCK('test', 0)
1	1	1
SELECT IS_FREE_LOCK('test') = 0 AS expect_1;
expect_1
1
SELECT RELEASE_LOCK('test') = 1 AS expect_1;
expect_1
1
SELECT GET_LOCK('test', 0), GET_LOCK('test1', 0), RELEASE_ALL_LOCKS(),
GET_LOCK('test', 0);
GET_LOCK('test', 0)	GET_LOCK('test1', 0)	RELEASE_ALL_LOCKS()	GET_LOCK('test', 0)
1	1	2	1
SELECT RELEASE_ALL_LOCKS() = 1 AS expect_1;
expect_1
1
# FT-13: Check types of function results. 
CREATE TABLE t1 AS SELECT GET_LOCK('test', 0) AS g, RELEASE_LOCK('test') AS r,
RELEASE_ALL_LOCKS() AS ra, IS_USED_LOCK('test') AS isu,
IS_FREE_LOCK('test') AS isf;
DESCRIBE t1;
Field	Type	Null	Key	Default	Extra
g	int(1)	YES		NULL	
r	int(1)	YES		NULL	
ra	bigint(21) unsigned	NO		0	
isu	bigint(21) unsigned	YES		NULL	
isf	int(1)	YES		NULL	
DROP TABLE t1;
# FT-14: Check the handling of user-level lock related function parameters.
# FT-14.1: Lock names with NULL or "" assigned.
SELECT GET_LOCK(NULL, 0);
ERROR 42000: Incorrect user-level lock name 'NULL'.
SELECT GET_LOCK("", 0);
ERROR 42000: Incorrect user-level lock name ''.
SELECT RELEASE_LOCK(NULL);
ERROR 42000: Incorrect user-level lock name 'NULL'.
SELECT RELEASE_LOCK("");
ERROR 42000: Incorrect user-level lock name ''.
SELECT IS_USED_LOCK(NULL);
ERROR 42000: Incorrect user-level lock name 'NULL'.
SELECT IS_USED_LOCK("");
ERROR 42000: Incorrect user-level lock name ''.
SELECT IS_FREE_LOCK(NULL);
ERROR 42000: Incorrect user-level lock name 'NULL'.
SELECT IS_FREE_LOCK("");
ERROR 42000: Incorrect user-level lock name ''.
# FT-14.2: Length of lock name at the limit of 64.
SELECT GET_LOCK(REPEAT('a', 64), 0) = 1 AS expect_1;
expect_1
1
SELECT IS_USED_LOCK(REPEAT('a', 64)) = CONNECTION_ID() AS expect_1;
expect_1
1
SELECT IS_FREE_LOCK(REPEAT('a', 64)) = 0 AS expect_1;
expect_1
1
SELECT RELEASE_LOCK(REPEAT('a', 64)) = 1 AS expect_1;
expect_1
1
# FT-14.3: Lock name too long.
SELECT GET_LOCK(REPEAT('a', 65), 0);
ERROR 42000: Incorrect user-level lock name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.
SELECT IS_USED_LOCK(REPEAT('a', 65));
ERROR 42000: Incorrect user-level lock name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.
SELECT IS_FREE_LOCK(REPEAT('a', 65));
ERROR 42000: Incorrect user-level lock name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.
SELECT RELEASE_LOCK(REPEAT('a', 65));
ERROR 42000: Incorrect user-level lock name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.
# FT-14.4: Check that lock names are case-insensitive.
SELECT GET_LOCK('A', 0);
GET_LOCK('A', 0)
1
connection con1;
SELECT GET_LOCK('a', 0);
GET_LOCK('a', 0)
0
connection default;
SELECT IS_USED_LOCK('a') = CONNECTION_ID();
IS_USED_LOCK('a') = CONNECTION_ID()
1
SELECT IS_FREE_LOCK('a');
IS_FREE_LOCK('a')
0
SELECT RELEASE_LOCK('a');
RELEASE_LOCK('a')
1
# FT-14.5: Check that lock names are converted and compared in utf-8,
# to do this use 'ั‚ะตัั‚' in various encodings as lock name.
SELECT GET_LOCK(_cp1251 0xf2e5f1f2, 0);
GET_LOCK(_cp1251 0xf2e5f1f2, 0)
1
connection con1;
SELECT GET_LOCK(_utf8 0xd182d0b5d181d182, 0);
GET_LOCK(_utf8 0xd182d0b5d181d182, 0)
0
connection default;
SELECT IS_USED_LOCK(_koi8r 0xd4c5d3d4) = CONNECTION_ID();
IS_USED_LOCK(_koi8r 0xd4c5d3d4) = CONNECTION_ID()
1
SELECT IS_FREE_LOCK(_utf8 0xd182d0b5d181d182);
IS_FREE_LOCK(_utf8 0xd182d0b5d181d182)
0
SELECT RELEASE_LOCK(_utf8 0xd182d0b5d181d182);
RELEASE_LOCK(_utf8 0xd182d0b5d181d182)
1
# FT-14.6: Check wrong number of parameters.
SELECT GET_LOCK('test');
ERROR 42000: Incorrect parameter count in the call to native function 'GET_LOCK'
SELECT GET_LOCK('test', 0, 1);
ERROR 42000: Incorrect parameter count in the call to native function 'GET_LOCK'
SELECT RELEASE_LOCK();
ERROR 42000: Incorrect parameter count in the call to native function 'RELEASE_LOCK'
SELECT RELEASE_LOCK('test', 1);
ERROR 42000: Incorrect parameter count in the call to native function 'RELEASE_LOCK'
SELECT RELEASE_ALL_LOCKS('test');
ERROR 42000: Incorrect parameter count in the call to native function 'RELEASE_ALL_LOCKS'
SELECT IS_USED_LOCK();
ERROR 42000: Incorrect parameter count in the call to native function 'IS_USED_LOCK'
SELECT IS_USED_LOCK('test', 'test2');
ERROR 42000: Incorrect parameter count in the call to native function 'IS_USED_LOCK'
SELECT IS_FREE_LOCK();
ERROR 42000: Incorrect parameter count in the call to native function 'IS_FREE_LOCK'
SELECT IS_FREE_LOCK('test', 'test2');
ERROR 42000: Incorrect parameter count in the call to native function 'IS_FREE_LOCK'
# FT-14.7: NULL timeout is interpreted as 0 timeout.
connection con1;
SELECT GET_LOCK("test", 0);
GET_LOCK("test", 0)
1
connection default;
#        Interpretation as 0 leads to use of send/reap is not required.
SELECT GET_LOCK("test", NULL) = 0 AS expect_1;
expect_1
1
connection con1;
SELECT RELEASE_LOCK("test");
RELEASE_LOCK("test")
1
connection default;
# FT-14.8: Check that a negative timeout is interpreted as infinite wait.
#         Test case for
#         BUG#11764049 GET_LOCK() TIMEOUT BEHAVES DIFFERENTLY ON
#                      DIFFERING PLATFORMS
connection default;
SELECT GET_LOCK('test', 0);
GET_LOCK('test', 0)
1
connection con1;
# Send statement and reap result later.
SELECT GET_LOCK('test', -1);
connection default;
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
connection con1;
# Reap result of "SELECT GET_LOCK('test', -1)".
GET_LOCK('test', -1)
1
SELECT RELEASE_LOCK('test');
RELEASE_LOCK('test')
1
disconnect con1;
connection default;
CREATE TABLE t1 (conn CHAR(7), connection_id INT);
INSERT INTO t1 VALUES ('default', CONNECTION_ID());
SELECT GET_LOCK('bug16501',600);
GET_LOCK('bug16501',600)
1
connect  con1,localhost,root,,;
INSERT INTO t1 VALUES ('con1', CONNECTION_ID());
SELECT IS_USED_LOCK('bug16501') = connection_id
FROM t1
WHERE conn = 'default';
IS_USED_LOCK('bug16501') = connection_id
1
# Send statement and reap result later.
SELECT GET_LOCK('bug16501',600);
connection default;
SELECT IS_USED_LOCK('bug16501') = CONNECTION_ID();
IS_USED_LOCK('bug16501') = CONNECTION_ID()
1
SELECT RELEASE_LOCK('bug16501');
RELEASE_LOCK('bug16501')
1
connection con1;
# Reap result of "SELECT GET_LOCK('bug16501',600)".
GET_LOCK('bug16501',600)
1
connection default;
SELECT IS_USED_LOCK('bug16501') = connection_id
FROM t1
WHERE conn = 'con1';
IS_USED_LOCK('bug16501') = connection_id
1
connection con1;
SELECT IS_USED_LOCK('bug16501') = CONNECTION_ID();
IS_USED_LOCK('bug16501') = CONNECTION_ID()
1
SELECT RELEASE_LOCK('bug16501');
RELEASE_LOCK('bug16501')
1
SELECT IS_USED_LOCK('bug16501');
IS_USED_LOCK('bug16501')
NULL
connection default;
SELECT RELEASE_ALL_LOCKS();
RELEASE_ALL_LOCKS()
0
DROP TABLE t1;
connection con1;
disconnect con1;
connection default;
#
# Bug#20031761 ASSERTION `SCALE >= 0 && PRECISION > 0 &&
#              SCALE <= PRECISION' FAILED
#
SET @@session.div_precision_increment=0;
select * from(SELECT MIN(GET_LOCK(0,0) / 1 ^ 0)) as a;
MIN(GET_LOCK(0,0) / 1 ^ 0)
1
select * from(SELECT MAX(RELEASE_LOCK(0) / 1 ^ 0)) as a;
MAX(RELEASE_LOCK(0) / 1 ^ 0)
1
select * from(SELECT MAX(RELEASE_ALL_LOCKS() / 1 ^ 0)) as a;
MAX(RELEASE_ALL_LOCKS() / 1 ^ 0)
0
SET @@session.div_precision_increment=default;
#
# End of tests
#

Man Man