mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 21:12:26 +01:00
33294b1b50
- BUG#15934: Instance manager fails to work; - BUG#18020: IM connect problem; - BUG#18027: IM: Server_ID differs; - BUG#18033: IM: Server_ID not reported; - BUG#21331: Instance Manager: Connect problems in tests; The only test suite has been changed (server codebase has not been modified). BitKeeper/deleted/.del-im_check_os.inc: Rename: mysql-test/include/im_check_os.inc -> BitKeeper/deleted/.del-im_check_os.inc mysql-test/include/im_check_env.inc: Include only this file from all IM-tests. mysql-test/lib/mtr_io.pl: Update mtr_get_pid_from_file() to workaround race, described in BUG#21884. mysql-test/lib/mtr_process.pl: Refactor im_start()/im_stop() so that they will be more reliable. There are the following user-visible changes: - if one of these functions fails, the test suite is aborted; - mtr_im_stop() now determines whether the component is alive or not not only by checking PID, but also by trying to connect to the component; - after starting IM, the test suite waits for it to start accepting client connections and to start all its guarded mysqld instances; - a lot of debug-logs have been added in order to simplify investigation of future failures. mysql-test/mysql-test-run.pl: 1. Get rid of kill_and_cleanup(); 2. Move im_start()/im_stop() to mtr_process.pl; 3. Change default IM port to 9311 so that it does not interfere with default slave port; mysql-test/r/im_daemon_life_cycle.result: Updated result file. mysql-test/r/im_life_cycle.result: Updated result file. mysql-test/r/im_options_set.result: Updated result file. mysql-test/r/im_options_unset.result: Updated result file. mysql-test/r/im_utils.result: Updated result file. mysql-test/t/im_daemon_life_cycle.imtest: Updated IM-test. mysql-test/t/im_life_cycle.imtest: Updated IM-test. mysql-test/t/im_options_set.imtest: Updated IM-test. mysql-test/t/im_options_unset.imtest: Updated IM-test. mysql-test/t/im_utils.imtest: Updated IM-test.
116 lines
3.7 KiB
Text
116 lines
3.7 KiB
Text
###########################################################################
|
|
#
|
|
# This file contains test for (3) test suite.
|
|
#
|
|
# Consult WL#2789 for more information.
|
|
#
|
|
###########################################################################
|
|
|
|
#
|
|
# Check the options-management commands:
|
|
# - SET;
|
|
# - FLUSH INSTANCES;
|
|
#
|
|
# Let's test the commands on the option 'server_id'. It's expected that
|
|
# originally the instances have the following server ids:
|
|
# - mysqld1: 1
|
|
# - mysqld2: 2
|
|
#
|
|
# 1. SET <instance_id>.server_id= SERVER_ID); where SERVER_ID is 11 or 12.
|
|
# 1.1. check that the configuration file has been updated (i.e. contains
|
|
# server_id=SERVER_ID for the instance);
|
|
# 1.2. (for mysqld1) check that the running instance has not been affected:
|
|
# connect to the instance and check that 'SHOW VARIABLES LIKE 'server_id''
|
|
# returns zero;
|
|
# 1.3. check that internal cache of Instance Manager has not been affected
|
|
# (i.e. SHOW INSTANCE OPTIONS <instance> does not contain updated value).
|
|
#
|
|
# 2. FLUSH INSTANCES;
|
|
# 2.1. check that the configuration file has not been updated;
|
|
# 2.2. (for mysqld1) check that the running instance has not been affected:
|
|
# connect to the instance and check that 'SHOW VARIABLES LIKE 'server_id''
|
|
# returns zero value;
|
|
# 2.3. check that internal cache of Instance Manager has been updated (i.e.
|
|
# SHOW INSTANCE OPTIONS <instance> contains 'server_id=SERVER_ID' line).
|
|
#
|
|
# 3. Restore options.
|
|
#
|
|
|
|
###########################################################################
|
|
|
|
--source include/im_check_env.inc
|
|
|
|
###########################################################################
|
|
#
|
|
# 1. SET <instance_id>.server_id= SERVER_ID); where SERVER_ID is 11 or 12.
|
|
#
|
|
###########################################################################
|
|
|
|
# * mysqld1
|
|
|
|
SET mysqld1.server_id = 11;
|
|
|
|
# - check that the configuration file has been updated (i.e. contains
|
|
# server_id=SERVER_ID for the instance);
|
|
|
|
--exec grep server_id $MYSQLTEST_VARDIR/im.cnf ;
|
|
|
|
# - (for mysqld1) check that the running instance has not been affected:
|
|
# connect to the instance and check that 'SHOW VARIABLES LIKE 'server_id''
|
|
# returns zero;
|
|
|
|
--connection mysql1_con
|
|
|
|
SHOW VARIABLES LIKE 'server_id';
|
|
|
|
--connection default
|
|
|
|
# - check that internal cache of Instance Manager has not been affected
|
|
# (i.e. SHOW INSTANCE OPTIONS <instance> does not contain updated value).
|
|
# TODO: we should check only server_id option here.
|
|
|
|
# SHOW INSTANCE OPTIONS mysqld1;
|
|
|
|
# * mysqld2
|
|
|
|
SET mysqld2.server_id = 12;
|
|
|
|
# - check that the configuration file has been updated (i.e. contains
|
|
# server_id=SERVER_ID for the instance);
|
|
|
|
--exec grep server_id $MYSQLTEST_VARDIR/im.cnf ;
|
|
|
|
# - check that internal cache of Instance Manager has not been affected
|
|
# (i.e. SHOW INSTANCE OPTIONS <instance> does not contain updated value).
|
|
# TODO: we should check only server_id option here.
|
|
|
|
# SHOW INSTANCE OPTIONS mysqld2;
|
|
|
|
###########################################################################
|
|
#
|
|
# 2. FLUSH INSTANCES;
|
|
#
|
|
###########################################################################
|
|
|
|
FLUSH INSTANCES;
|
|
|
|
# - check that the configuration file has not been updated;
|
|
|
|
--exec grep server_id $MYSQLTEST_VARDIR/im.cnf ;
|
|
|
|
# - (for mysqld1) check that the running instance has not been affected:
|
|
# connect to the instance and check that 'SHOW VARIABLES LIKE 'server_id''
|
|
# returns zero value;
|
|
|
|
--connection mysql1_con
|
|
|
|
SHOW VARIABLES LIKE 'server_id';
|
|
|
|
--connection default
|
|
|
|
# - check that internal cache of Instance Manager has been updated (i.e.
|
|
# SHOW INSTANCE OPTIONS <instance> contains 'server_id=' line).
|
|
# TODO: we should check only server_id option here.
|
|
|
|
# SHOW INSTANCE OPTIONS mysqld1;
|
|
# SHOW INSTANCE OPTIONS mysqld2;
|