diff options
author | Alexander Barkov <bar@mariadb.com> | 2018-03-02 11:31:27 +0400 |
---|---|---|
committer | Alexander Barkov <bar@mariadb.com> | 2018-03-02 11:31:27 +0400 |
commit | 88a9d4ab42d370dedc9b1d90c75bee53fd8fb8c0 (patch) | |
tree | 47948f0c01e1cc409e44f7aa16997d3c203493d5 /mysql-test/t/sp-destruct.test | |
parent | 4025cfaec038594bfc97bea48aa2cfe139930cc2 (diff) | |
download | mariadb-git-88a9d4ab42d370dedc9b1d90c75bee53fd8fb8c0.tar.gz |
MDEV-15444 Querying I_S.PARAMETERS can crash with a corrupted mysql.proc
Diffstat (limited to 'mysql-test/t/sp-destruct.test')
-rw-r--r-- | mysql-test/t/sp-destruct.test | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/mysql-test/t/sp-destruct.test b/mysql-test/t/sp-destruct.test index 31da235d906..c0a83b12206 100644 --- a/mysql-test/t/sp-destruct.test +++ b/mysql-test/t/sp-destruct.test @@ -285,3 +285,38 @@ create database mysqltest1; create procedure mysqltest1.foo() select "foo"; update mysql.proc set name='' where db='mysqltest1'; drop database mysqltest1; + + +--echo # +--echo # MDEV-15444 Querying I_S.PARAMETERS can crash with a corrupted mysql.proc +--echo # + +CREATE OR REPLACE FUNCTION f1 (a INT) RETURNS INT RETURN 10; +CREATE OR REPLACE FUNCTION f2 (a INT) RETURNS INT RETURN 10; + +# Get the current data type for mysql.proc.type +--vertical_results +SELECT + @type0:=COLUMN_TYPE AS t0, + @type1:=REPLACE(COLUMN_TYPE,')',',''XXX'')') AS t1 + FROM INFORMATION_SCHEMA.COLUMNS +WHERE table_schema='mysql' AND table_name='proc' AND column_name='type'; +--horizontal_results + +# Change mysql.proc.type and update the record for 'f1' +EXECUTE IMMEDIATE CONCAT('ALTER TABLE mysql.proc MODIFY type ', @type1); +SHOW COLUMNS IN mysql.proc LIKE 'type'; +UPDATE mysql.proc SET type='XXX' WHERE name='f1' AND db='test'; + +# Check the I_S query +--vertical_results +SELECT * FROM INFORMATION_SCHEMA.PARAMETERS WHERE SPECIFIC_SCHEMA='test'; +--horizontal_results + +# Restore the record for 'f1' and restore mysql.proc.type +UPDATE mysql.proc SET type='FUNCTION' WHERE name='f1' AND db='test'; +EXECUTE IMMEDIATE CONCAT('ALTER TABLE mysql.proc MODIFY type ', @type0); +SHOW COLUMNS IN mysql.proc LIKE 'type'; + +DROP FUNCTION f1; +DROP FUNCTION f2; |