mirror of
https://github.com/MariaDB/server.git
synced 2025-01-25 00:04:33 +01:00
1ad5bb1a69
Bug#16565 mysqld --help --verbose does not order variablesBug#20413 sql_slave_skip_counter is not shown in show variables Bug#20415 Output of mysqld --help --verbose is incomplete Bug#25430 variable not found in SELECT @@global.ft_max_word_len; Bug#32902 plugin variables don't know their names Bug#34599 MySQLD Option and Variable Reference need to be consistent in formatting! Bug#34829 No default value for variable and setting default does not raise error Bug#34834 ? Is accepted as a valid sql mode Bug#34878 Few variables have default value according to documentation but error occurs Bug#34883 ft_boolean_syntax cant be assigned from user variable to global var. Bug#37187 `INFORMATION_SCHEMA`.`GLOBAL_VARIABLES`: inconsistent status Bug#40988 log_output_basic.test succeeded though syntactically false. Bug#41010 enum-style command-line options are not honoured (maria.maria-recover fails) Bug#42103 Setting key_buffer_size to a negative value may lead to very large allocations Bug#44691 Some plugins configured as MYSQL_PLUGIN_MANDATORY in can be disabled Bug#44797 plugins w/o command-line options have no disabling option in --help Bug#46314 string system variables don't support expressions Bug#46470 sys_vars.max_binlog_cache_size_basic_32 is broken Bug#46586 When using the plugin interface the type "set" for options caused a crash. Bug#47212 Crash in DBUG_PRINT in mysqltest.cc when trying to print octal number Bug#48758 mysqltest crashes on sys_vars.collation_server_basic in gcov builds Bug#49417 some complaints about mysqld --help --verbose output Bug#49540 DEFAULT value of binlog_format isn't the default value Bug#49640 ambiguous option '--skip-skip-myisam' (double skip prefix) Bug#49644 init_connect and \0 Bug#49645 init_slave and multi-byte characters Bug#49646 mysql --show-warnings crashes when server dies CMakeLists.txt: Bug#44691 Some plugins configured as MYSQL_PLUGIN_MANDATORY in can be disabled client/mysql.cc: don't crash with --show-warnings when mysqld dies config/ac-macros/plugins.m4: Bug#44691 Some plugins configured as MYSQL_PLUGIN_MANDATORY in can be disabled include/my_getopt.h: comments include/my_pthread.h: fix double #define mysql-test/mysql-test-run.pl: run sys_vars suite by default properly recognize envirinment variables (e.g. MTR_MAX_SAVE_CORE) set to 0 escape gdb command line arguments mysql-test/suite/sys_vars/r/rpl_init_slave_func.result: init_slave+utf8 bug mysql-test/suite/sys_vars/t/rpl_init_slave_func.test: init_slave+utf8 bug mysys/my_getopt.c: Bug#34599 MySQLD Option and Variable Reference need to be consistent in formatting! Bug#46586 When using the plugin interface the type "set" for options caused a crash. Bug#49640 ambiguous option '--skip-skip-myisam' (double skip prefix) mysys/typelib.c: support for flagset sql/ha_ndbcluster.cc: backport from telco tree sql/item_func.cc: Bug#49644 init_connect and \0 Bug#49645 init_slave and multi-byte characters sql/sql_builtin.cc.in: Bug#44691 Some plugins configured as MYSQL_PLUGIN_MANDATORY in can be disabled sql/sql_plugin.cc: Bug#44691 Some plugins configured as MYSQL_PLUGIN_MANDATORY in can be disabled Bug#32902 plugin variables don't know their names Bug#44797 plugins w/o command-line options have no disabling option in --help sql/sys_vars.cc: all server variables are defined here storage/myisam/ft_parser.c: remove unnecessary updates of param->quot storage/myisam/ha_myisam.cc: myisam_* variables belong here strings/my_vsnprintf.c: %o and %llx unittest/mysys/my_vsnprintf-t.c: %o and %llx tests vio/viosocket.c: bugfix: fix @@wait_timeout to work with socket timeouts (vs. alarm thread)
1149 lines
23 KiB
Text
1149 lines
23 KiB
Text
# Objects to test:
|
||
# - stored procedures/functions;
|
||
# - triggers;
|
||
# - events;
|
||
# - views;
|
||
#
|
||
# For stored routines:
|
||
# - create a database with collation utf8_unicode_ci;
|
||
# - create an object, which
|
||
# - contains SP-var with explicit CHARSET-clause;
|
||
# - contains SP-var without CHARSET-clause;
|
||
# - contains text constant;
|
||
# - has localized routine/parameter names;
|
||
# - check:
|
||
# - execute;
|
||
# - SHOW CREATE output;
|
||
# - SHOW output;
|
||
# - SELECT FROM INFORMATION_SCHEMA output;
|
||
# - alter database character set;
|
||
# - change connection collation;
|
||
# - check again;
|
||
# - dump definition using mysqldump;
|
||
# - drop object;
|
||
# - restore object;
|
||
#
|
||
|
||
###########################################################################
|
||
#
|
||
# NOTE: this file contains text in UTF8 and KOI8-R encodings.
|
||
#
|
||
###########################################################################
|
||
|
||
# Test requires server to accept client connections (for mysqldump portions)
|
||
--source include/not_embedded.inc
|
||
--source include/have_utf8.inc
|
||
--source include/have_cp866.inc
|
||
--source include/have_cp1251.inc
|
||
--source include/have_koi8r.inc
|
||
|
||
###########################################################################
|
||
|
||
set names koi8r;
|
||
delimiter |;
|
||
|
||
###########################################################################
|
||
#
|
||
# * Views.
|
||
#
|
||
###########################################################################
|
||
|
||
--echo
|
||
--echo -------------------------------------------------------------------
|
||
--echo Views
|
||
--echo -------------------------------------------------------------------
|
||
--echo
|
||
|
||
#
|
||
# Preparation:
|
||
#
|
||
|
||
# - Create database with fixed, pre-defined character set.
|
||
|
||
--disable_warnings
|
||
DROP DATABASE IF EXISTS mysqltest1|
|
||
--enable_warnings
|
||
|
||
CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
|
||
use mysqltest1|
|
||
|
||
CREATE TABLE t1(ËÏÌ INT)|
|
||
INSERT INTO t1 VALUES(1)|
|
||
|
||
# - Create views;
|
||
|
||
--echo
|
||
|
||
CREATE VIEW v1 AS
|
||
SELECT 'ÔÅÓÔ' AS c1, ËÏÌ AS c2
|
||
FROM t1|
|
||
|
||
--echo
|
||
|
||
CREATE VIEW v2 AS SELECT _utf8'теÑ<C2B5>Ñ‚' as c1|
|
||
|
||
--echo
|
||
|
||
CREATE VIEW v3 AS SELECT _utf8'теÑ<C2B5>Ñ‚'|
|
||
|
||
--echo
|
||
|
||
#
|
||
# First-round checks.
|
||
#
|
||
|
||
--source include/ddl_i18n.check_views.inc
|
||
|
||
#
|
||
# Change running environment (alter database character set, change session
|
||
# variables).
|
||
#
|
||
|
||
--echo
|
||
--echo
|
||
|
||
ALTER DATABASE mysqltest1 COLLATE cp866_general_ci|
|
||
|
||
#
|
||
# Second-round checks:
|
||
#
|
||
|
||
# - Change connection to flush cache;
|
||
|
||
--connect (con2,localhost,root,,)
|
||
--echo
|
||
--echo ---> connection: con2
|
||
|
||
# - Switch environment variables and trigger loading views;
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
--disable_result_log
|
||
SELECT * FROM mysqltest1.v1|
|
||
SELECT * FROM mysqltest1.v2|
|
||
SELECT * FROM mysqltest1.v3|
|
||
--enable_result_log
|
||
|
||
use mysqltest1|
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_views.inc
|
||
|
||
#
|
||
# Check mysqldump.
|
||
#
|
||
|
||
# - Dump mysqltest1;
|
||
|
||
--let $views_dump1 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.views.mysqltest1.sql
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest1 to ddl_i18n_koi8r.views.mysqltest1.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --databases mysqltest1 > $views_dump1
|
||
|
||
# - Clean mysqltest1;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
DROP DATABASE mysqltest1|
|
||
|
||
# - Restore mysqltest1;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
--echo ---> Restoring mysqltest1...
|
||
--exec $MYSQL test < $views_dump1
|
||
|
||
--remove_file $views_dump1
|
||
|
||
#
|
||
# Third-round checks.
|
||
#
|
||
|
||
# - Change connection to flush cache;
|
||
|
||
--connect (con3,localhost,root,,)
|
||
--echo
|
||
--echo ---> connection: con3
|
||
|
||
# - Switch environment variables and trigger loading views;
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
--disable_result_log
|
||
SELECT * FROM mysqltest1.v1|
|
||
SELECT * FROM mysqltest1.v2|
|
||
SELECT * FROM mysqltest1.v3|
|
||
--enable_result_log
|
||
|
||
use mysqltest1|
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_views.inc
|
||
|
||
#
|
||
# Cleanup.
|
||
#
|
||
|
||
--connection default
|
||
--echo
|
||
--echo ---> connection: default
|
||
|
||
--disconnect con2
|
||
--disconnect con3
|
||
|
||
use test|
|
||
|
||
DROP DATABASE mysqltest1|
|
||
|
||
###########################################################################
|
||
#
|
||
# * Stored procedures/functions.
|
||
#
|
||
###########################################################################
|
||
|
||
--echo
|
||
--echo -------------------------------------------------------------------
|
||
--echo Stored procedures/functions
|
||
--echo -------------------------------------------------------------------
|
||
--echo
|
||
|
||
#
|
||
# Preparation:
|
||
#
|
||
|
||
# - Create database with fixed, pre-defined character set.
|
||
|
||
--disable_warnings
|
||
DROP DATABASE IF EXISTS mysqltest1|
|
||
DROP DATABASE IF EXISTS mysqltest2|
|
||
--enable_warnings
|
||
|
||
CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
CREATE DATABASE mysqltest2 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
|
||
use mysqltest1|
|
||
|
||
# - Create two stored routines -- with and without explicit
|
||
# CHARSET-clause for SP-variable;
|
||
#
|
||
|
||
--echo
|
||
|
||
# - Procedure p1
|
||
|
||
CREATE PROCEDURE p1(
|
||
INOUT ÐÁÒÁÍ1 CHAR(10),
|
||
OUT ÐÁÒÁÍ2 CHAR(10))
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10);
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION(ÐÁÒÁÍ1) AS c2,
|
||
COLLATION(ÐÁÒÁÍ2) AS c3;
|
||
|
||
SELECT
|
||
COLLATION('ÔÅËÓÔ') AS c4,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c5,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c6,
|
||
@@collation_connection AS c7,
|
||
@@character_set_client AS c8;
|
||
|
||
SET ÐÁÒÁÍ1 = 'a';
|
||
SET ÐÁÒÁÍ2 = 'b';
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Procedure p2
|
||
|
||
CREATE PROCEDURE p2(
|
||
INOUT ÐÁÒÁÍ1 CHAR(10) CHARACTER SET utf8,
|
||
OUT ÐÁÒÁÍ2 CHAR(10) CHARACTER SET utf8)
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION(ÐÁÒÁÍ1) AS c2,
|
||
COLLATION(ÐÁÒÁÍ2) AS c3;
|
||
|
||
SELECT
|
||
COLLATION('ÔÅËÓÔ') AS c4,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c5,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c6,
|
||
@@collation_connection AS c7,
|
||
@@character_set_client AS c8;
|
||
|
||
SET ÐÁÒÁÍ1 = 'a';
|
||
SET ÐÁÒÁÍ2 = 'b';
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Procedure p3
|
||
|
||
CREATE PROCEDURE mysqltest2.p3(
|
||
INOUT ÐÁÒÁÍ1 CHAR(10),
|
||
OUT ÐÁÒÁÍ2 CHAR(10))
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10);
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION(ÐÁÒÁÍ1) AS c2,
|
||
COLLATION(ÐÁÒÁÍ2) AS c3;
|
||
|
||
SELECT
|
||
COLLATION('ÔÅËÓÔ') AS c4,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c5,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c6,
|
||
@@collation_connection AS c7,
|
||
@@character_set_client AS c8;
|
||
|
||
SET ÐÁÒÁÍ1 = 'a';
|
||
SET ÐÁÒÁÍ2 = 'b';
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Procedure p4
|
||
|
||
CREATE PROCEDURE mysqltest2.p4(
|
||
INOUT ÐÁÒÁÍ1 CHAR(10) CHARACTER SET utf8,
|
||
OUT ÐÁÒÁÍ2 CHAR(10) CHARACTER SET utf8)
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION(ÐÁÒÁÍ1) AS c2,
|
||
COLLATION(ÐÁÒÁÍ2) AS c3;
|
||
|
||
SELECT
|
||
COLLATION('ÔÅËÓÔ') AS c4,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c5,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c6,
|
||
@@collation_connection AS c7,
|
||
@@character_set_client AS c8;
|
||
|
||
SET ÐÁÒÁÍ1 = 'a';
|
||
SET ÐÁÒÁÍ2 = 'b';
|
||
END|
|
||
|
||
#
|
||
# First-round checks.
|
||
#
|
||
|
||
--source include/ddl_i18n.check_sp.inc
|
||
|
||
#
|
||
# Change running environment (alter database character set, change session
|
||
# variables).
|
||
#
|
||
|
||
--echo
|
||
--echo
|
||
|
||
ALTER DATABASE mysqltest1 COLLATE cp866_general_ci|
|
||
ALTER DATABASE mysqltest2 COLLATE cp866_general_ci|
|
||
|
||
#
|
||
# Second-round checks:
|
||
#
|
||
|
||
# - Change connection to flush SP-cache;
|
||
|
||
--connect (con2,localhost,root,,mysqltest1)
|
||
--echo
|
||
--echo ---> connection: con2
|
||
|
||
# - Switch environment variables and trigger loading stored procedures;
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
CALL p1(@a, @b)|
|
||
CALL p2(@a, @b)|
|
||
CALL mysqltest2.p3(@a, @b)|
|
||
CALL mysqltest2.p4(@a, @b)|
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_sp.inc
|
||
|
||
#
|
||
# Check mysqldump.
|
||
#
|
||
|
||
# - Dump mysqltest1, mysqltest2;
|
||
|
||
--let $sp_dump1 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.sp.mysqltest1.sql
|
||
--let $sp_dump2 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.sp.mysqltest2.sql
|
||
|
||
--echo
|
||
--echo ---> Dump of mysqltest1
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --routines --databases mysqltest1
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest1 to ddl_i18n_koi8r.sp.mysqltest1.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --routines --databases mysqltest1 > $sp_dump1
|
||
|
||
--echo
|
||
--echo ---> Dump of mysqltest2
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --routines --databases mysqltest2
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest2 to ddl_i18n_koi8r.sp.mysqltest2.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --routines --databases mysqltest2 > $sp_dump2
|
||
|
||
# - Clean mysqltest1, mysqltest2;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
DROP DATABASE mysqltest1|
|
||
DROP DATABASE mysqltest2|
|
||
|
||
# - Restore mysqltest1;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
--echo ---> Restoring mysqltest1...
|
||
--exec $MYSQL test < $sp_dump1
|
||
|
||
--echo ---> Restoring mysqltest2...
|
||
--exec $MYSQL test < $sp_dump2
|
||
|
||
--remove_file $sp_dump1
|
||
--remove_file $sp_dump2
|
||
|
||
#
|
||
# Third-round checks.
|
||
#
|
||
|
||
# - Change connection to flush SP-cache;
|
||
|
||
--connect (con3,localhost,root,,mysqltest1)
|
||
--echo
|
||
--echo ---> connection: con3
|
||
|
||
# - Switch environment variables and trigger loading stored procedures;
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
CALL p1(@a, @b)|
|
||
CALL p2(@a, @b)|
|
||
CALL mysqltest2.p3(@a, @b)|
|
||
CALL mysqltest2.p4(@a, @b)|
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_sp.inc
|
||
|
||
#
|
||
# Cleanup.
|
||
#
|
||
|
||
--connection default
|
||
--echo
|
||
--echo ---> connection: default
|
||
|
||
--disconnect con2
|
||
--disconnect con3
|
||
|
||
use test|
|
||
|
||
DROP DATABASE mysqltest1|
|
||
DROP DATABASE mysqltest2|
|
||
|
||
###########################################################################
|
||
#
|
||
# * Triggers.
|
||
#
|
||
###########################################################################
|
||
|
||
--echo
|
||
--echo -------------------------------------------------------------------
|
||
--echo Triggers
|
||
--echo -------------------------------------------------------------------
|
||
--echo
|
||
|
||
#
|
||
# Preparation:
|
||
#
|
||
|
||
# - Create database with fixed, pre-defined character set;
|
||
|
||
--disable_warnings
|
||
DROP DATABASE IF EXISTS mysqltest1|
|
||
DROP DATABASE IF EXISTS mysqltest2|
|
||
--enable_warnings
|
||
|
||
CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
CREATE DATABASE mysqltest2 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
|
||
use mysqltest1|
|
||
|
||
# - Create tables for triggers;
|
||
|
||
CREATE TABLE t1(c INT)|
|
||
CREATE TABLE mysqltest2.t1(c INT)|
|
||
|
||
# - Create log tables;
|
||
|
||
CREATE TABLE log(msg VARCHAR(255))|
|
||
CREATE TABLE mysqltest2.log(msg VARCHAR(255))|
|
||
|
||
|
||
# - Create triggers -- with and without explicit CHARSET-clause for
|
||
# SP-variable;
|
||
#
|
||
|
||
--echo
|
||
|
||
# - Trigger trg1
|
||
|
||
CREATE TRIGGER trg1 BEFORE INSERT ON t1 FOR EACH ROW
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10);
|
||
|
||
INSERT INTO log VALUES(COLLATION(ÐÅÒÅÍ1));
|
||
INSERT INTO log VALUES(COLLATION('ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_koi8r 'ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_utf8 'текÑ<C2BA>Ñ‚'));
|
||
INSERT INTO log VALUES(@@collation_connection);
|
||
INSERT INTO log VALUES(@@character_set_client);
|
||
|
||
SET @a1 = 'ÔÅËÓÔ';
|
||
SET @a1 = _koi8r 'ÔÅËÓÔ';
|
||
SET @a2 = _utf8 'текÑ<C2BA>Ñ‚';
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Trigger trg2
|
||
|
||
CREATE TRIGGER trg2 AFTER INSERT ON t1 FOR EACH ROW
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
INSERT INTO log VALUES(COLLATION(ÐÅÒÅÍ1));
|
||
INSERT INTO log VALUES(COLLATION('ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_koi8r 'ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_utf8 'текÑ<C2BA>Ñ‚'));
|
||
INSERT INTO log VALUES(@@collation_connection);
|
||
INSERT INTO log VALUES(@@character_set_client);
|
||
|
||
SET @b1 = 'ÔÅËÓÔ';
|
||
SET @b1 = _koi8r 'ÔÅËÓÔ';
|
||
SET @b2 = _utf8 'текÑ<C2BA>Ñ‚';
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Trigger trg3
|
||
|
||
CREATE TRIGGER mysqltest2.trg3 BEFORE INSERT ON mysqltest2.t1 FOR EACH ROW
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10);
|
||
|
||
INSERT INTO log VALUES(COLLATION(ÐÅÒÅÍ1));
|
||
INSERT INTO log VALUES(COLLATION('ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_koi8r 'ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_utf8 'текÑ<C2BA>Ñ‚'));
|
||
INSERT INTO log VALUES(@@collation_connection);
|
||
INSERT INTO log VALUES(@@character_set_client);
|
||
|
||
SET @a1 = 'ÔÅËÓÔ';
|
||
SET @a1 = _koi8r 'ÔÅËÓÔ';
|
||
SET @a2 = _utf8 'текÑ<C2BA>Ñ‚';
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Trigger trg4
|
||
|
||
CREATE TRIGGER mysqltest2.trg4 AFTER INSERT ON mysqltest2.t1 FOR EACH ROW
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
INSERT INTO log VALUES(COLLATION(ÐÅÒÅÍ1));
|
||
INSERT INTO log VALUES(COLLATION('ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_koi8r 'ÔÅËÓÔ'));
|
||
INSERT INTO log VALUES(COLLATION(_utf8 'текÑ<C2BA>Ñ‚'));
|
||
INSERT INTO log VALUES(@@collation_connection);
|
||
INSERT INTO log VALUES(@@character_set_client);
|
||
|
||
SET @b1 = 'ÔÅËÓÔ';
|
||
SET @b1 = _koi8r 'ÔÅËÓÔ';
|
||
SET @b2 = _utf8 'текÑ<C2BA>Ñ‚';
|
||
END|
|
||
|
||
--echo
|
||
|
||
#
|
||
# First-round checks.
|
||
#
|
||
|
||
--source include/ddl_i18n.check_triggers.inc
|
||
|
||
#
|
||
# Change running environment (alter database character set, change session
|
||
# variables).
|
||
#
|
||
|
||
--echo
|
||
--echo
|
||
|
||
ALTER DATABASE mysqltest1 COLLATE cp866_general_ci|
|
||
ALTER DATABASE mysqltest2 COLLATE cp866_general_ci|
|
||
|
||
#
|
||
# Second-round checks:
|
||
#
|
||
|
||
# - Flush table cache;
|
||
|
||
ALTER TABLE t1 ADD COLUMN fake INT|
|
||
ALTER TABLE t1 DROP COLUMN fake|
|
||
|
||
ALTER TABLE mysqltest2.t1 ADD COLUMN fake INT|
|
||
ALTER TABLE mysqltest2.t1 DROP COLUMN fake|
|
||
|
||
# - Switch environment variables and initiate loading of triggers
|
||
# (connect using NULL database);
|
||
|
||
--connect (con2,localhost,root,,)
|
||
--echo
|
||
--echo ---> connection: con2
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
INSERT INTO mysqltest1.t1 VALUES(0)|
|
||
INSERT INTO mysqltest2.t1 VALUES(0)|
|
||
|
||
DELETE FROM mysqltest1.log|
|
||
DELETE FROM mysqltest2.log|
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
use mysqltest1|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_triggers.inc
|
||
|
||
#
|
||
# Check mysqldump.
|
||
#
|
||
|
||
# - Dump mysqltest1, mysqltest2;
|
||
|
||
--let $triggers_dump1 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.triggers.mysqltest1.sql
|
||
--let $triggers_dump2 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.triggers.mysqltest2.sql
|
||
|
||
--echo
|
||
--echo ---> Dump of mysqltest1
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --triggers --databases mysqltest1
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest1 to ddl_i18n_koi8r.triggers.mysqltest1.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --triggers --databases mysqltest1 > $triggers_dump1
|
||
|
||
--echo
|
||
--echo ---> Dump of mysqltest2
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --triggers --databases mysqltest2
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest2 to ddl_i18n_koi8r.triggers.mysqltest2.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --triggers --databases mysqltest2 > $triggers_dump2
|
||
|
||
# - Clean mysqltest1, mysqltest2;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
DROP DATABASE mysqltest1|
|
||
DROP DATABASE mysqltest2|
|
||
|
||
# - Restore mysqltest1;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
--echo ---> Restoring mysqltest1...
|
||
--exec $MYSQL test < $triggers_dump1
|
||
|
||
--echo ---> Restoring mysqltest2...
|
||
--exec $MYSQL test < $triggers_dump2
|
||
|
||
--remove_file $triggers_dump1
|
||
--remove_file $triggers_dump2
|
||
|
||
#
|
||
# Third-round checks.
|
||
#
|
||
|
||
# - Flush table cache;
|
||
|
||
ALTER TABLE mysqltest1.t1 ADD COLUMN fake INT|
|
||
ALTER TABLE mysqltest1.t1 DROP COLUMN fake|
|
||
|
||
ALTER TABLE mysqltest2.t1 ADD COLUMN fake INT|
|
||
ALTER TABLE mysqltest2.t1 DROP COLUMN fake|
|
||
|
||
# - Switch environment variables and initiate loading of triggers
|
||
# (connect using NULL database);
|
||
|
||
--connect (con3,localhost,root,,)
|
||
--echo
|
||
--echo ---> connection: con3
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
INSERT INTO mysqltest1.t1 VALUES(0)|
|
||
INSERT INTO mysqltest2.t1 VALUES(0)|
|
||
|
||
DELETE FROM mysqltest1.log|
|
||
DELETE FROM mysqltest2.log|
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
use mysqltest1|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_triggers.inc
|
||
|
||
#
|
||
# Cleanup.
|
||
#
|
||
|
||
--connection default
|
||
--echo
|
||
--echo ---> connection: default
|
||
|
||
--disconnect con2
|
||
--disconnect con3
|
||
|
||
use test|
|
||
|
||
DROP DATABASE mysqltest1|
|
||
DROP DATABASE mysqltest2|
|
||
|
||
###########################################################################
|
||
#
|
||
# * Events
|
||
#
|
||
# We don't have EXECUTE EVENT so far, so this test is limited. It checks that
|
||
# event with non-latin1 symbols can be created, dumped, restored and SHOW
|
||
# statements work properly.
|
||
#
|
||
###########################################################################
|
||
|
||
--echo
|
||
--echo -------------------------------------------------------------------
|
||
--echo Events
|
||
--echo -------------------------------------------------------------------
|
||
--echo
|
||
|
||
#
|
||
# Preparation:
|
||
#
|
||
|
||
# - Create database with fixed, pre-defined character set.
|
||
|
||
--disable_warnings
|
||
DROP DATABASE IF EXISTS mysqltest1|
|
||
DROP DATABASE IF EXISTS mysqltest2|
|
||
--enable_warnings
|
||
|
||
CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
CREATE DATABASE mysqltest2 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
|
||
use mysqltest1|
|
||
|
||
# - Create two stored routines -- with and without explicit
|
||
# CHARSET-clause for SP-variable;
|
||
#
|
||
|
||
--echo
|
||
|
||
# - Event ev1
|
||
|
||
CREATE EVENT ev1 ON SCHEDULE AT '2030-01-01 00:00:00' DO
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10);
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION('ÔÅËÓÔ') AS c2,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c3,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c4,
|
||
@@collation_connection AS c5,
|
||
@@character_set_client AS c6;
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Event ev2
|
||
|
||
CREATE EVENT ev2 ON SCHEDULE AT '2030-01-01 00:00:00' DO
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION('ÔÅËÓÔ') AS c2,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c3,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c4,
|
||
@@collation_connection AS c5,
|
||
@@character_set_client AS c6;
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Event ev3
|
||
|
||
CREATE EVENT mysqltest2.ev3 ON SCHEDULE AT '2030-01-01 00:00:00' DO
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION('ÔÅËÓÔ') AS c2,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c3,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c4,
|
||
@@collation_connection AS c5,
|
||
@@character_set_client AS c6;
|
||
END|
|
||
|
||
--echo
|
||
|
||
# - Event ev4
|
||
|
||
CREATE EVENT mysqltest2.ev4 ON SCHEDULE AT '2030-01-01 00:00:00' DO
|
||
BEGIN
|
||
DECLARE ÐÅÒÅÍ1 CHAR(10) CHARACTER SET utf8;
|
||
|
||
SELECT
|
||
COLLATION(ÐÅÒÅÍ1) AS c1,
|
||
COLLATION('ÔÅËÓÔ') AS c2,
|
||
COLLATION(_koi8r 'ÔÅËÓÔ') AS c3,
|
||
COLLATION(_utf8 'текÑ<C2BA>Ñ‚') AS c4,
|
||
@@collation_connection AS c5,
|
||
@@character_set_client AS c6;
|
||
END|
|
||
|
||
--echo
|
||
|
||
|
||
#
|
||
# First-round checks.
|
||
#
|
||
|
||
--source include/ddl_i18n.check_events.inc
|
||
|
||
#
|
||
# Change running environment (alter database character set, change session
|
||
# variables).
|
||
#
|
||
|
||
--echo
|
||
--echo
|
||
|
||
ALTER DATABASE mysqltest1 COLLATE cp866_general_ci|
|
||
ALTER DATABASE mysqltest2 COLLATE cp866_general_ci|
|
||
|
||
#
|
||
# Second-round checks:
|
||
#
|
||
|
||
# - Change connection to flush cache;
|
||
|
||
--connect (con2,localhost,root,,mysqltest1)
|
||
--echo
|
||
--echo ---> connection: con2
|
||
|
||
# - Switch environment variables and trigger loading stored procedures;
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
--disable_result_log
|
||
SHOW CREATE EVENT ev1|
|
||
SHOW CREATE EVENT ev2|
|
||
SHOW CREATE EVENT mysqltest2.ev3|
|
||
SHOW CREATE EVENT mysqltest2.ev4|
|
||
--enable_result_log
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_events.inc
|
||
|
||
#
|
||
# Check mysqldump.
|
||
#
|
||
|
||
# - Dump mysqltest1, mysqltest2;
|
||
|
||
--let $events_dump1 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.events.mysqltest1.sql
|
||
--let $events_dump2 = $MYSQLTEST_VARDIR/tmp/ddl_i18n_koi8r.events.mysqltest2.sql
|
||
|
||
--echo
|
||
--echo ---> Dump of mysqltest1
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --events --databases mysqltest1
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest1 to ddl_i18n_koi8r.events.mysqltest1.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --events --databases mysqltest1 > $events_dump1
|
||
|
||
--echo
|
||
--echo ---> Dump of mysqltest2
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --events --databases mysqltest2
|
||
|
||
--echo
|
||
--echo ---> Dumping mysqltest2 to ddl_i18n_koi8r.events.mysqltest2.sql
|
||
|
||
--exec $MYSQL_DUMP --character-sets-dir=$MYSQL_SHAREDIR/charsets --compact --events --databases mysqltest2 > $events_dump2
|
||
|
||
# - Clean mysqltest1, mysqltest2;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
DROP DATABASE mysqltest1|
|
||
DROP DATABASE mysqltest2|
|
||
|
||
# - Restore mysqltest1;
|
||
|
||
--echo
|
||
--echo
|
||
|
||
--echo ---> Restoring mysqltest1...
|
||
--exec $MYSQL test < $events_dump1
|
||
|
||
--echo ---> Restoring mysqltest2...
|
||
--exec $MYSQL test < $events_dump2
|
||
|
||
--remove_file $events_dump1
|
||
--remove_file $events_dump2
|
||
|
||
#
|
||
# Third-round checks.
|
||
#
|
||
|
||
# - Change connection to flush cache;
|
||
|
||
--connect (con3,localhost,root,,mysqltest1)
|
||
--echo
|
||
--echo ---> connection: con3
|
||
|
||
# - Switch environment variables and trigger loading stored procedures;
|
||
|
||
SET @@character_set_client= cp1251|
|
||
SET @@character_set_results= cp1251|
|
||
SET @@collation_connection= cp1251_general_ci|
|
||
|
||
--disable_result_log
|
||
SHOW CREATE EVENT ev1|
|
||
SHOW CREATE EVENT ev2|
|
||
SHOW CREATE EVENT mysqltest2.ev3|
|
||
SHOW CREATE EVENT mysqltest2.ev4|
|
||
--enable_result_log
|
||
|
||
# - Restore environment;
|
||
|
||
set names koi8r|
|
||
|
||
# - Check!
|
||
|
||
--source include/ddl_i18n.check_events.inc
|
||
|
||
###########################################################################
|
||
#
|
||
# * DDL statements inside stored routine.
|
||
#
|
||
# Here we check that DDL statements use actual database collation even if they
|
||
# are called from stored routine.
|
||
#
|
||
###########################################################################
|
||
|
||
--echo
|
||
--echo -------------------------------------------------------------------
|
||
--echo DDL statements within stored routine.
|
||
--echo -------------------------------------------------------------------
|
||
--echo
|
||
|
||
#
|
||
# Preparation:
|
||
#
|
||
|
||
# - Create database with fixed, pre-defined character set.
|
||
|
||
--disable_warnings
|
||
DROP DATABASE IF EXISTS mysqltest1|
|
||
DROP DATABASE IF EXISTS mysqltest2|
|
||
--enable_warnings
|
||
|
||
CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
CREATE DATABASE mysqltest2 DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci|
|
||
|
||
use mysqltest1|
|
||
|
||
# - Create procedures;
|
||
|
||
--echo
|
||
|
||
CREATE PROCEDURE p1()
|
||
BEGIN
|
||
CREATE TABLE t1(col1 VARCHAR(10));
|
||
SHOW CREATE TABLE t1;
|
||
END|
|
||
|
||
--echo
|
||
|
||
CREATE PROCEDURE mysqltest2.p2()
|
||
BEGIN
|
||
CREATE TABLE t2(col1 VARCHAR(10));
|
||
SHOW CREATE TABLE t2;
|
||
END|
|
||
|
||
--echo
|
||
|
||
#
|
||
# First-round checks.
|
||
#
|
||
|
||
CALL p1()|
|
||
|
||
--echo
|
||
|
||
SHOW CREATE TABLE t1|
|
||
|
||
--echo
|
||
--echo
|
||
|
||
CALL mysqltest2.p2()|
|
||
|
||
--echo
|
||
|
||
SHOW CREATE TABLE mysqltest2.t2|
|
||
|
||
#
|
||
# Alter database.
|
||
#
|
||
|
||
--echo
|
||
|
||
ALTER DATABASE mysqltest1 COLLATE cp1251_general_cs|
|
||
ALTER DATABASE mysqltest2 COLLATE cp1251_general_cs|
|
||
|
||
DROP TABLE t1|
|
||
DROP TABLE mysqltest2.t2|
|
||
|
||
--echo
|
||
|
||
#
|
||
# Second-round checks.
|
||
#
|
||
|
||
CALL p1()|
|
||
|
||
--echo
|
||
|
||
SHOW CREATE TABLE t1|
|
||
|
||
--echo
|
||
--echo
|
||
|
||
CALL mysqltest2.p2()|
|
||
|
||
--echo
|
||
|
||
SHOW CREATE TABLE mysqltest2.t2|
|
||
|
||
###########################################################################
|
||
#
|
||
# That's it.
|
||
#
|
||
###########################################################################
|
||
|
||
#
|
||
# Cleanup.
|
||
#
|
||
delimiter ;|
|
||
|
||
--connection con2
|
||
--echo
|
||
--echo ---> connection: con2
|
||
--disconnect con2
|
||
--source include/wait_until_disconnected.inc
|
||
--connection con3
|
||
--echo
|
||
--echo ---> connection: con3
|
||
--disconnect con3
|
||
--source include/wait_until_disconnected.inc
|
||
--connection default
|
||
--echo
|
||
--echo ---> connection: default
|
||
USE test;
|
||
DROP DATABASE mysqltest1;
|
||
DROP DATABASE mysqltest2;
|
||
|