2009-10-26 11:55:57 +02:00
|
|
|
#
|
|
|
|
# Bug #47412: Valgrind warnings / user can read uninitalized memory
|
|
|
|
# using SP variables
|
|
|
|
#
|
|
|
|
CREATE SCHEMA testdb;
|
|
|
|
USE testdb;
|
|
|
|
CREATE FUNCTION f2 () RETURNS INTEGER
|
|
|
|
BEGIN
|
|
|
|
DECLARE CONTINUE HANDLER FOR SQLSTATE '42000' SET @aux = 1;
|
|
|
|
RETURN f_not_exists () ;
|
|
|
|
END|
|
|
|
|
CREATE PROCEDURE p3 ( arg1 VARCHAR(32) )
|
|
|
|
BEGIN
|
|
|
|
CALL p_not_exists ( );
|
|
|
|
END|
|
|
|
|
# should not return valgrind warnings
|
|
|
|
CALL p3 ( f2 () );
|
|
|
|
ERROR 42000: PROCEDURE testdb.p_not_exists does not exist
|
|
|
|
DROP SCHEMA testdb;
|
|
|
|
CREATE SCHEMA testdb;
|
|
|
|
USE testdb;
|
|
|
|
CREATE FUNCTION f2 () RETURNS INTEGER
|
|
|
|
BEGIN
|
|
|
|
DECLARE CONTINUE HANDLER FOR SQLSTATE '42000' SET @aux = 1;
|
|
|
|
RETURN f_not_exists () ;
|
|
|
|
END|
|
|
|
|
CREATE PROCEDURE p3 ( arg2 INTEGER )
|
|
|
|
BEGIN
|
|
|
|
CALL p_not_exists ( );
|
|
|
|
END|
|
|
|
|
# should not return valgrind warnings
|
|
|
|
CALL p3 ( f2 () );
|
|
|
|
ERROR 42000: PROCEDURE testdb.p_not_exists does not exist
|
|
|
|
DROP SCHEMA testdb;
|
|
|
|
CREATE SCHEMA testdb;
|
|
|
|
USE testdb;
|
|
|
|
CREATE FUNCTION f2 () RETURNS INTEGER
|
|
|
|
BEGIN
|
|
|
|
DECLARE CONTINUE HANDLER FOR SQLSTATE '42000' SET @aux = 1;
|
|
|
|
RETURN f_not_exists () ;
|
|
|
|
END|
|
|
|
|
# should not return valgrind warnings
|
|
|
|
SELECT f2 ();
|
|
|
|
f2 ()
|
|
|
|
NULL
|
|
|
|
DROP SCHEMA testdb;
|
2010-01-28 12:41:14 -02:00
|
|
|
USE test;
|
|
|
|
#
|
|
|
|
# Bug#50423: Crash on second call of a procedure dropping a trigger
|
|
|
|
#
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
|
|
DROP TRIGGER IF EXISTS tr1;
|
|
|
|
DROP PROCEDURE IF EXISTS p1;
|
|
|
|
CREATE TABLE t1 (f1 INTEGER);
|
|
|
|
CREATE TRIGGER tr1 BEFORE INSERT ON t1 FOR EACH ROW SET @aux = 1;
|
|
|
|
CREATE PROCEDURE p1 () DROP TRIGGER tr1;
|
|
|
|
CALL p1 ();
|
|
|
|
CALL p1 ();
|
|
|
|
ERROR HY000: Trigger does not exist
|
|
|
|
DROP TABLE t1;
|
|
|
|
DROP PROCEDURE p1;
|
2010-02-13 08:35:14 -02:00
|
|
|
#
|
|
|
|
# Bug#50423: Crash on second call of a procedure dropping a trigger
|
|
|
|
#
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
|
|
DROP TRIGGER IF EXISTS tr1;
|
|
|
|
DROP PROCEDURE IF EXISTS p1;
|
|
|
|
CREATE TABLE t1 (f1 INTEGER);
|
|
|
|
CREATE TRIGGER tr1 BEFORE INSERT ON t1 FOR EACH ROW SET @aux = 1;
|
|
|
|
CREATE PROCEDURE p1 () DROP TRIGGER tr1;
|
|
|
|
CALL p1 ();
|
|
|
|
CALL p1 ();
|
|
|
|
ERROR HY000: Trigger does not exist
|
|
|
|
DROP TABLE t1;
|
|
|
|
DROP PROCEDURE p1;
|
Fixed bug#54375 - Error in stored procedure leaves connection
in different default schema.
In strict mode, when data truncation or conversion happens,
THD::killed is set to THD::KILL_BAD_DATA.
This is abuse of KILL mechanism to guarantee that execution
of statement is aborted.
The stored procedures execution, on the other hand,
upon detection that a connection was killed, would
terminate immediately, without trying to restore the caller's
context, in particular, restore the caller's current schema.
The fix is, when terminating a stored procedure execution,
to only bypass cleanup if the entire connection was killed,
not in case of other forms of KILL.
mysql-test/r/sp-bugs.result:
Added result for a test case for bug#54375.
mysql-test/t/sp-bugs.test:
Added test case for bug#54375.
sql/sp_head.cc:
sp_head::execute modified: restore saved current db if
connection is not killed.
2010-11-11 10:52:51 +06:00
|
|
|
#
|
|
|
|
# Bug#54375: Error in stored procedure leaves connection
|
|
|
|
# in different default schema
|
|
|
|
#
|
|
|
|
SET @@SQL_MODE = 'STRICT_ALL_TABLES';
|
|
|
|
DROP DATABASE IF EXISTS db1;
|
|
|
|
CREATE DATABASE db1;
|
|
|
|
USE db1;
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
|
|
CREATE TABLE t1 (c1 int NOT NULL PRIMARY KEY);
|
|
|
|
INSERT INTO t1 VALUES (1);
|
|
|
|
CREATE FUNCTION f1 (
|
|
|
|
some_value int
|
|
|
|
)
|
|
|
|
RETURNS smallint
|
|
|
|
DETERMINISTIC
|
|
|
|
BEGIN
|
|
|
|
INSERT INTO t1 SET c1 = some_value;
|
|
|
|
RETURN(LAST_INSERT_ID());
|
|
|
|
END$$
|
|
|
|
DROP DATABASE IF EXISTS db2;
|
|
|
|
CREATE DATABASE db2;
|
|
|
|
USE db2;
|
|
|
|
SELECT DATABASE();
|
|
|
|
DATABASE()
|
|
|
|
db2
|
|
|
|
SELECT db1.f1(1);
|
|
|
|
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
|
|
|
|
SELECT DATABASE();
|
|
|
|
DATABASE()
|
|
|
|
db2
|
|
|
|
USE test;
|
|
|
|
DROP FUNCTION db1.f1;
|
|
|
|
DROP TABLE db1.t1;
|
|
|
|
DROP DATABASE db1;
|
|
|
|
DROP DATABASE db2;
|
2012-03-27 12:42:11 +05:30
|
|
|
USE test;
|
2012-01-30 11:57:33 +05:30
|
|
|
#
|
|
|
|
# Bug#13105873:valgrind warning:possible crash in foreign
|
|
|
|
# key handling on subsequent create table if not exists
|
|
|
|
#
|
|
|
|
DROP DATABASE IF EXISTS testdb;
|
|
|
|
CREATE DATABASE testdb;
|
|
|
|
USE testdb;
|
|
|
|
CREATE TABLE t1 (id1 INT PRIMARY KEY);
|
|
|
|
CREATE PROCEDURE `p1`()
|
|
|
|
BEGIN
|
|
|
|
CREATE TABLE IF NOT EXISTS t2(id INT PRIMARY KEY,
|
|
|
|
CONSTRAINT FK FOREIGN KEY (id) REFERENCES t1( id1 ));
|
|
|
|
END$
|
|
|
|
CALL p1();
|
|
|
|
# below stmt should not return valgrind warnings
|
|
|
|
CALL p1();
|
|
|
|
Warnings:
|
|
|
|
Note 1050 Table 't2' already exists
|
|
|
|
DROP DATABASE testdb;
|
2012-03-27 12:42:11 +05:30
|
|
|
USE test;
|
2009-10-26 11:55:57 +02:00
|
|
|
End of 5.1 tests
|
2012-03-27 12:42:11 +05:30
|
|
|
#
|
|
|
|
# Bug#11763507 - 56224: FUNCTION NAME IS CASE-SENSITIVE
|
|
|
|
#
|
|
|
|
SET @@SQL_MODE = '';
|
|
|
|
CREATE FUNCTION testf_bug11763507() RETURNS INT
|
|
|
|
BEGIN
|
|
|
|
RETURN 0;
|
|
|
|
END
|
|
|
|
$
|
|
|
|
CREATE PROCEDURE testp_bug11763507()
|
|
|
|
BEGIN
|
|
|
|
SELECT "PROCEDURE testp_bug11763507";
|
|
|
|
END
|
|
|
|
$
|
|
|
|
SELECT testf_bug11763507();
|
|
|
|
testf_bug11763507()
|
|
|
|
0
|
|
|
|
SELECT TESTF_bug11763507();
|
|
|
|
TESTF_bug11763507()
|
|
|
|
0
|
|
|
|
SHOW FUNCTION STATUS LIKE 'testf_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testf_bug11763507 FUNCTION root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW FUNCTION STATUS WHERE NAME='testf_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testf_bug11763507 FUNCTION root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW FUNCTION STATUS LIKE 'TESTF_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testf_bug11763507 FUNCTION root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW FUNCTION STATUS WHERE NAME='TESTF_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testf_bug11763507 FUNCTION root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW CREATE FUNCTION testf_bug11763507;
|
|
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
|
|
testf_bug11763507 CREATE DEFINER=`root`@`localhost` FUNCTION `testf_bug11763507`() RETURNS int(11)
|
|
|
|
BEGIN
|
|
|
|
RETURN 0;
|
|
|
|
END latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW CREATE FUNCTION TESTF_bug11763507;
|
|
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
|
|
testf_bug11763507 CREATE DEFINER=`root`@`localhost` FUNCTION `testf_bug11763507`() RETURNS int(11)
|
|
|
|
BEGIN
|
|
|
|
RETURN 0;
|
|
|
|
END latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
CALL testp_bug11763507();
|
|
|
|
PROCEDURE testp_bug11763507
|
|
|
|
PROCEDURE testp_bug11763507
|
|
|
|
CALL TESTP_bug11763507();
|
|
|
|
PROCEDURE testp_bug11763507
|
|
|
|
PROCEDURE testp_bug11763507
|
|
|
|
SHOW PROCEDURE STATUS LIKE 'testp_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testp_bug11763507 PROCEDURE root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW PROCEDURE STATUS WHERE NAME='testp_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testp_bug11763507 PROCEDURE root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW PROCEDURE STATUS LIKE 'TESTP_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testp_bug11763507 PROCEDURE root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW PROCEDURE STATUS WHERE NAME='TESTP_bug11763507';
|
|
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
|
|
test testp_bug11763507 PROCEDURE root@localhost # # DEFINER latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW CREATE PROCEDURE testp_bug11763507;
|
|
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
|
|
testp_bug11763507 CREATE DEFINER=`root`@`localhost` PROCEDURE `testp_bug11763507`()
|
|
|
|
BEGIN
|
|
|
|
SELECT "PROCEDURE testp_bug11763507";
|
|
|
|
END latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SHOW CREATE PROCEDURE TESTP_bug11763507;
|
|
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
|
|
testp_bug11763507 CREATE DEFINER=`root`@`localhost` PROCEDURE `testp_bug11763507`()
|
|
|
|
BEGIN
|
|
|
|
SELECT "PROCEDURE testp_bug11763507";
|
|
|
|
END latin1 latin1_swedish_ci latin1_swedish_ci
|
|
|
|
SELECT specific_name FROM INFORMATION_SCHEMA.ROUTINES WHERE specific_name LIKE 'testf_bug11763507';
|
|
|
|
specific_name
|
|
|
|
testf_bug11763507
|
|
|
|
SELECT specific_name FROM INFORMATION_SCHEMA.ROUTINES WHERE specific_name LIKE 'TESTF_bug11763507';
|
|
|
|
specific_name
|
|
|
|
testf_bug11763507
|
|
|
|
SELECT specific_name FROM INFORMATION_SCHEMA.ROUTINES WHERE specific_name='testf_bug11763507';
|
|
|
|
specific_name
|
|
|
|
testf_bug11763507
|
|
|
|
SELECT specific_name FROM INFORMATION_SCHEMA.ROUTINES WHERE specific_name='TESTF_bug11763507';
|
|
|
|
specific_name
|
|
|
|
testf_bug11763507
|
|
|
|
DROP PROCEDURE testp_bug11763507;
|
|
|
|
DROP FUNCTION testf_bug11763507;
|
|
|
|
#END OF BUG#11763507 test.
|