2002-12-05 14:01:15 +03:00
|
|
|
# This test is to check various cases of connections
|
2005-10-12 13:56:07 +02:00
|
|
|
# with right and wrong password, with and without database
|
|
|
|
# Unfortunately the check is incomplete as we can't connect without database
|
2002-12-05 14:01:15 +03:00
|
|
|
|
2005-03-29 15:50:16 -08:00
|
|
|
# This test makes no sense with the embedded server
|
|
|
|
--source include/not_embedded.inc
|
|
|
|
|
2006-01-19 05:56:06 +03:00
|
|
|
# check that CSV engine was compiled in, as the test relies on the presence
|
|
|
|
# of the log tables (which are CSV-based). By connect mysql; show tables;
|
|
|
|
--source include/have_csv.inc
|
|
|
|
|
2005-09-08 12:09:30 +04:00
|
|
|
--disable_warnings
|
|
|
|
drop table if exists t1,t2;
|
|
|
|
--enable_warnings
|
|
|
|
|
2005-10-12 13:56:07 +02:00
|
|
|
|
2002-12-05 14:01:15 +03:00
|
|
|
#connect (con1,localhost,root,,"");
|
|
|
|
#show tables;
|
|
|
|
connect (con1,localhost,root,,mysql);
|
|
|
|
show tables;
|
2005-10-12 13:56:07 +02:00
|
|
|
connect (con2,localhost,root,,test);
|
2002-12-05 14:01:15 +03:00
|
|
|
show tables;
|
|
|
|
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,root,z,test2);
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,root,z,);
|
2002-12-05 14:01:15 +03:00
|
|
|
|
|
|
|
grant ALL on *.* to test@localhost identified by "gambling";
|
|
|
|
grant ALL on *.* to test@127.0.0.1 identified by "gambling";
|
|
|
|
|
|
|
|
# Now check this user with different databases
|
|
|
|
#connect (con1,localhost,test,gambling,"");
|
|
|
|
#show tables;
|
2005-10-12 13:56:07 +02:00
|
|
|
connect (con3,localhost,test,gambling,mysql);
|
2002-12-05 14:01:15 +03:00
|
|
|
show tables;
|
2005-10-12 13:56:07 +02:00
|
|
|
connect (con4,localhost,test,gambling,test);
|
2002-12-05 14:01:15 +03:00
|
|
|
show tables;
|
|
|
|
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,,test2);
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,,"");
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,zorro,test2);
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,zorro,);
|
2002-12-05 14:01:15 +03:00
|
|
|
|
|
|
|
|
|
|
|
# check if old password version also works
|
2004-07-08 18:54:07 +05:00
|
|
|
update mysql.user set password=old_password("gambling2") where user=_binary"test";
|
2002-12-05 14:01:15 +03:00
|
|
|
flush privileges;
|
|
|
|
|
2005-10-12 13:56:07 +02:00
|
|
|
connect (con10,localhost,test,gambling2,);
|
|
|
|
connect (con5,localhost,test,gambling2,mysql);
|
2006-10-03 15:33:44 +02:00
|
|
|
connection con5;
|
2004-08-26 18:26:38 +03:00
|
|
|
set password="";
|
2004-10-28 14:02:09 +03:00
|
|
|
--error 1372
|
2004-07-30 22:05:08 +02:00
|
|
|
set password='gambling3';
|
2003-07-08 02:36:14 +04:00
|
|
|
set password=old_password('gambling3');
|
2002-12-05 14:01:15 +03:00
|
|
|
show tables;
|
2005-10-12 13:56:07 +02:00
|
|
|
connect (con6,localhost,test,gambling3,test);
|
2002-12-05 14:01:15 +03:00
|
|
|
show tables;
|
|
|
|
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,,test2);
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,,);
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,zorro,test2);
|
2005-11-07 22:30:44 +01:00
|
|
|
--replace_result $MASTER_MYSOCK MASTER_SOCKET $MASTER_MYPORT MASTER_PORT
|
2005-10-12 13:56:07 +02:00
|
|
|
--error 1045
|
|
|
|
connect (fail_con,localhost,test,zorro,);
|
2003-06-13 11:17:31 +02:00
|
|
|
|
2003-07-08 02:36:14 +04:00
|
|
|
|
2003-06-13 11:17:31 +02:00
|
|
|
# remove user 'test' so that other tests which may use 'test'
|
|
|
|
# do not depend on this test.
|
2003-07-08 02:36:14 +04:00
|
|
|
|
2004-07-08 18:54:07 +05:00
|
|
|
delete from mysql.user where user=_binary"test";
|
2003-06-13 11:17:31 +02:00
|
|
|
flush privileges;
|
2005-07-28 03:22:47 +03:00
|
|
|
|
2005-09-08 12:09:30 +04:00
|
|
|
#
|
|
|
|
# Bug#12517: Clear user variables and replication events before
|
|
|
|
# closing temp tables in thread cleanup.
|
2005-10-12 13:56:07 +02:00
|
|
|
connect (con7,localhost,root,,test);
|
|
|
|
connection con7;
|
2005-08-30 17:22:19 +04:00
|
|
|
create table t1 (id integer not null auto_increment primary key);
|
|
|
|
create temporary table t2(id integer not null auto_increment primary key);
|
|
|
|
set @id := 1;
|
|
|
|
delete from t1 where id like @id;
|
2005-10-12 13:56:07 +02:00
|
|
|
disconnect con7;
|
2005-09-08 12:09:30 +04:00
|
|
|
--sleep 5
|
|
|
|
connection default;
|
|
|
|
drop table t1;
|
2005-08-30 17:22:19 +04:00
|
|
|
|
2008-03-12 17:44:40 +03:00
|
|
|
--disconnect con1
|
|
|
|
--disconnect con2
|
|
|
|
--disconnect con3
|
|
|
|
--disconnect con4
|
|
|
|
--disconnect con5
|
|
|
|
--disconnect con6
|
|
|
|
--disconnect con10
|
|
|
|
|
|
|
|
--echo # ------------------------------------------------------------------
|
|
|
|
--echo # -- End of 4.1 tests
|
|
|
|
--echo # ------------------------------------------------------------------
|
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
###########################################################################
|
|
|
|
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo
|
|
|
|
--echo # -- Bug#33507: Event scheduler creates more threads than max_connections
|
|
|
|
--echo # -- which results in user lockout.
|
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
2008-03-12 17:44:40 +03:00
|
|
|
GRANT USAGE ON *.* TO mysqltest_u1@localhost;
|
|
|
|
|
|
|
|
# NOTE: if the test case fails sporadically due to spurious connections,
|
|
|
|
# consider disabling all users.
|
|
|
|
|
|
|
|
--echo
|
|
|
|
let $saved_max_connections = `SELECT @@global.max_connections`;
|
|
|
|
SET GLOBAL max_connections = 3;
|
|
|
|
SET GLOBAL event_scheduler = ON;
|
|
|
|
|
|
|
|
--echo
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo # -- Waiting for Event Scheduler to start...
|
2008-03-12 17:44:40 +03:00
|
|
|
let $wait_condition =
|
|
|
|
SELECT COUNT(*) = 1
|
|
|
|
FROM information_schema.processlist
|
|
|
|
WHERE user = 'event_scheduler';
|
|
|
|
--source include/wait_condition.inc
|
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo # -- Disconnecting default connection...
|
|
|
|
--disconnect default
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Check that we allow exactly three user connections, no matter how
|
|
|
|
--echo # -- many threads are running.
|
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo # -- Connecting (1)...
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
let $con_name = con_1;
|
|
|
|
let $con_user_name = mysqltest_u1;
|
|
|
|
--source include/connect2.inc
|
2008-03-12 17:44:40 +03:00
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Connecting (2)...
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
let $con_name = con_2;
|
|
|
|
let $con_user_name = mysqltest_u1;
|
|
|
|
--source include/connect2.inc
|
2008-03-12 17:44:40 +03:00
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo # -- Connecting (3)...
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
let $con_name = con_3;
|
|
|
|
let $con_user_name = mysqltest_u1;
|
|
|
|
--source include/connect2.inc
|
2008-03-12 17:44:40 +03:00
|
|
|
|
|
|
|
--echo
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo # -- Connecting (4) [should fail]...
|
|
|
|
let $con_name = con_4;
|
|
|
|
let $con_user_name = mysqltest_u1;
|
|
|
|
let $wait_timeout = 5;
|
|
|
|
--source include/connect2.inc
|
2008-03-12 17:44:40 +03:00
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Check that we allow one extra SUPER-user connection.
|
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo # -- Connecting super (1)...
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
let $con_name = con_super_1;
|
|
|
|
let $con_user_name = root;
|
|
|
|
--source include/connect2.inc
|
2008-03-12 17:44:40 +03:00
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
|
|
|
--echo # -- Connecting super (2) [should fail]...
|
|
|
|
let $con_name = con_super_2;
|
|
|
|
let $con_user_name = root;
|
|
|
|
let $wait_timeout = 5;
|
|
|
|
--source include/connect2.inc
|
2008-03-12 17:44:40 +03:00
|
|
|
|
|
|
|
--echo
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo # -- Ensure that we have Event Scheduler thread, 3 ordinary user
|
|
|
|
--echo # -- connections and one extra super-user connection.
|
2008-03-12 17:44:40 +03:00
|
|
|
SELECT user FROM information_schema.processlist ORDER BY id;
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Resetting variables...
|
|
|
|
--eval SET GLOBAL max_connections = $saved_max_connections
|
2008-03-13 12:02:12 +03:00
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Stopping Event Scheduler...
|
2008-03-12 17:44:40 +03:00
|
|
|
SET GLOBAL event_scheduler = OFF;
|
|
|
|
|
Avoid races in connect.test.
The problem was in a test case for Bug33507:
- when the number of active connections reaches the limit,
the server accepts only root connections. That's achieved by
accepting a connection, negotiating with the client and
checking user credentials. If it is not SUPER, the connection
is dropped.
- when the server accepts connection, it increases the counter;
- when the server drops connection, it decreases the counter;
- the race was in between of decreasing the counter and accepting
new connection:
- max_user_connections = 2;
- 2 oridinary user connections accepted;
- extra user connection is establishing;
- server checked user credentials, and sent 'Too many connections'
error;
- the client receives the error and establishes extra SUPER user
connection;
- the server however didn't decrease the counter (the extra
user connection still is "alive" in the server) -- so, the new
SUPER-user connection, will be dropped, because it exceeds
(max_user_connections + 1).
The fix is to implement "safe connect", which makes several attempts
to connect and use it in the test script.
2008-03-17 14:26:00 +03:00
|
|
|
--echo
|
2008-03-13 12:02:12 +03:00
|
|
|
--echo # -- Waiting for Event Scheduler to stop...
|
|
|
|
let $wait_condition =
|
|
|
|
SELECT COUNT(*) = 0
|
|
|
|
FROM information_schema.processlist
|
|
|
|
WHERE user = 'event_scheduler';
|
|
|
|
--source include/wait_condition.inc
|
|
|
|
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo
|
|
|
|
--echo # -- That's it. Closing connections...
|
|
|
|
--disconnect con_1
|
|
|
|
--disconnect con_2
|
2008-03-13 12:02:12 +03:00
|
|
|
--disconnect con_3
|
2008-03-12 17:44:40 +03:00
|
|
|
--disconnect con_super_1
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Restoring default connection...
|
|
|
|
--connect (default,localhost,root,,test)
|
|
|
|
|
2008-03-13 12:02:12 +03:00
|
|
|
--echo
|
|
|
|
--echo # -- Waiting for connections to close...
|
|
|
|
let $wait_condition =
|
|
|
|
SELECT COUNT(*) = 1
|
|
|
|
FROM information_schema.processlist
|
|
|
|
WHERE db = 'test';
|
|
|
|
--source include/wait_condition.inc
|
|
|
|
|
|
|
|
--echo
|
|
|
|
DROP USER mysqltest_u1@localhost;
|
|
|
|
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo
|
|
|
|
--echo # -- End of Bug#33507.
|
|
|
|
--echo
|
|
|
|
|
2008-03-13 12:02:12 +03:00
|
|
|
###########################################################################
|
|
|
|
|
|
|
|
--echo # -- Bug#35074: max_used_connections is not correct.
|
|
|
|
--echo
|
|
|
|
|
|
|
|
FLUSH STATUS;
|
|
|
|
|
|
|
|
--echo
|
|
|
|
SHOW STATUS LIKE 'max_used_connections';
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Starting Event Scheduler...
|
|
|
|
SET GLOBAL event_scheduler = ON;
|
|
|
|
|
|
|
|
--echo # -- Waiting for Event Scheduler to start...
|
|
|
|
let $wait_condition =
|
|
|
|
SELECT COUNT(*) = 1
|
|
|
|
FROM information_schema.processlist
|
|
|
|
WHERE user = 'event_scheduler';
|
|
|
|
--source include/wait_condition.inc
|
|
|
|
|
|
|
|
# NOTE: We should use a new connection here instead of reconnect in order to
|
|
|
|
# avoid races (we can not for sure when the connection being disconnected is
|
|
|
|
# actually disconnected on the server).
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Opening a new connection to check max_used_connections...
|
|
|
|
--connect (con_1,localhost,root)
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Check that max_used_connections hasn't changed.
|
|
|
|
SHOW STATUS LIKE 'max_used_connections';
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Closing new connection...
|
|
|
|
--disconnect con_1
|
|
|
|
--connection default
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- Stopping Event Scheduler...
|
|
|
|
SET GLOBAL event_scheduler = OFF;
|
|
|
|
|
|
|
|
--echo # -- Waiting for Event Scheduler to stop...
|
|
|
|
let $wait_condition =
|
|
|
|
SELECT COUNT(*) = 0
|
|
|
|
FROM information_schema.processlist
|
|
|
|
WHERE user = 'event_scheduler';
|
|
|
|
--source include/wait_condition.inc
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo # -- End of Bug#35074.
|
|
|
|
--echo
|
|
|
|
|
2008-03-12 17:44:40 +03:00
|
|
|
--echo # ------------------------------------------------------------------
|
|
|
|
--echo # -- End of 5.1 tests
|
|
|
|
--echo # ------------------------------------------------------------------
|