config root man

Current Path : /compat/linux/proc/self/root/usr/opt/mysql57/mysql-test/suite/x/r/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : //compat/linux/proc/self/root/usr/opt/mysql57/mysql-test/suite/x/r/admin_xkill.result

install plugin mysqlx soname "mysqlx.so";
call mtr.add_suppression("Plugin mysqlx reported: .Failed at SSL configuration: .SSL context is not usable without certificate and private key..");
call mtr.add_suppression("Plugin mysqlx reported: .SSL_CTX_load_verify_locations failed.");
call mtr.add_suppression("Plugin mysqlx reported: 'Unhandled network error: Bad file descriptor'");
create user sslcon@localhost identified by 'sslcon';
grant all on *.* to sslcon@localhost;
RUN create user abc@localhost identified by 'abc'

0 rows affected
RUN create user xplugin@localhost identified by 'xplugin'

0 rows affected
RUN grant all on *.* to xplugin@localhost

0 rows affected
RUN create user process@localhost identified by 'process'

0 rows affected
RUN grant process on *.* to process@localhost

0 rows affected
RUN create user expire@localhost identified by 'expire'

0 rows affected
RUN grant all on *.* to expire@localhost

0 rows affected
RUN alter user expire@localhost password expire

0 rows affected
RUN select sleep(1)
sleep(1)
0
0 rows affected
Test data
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	sql_session
1	root	localhost	$SESSION
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
create and activate new session
connecting...
active session is now 'aux'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
2	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0 even with another new root session
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
switch back to default session
switched to session default
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
2	root	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=0 with default root session where list_clients already executed
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	2
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 2
    }
  }
  namespace: "xplugin"
}


command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
command ok
expect Mysqlx_stmt_list_clients=3 and Mysqlx_stmt_kill_client=1 with default root session where list_clients executed 3 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	3
0 rows affected
create and activate new session abc
expect only abc user session id 
connecting...
active session is now 'abc'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
3	abc	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
killing root user session with unprivileged user 'abc' which should be unsuccessful
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 1
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: You are not owner of thread (code 1095)
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=1 with session abc where list_clients and kill_client executed once
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	1
0 rows affected
RUN select user(),current_user()
user()	current_user()
abc@localhost	abc@localhost
0 rows affected
RUN show grants
Grants for abc@localhost
GRANT USAGE ON *.* TO 'abc'@'localhost'
0 rows affected
open another session of abc user and kill first session of abc user,which should be successful
connecting...
active session is now 'abc1'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
3	abc	localhost
4	abc	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 3
    }
  }
  namespace: "xplugin"
}


command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
4	abc	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=1 with new session abc where list_clients executed twice and kill_client executed once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	2
0 rows affected
RUN select user(),current_user()
user()	current_user()
abc@localhost	abc@localhost
0 rows affected
RUN show grants
Grants for abc@localhost
GRANT USAGE ON *.* TO 'abc'@'localhost'
0 rows affected
killing abc user session with its own session 'abc' which should be successful
expect right error instead of End of File
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 4
    }
  }
  namespace: "xplugin"
}

Server disconnected
closing session abc1
switched to session default
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
switch back to default session
switched to session default
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
command ok
expect Mysqlx_stmt_list_clients=4 and Mysqlx_stmt_kill_client=1 with default root session where list_clients executed 4 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	4
0 rows affected
RUN select user(),current_user()
user()	current_user()
root@localhost	root@localhost
0 rows affected
RUN show grants
Grants for root@localhost
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION
0 rows affected
open process only privileged user seession and kill root user session,expect error "You are not owner of thread"
connecting...
active session is now 'process'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
5	process	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 1
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: You are not owner of thread (code 1095)
checking list of clients after root user session killed by xplugin user
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
5	process	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=1 with process user where list_clients executed 2 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	2
0 rows affected
RUN select user(),current_user()
user()	current_user()
process@localhost	process@localhost
0 rows affected
RUN show grants
Grants for process@localhost
GRANT PROCESS ON *.* TO 'process'@'localhost'
0 rows affected
open privileged user seession and kill root user session,expect success
connecting...
active session is now 'xplugin'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
1	root	localhost
5	process	localhost
6	xplugin	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 1
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk

command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
checking list of clients after root user session killed by xplugin user
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
5	process	localhost
6	xplugin	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=1 with xplugin user where list_clients executed 2 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	2
0 rows affected
RUN select user(),current_user()
user()	current_user()
xplugin@localhost	xplugin@localhost
0 rows affected
RUN show grants
Grants for xplugin@localhost
GRANT ALL PRIVILEGES ON *.* TO 'xplugin'@'localhost'
0 rows affected
Cleanup
RUN drop schema if exists xtest

0 rows affected
closing session xplugin
Mysqlx.Ok {
  msg: "bye!"
}
ok
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
7	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect error while killing client with data type other than usinged int
try killing xprotocol session with valid sql_session id once xprotocol connetion opened with kill_client,expect error
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 11
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: Unknown MySQLx client id 11 (code 1094)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_STRING
      v_string {
        value: "1"
      }
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_BOOL
      v_bool: true
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_BOOL
      v_bool: false
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_BOOL
      v_bool: false
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_BOOL
      v_bool: true
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_FLOAT
      v_float: 1
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_DOUBLE
      v_double: 1
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_NULL
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_OCTETS
      v_octets {
        value: "1"
      }
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_SINT
      v_signed_int: -1
    }
  }
  namespace: "xplugin"
}

Got expected error: Invalid type for argument 'id' at #1 (should be unsigned int) (code 5016)
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=11 with root user even though kill_client returns errors
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	11
Mysqlx_stmt_list_clients	1
0 rows affected
Mysqlx.Ok {
  msg: "bye!"
}
ok
NOTICE: Account password expired
expect error if list_clients and kill_client executed from password expired user session
RUN show processlist
While executing show processlist:
Got expected error: You must reset your password using ALTER USER statement before executing this statement. (code 1820)
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

Got expected error: You must reset your password using ALTER USER statement before executing this statement. (code 1820)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 8
    }
  }
  namespace: "xplugin"
}

Got expected error:
Mysqlx.Error {
  severity: ERROR
  code: 1820
  msg: "You must reset your password using ALTER USER statement before executing this statement."
  sql_state: "HY000"
}

expect error for status var executed with password expired user
RUN show status like 'Mysqlx%client%'
While executing show status like 'Mysqlx%client%':
Got expected error: You must reset your password using ALTER USER statement before executing this statement. (code 1820)
Mysqlx.Ok {
  msg: "bye!"
}
ok
checking list_clients and kill_client with mixed case, expect success as these commands are case insensitive
send Mysqlx.Sql.StmtExecute {
  stmt: "LIST_clients"
  namespace: "xplugin"
}

client_id	user	host	
9	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_CLIENT"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 998
    }
  }
  namespace: "xplugin"
}

Got expected error:
Mysqlx.Error {
  severity: ERROR
  code: 1094
  msg: "Unknown MySQLx client id 998"
  sql_state: "HY000"
}

expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=1 with root user when these commads executed with mixed case
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	1
0 rows affected
Mysqlx.Ok {
  msg: "bye!"
}
ok
checking list_clients and kill_client with default 100 connections, expect success for both list and kill
RUN set @@global.mysqlx_max_connections=60

0 rows affected
RUN create user xconnection1@localhost identified by  'xconnection1'

0 rows affected
RUN create user xconnection2@localhost identified by  'xconnection2'

0 rows affected
RUN create user xconnection3@localhost identified by  'xconnection3'

0 rows affected
RUN create user xconnection4@localhost identified by  'xconnection4'

0 rows affected
RUN create user xconnection5@localhost identified by  'xconnection5'

0 rows affected
RUN create user xconnection6@localhost identified by  'xconnection6'

0 rows affected
RUN create user xconnection7@localhost identified by  'xconnection7'

0 rows affected
RUN create user xconnection8@localhost identified by  'xconnection8'

0 rows affected
RUN create user xconnection9@localhost identified by  'xconnection9'

0 rows affected
RUN create user xconnection10@localhost identified by  'xconnection10'

0 rows affected
RUN create user xconnection11@localhost identified by  'xconnection11'

0 rows affected
RUN create user xconnection12@localhost identified by  'xconnection12'

0 rows affected
RUN create user xconnection13@localhost identified by  'xconnection13'

0 rows affected
RUN create user xconnection14@localhost identified by  'xconnection14'

0 rows affected
RUN create user xconnection15@localhost identified by  'xconnection15'

0 rows affected
RUN create user xconnection16@localhost identified by  'xconnection16'

0 rows affected
RUN create user xconnection17@localhost identified by  'xconnection17'

0 rows affected
RUN create user xconnection18@localhost identified by  'xconnection18'

0 rows affected
RUN create user xconnection19@localhost identified by  'xconnection19'

0 rows affected
RUN create user xconnection20@localhost identified by  'xconnection20'

0 rows affected
RUN create user xconnection21@localhost identified by  'xconnection21'

0 rows affected
RUN create user xconnection22@localhost identified by  'xconnection22'

0 rows affected
RUN create user xconnection23@localhost identified by  'xconnection23'

0 rows affected
RUN create user xconnection24@localhost identified by  'xconnection24'

0 rows affected
RUN create user xconnection25@localhost identified by  'xconnection25'

0 rows affected
RUN create user xconnection26@localhost identified by  'xconnection26'

0 rows affected
RUN create user xconnection27@localhost identified by  'xconnection27'

0 rows affected
RUN create user xconnection28@localhost identified by  'xconnection28'

0 rows affected
RUN create user xconnection29@localhost identified by  'xconnection29'

0 rows affected
RUN create user xconnection30@localhost identified by  'xconnection30'

0 rows affected
RUN create user xconnection31@localhost identified by  'xconnection31'

0 rows affected
RUN create user xconnection32@localhost identified by  'xconnection32'

0 rows affected
RUN create user xconnection33@localhost identified by  'xconnection33'

0 rows affected
RUN create user xconnection34@localhost identified by  'xconnection34'

0 rows affected
RUN create user xconnection35@localhost identified by  'xconnection35'

0 rows affected
RUN create user xconnection36@localhost identified by  'xconnection36'

0 rows affected
RUN create user xconnection37@localhost identified by  'xconnection37'

0 rows affected
RUN create user xconnection38@localhost identified by  'xconnection38'

0 rows affected
RUN create user xconnection39@localhost identified by  'xconnection39'

0 rows affected
RUN create user xconnection40@localhost identified by  'xconnection40'

0 rows affected
RUN create user xconnection41@localhost identified by  'xconnection41'

0 rows affected
RUN create user xconnection42@localhost identified by  'xconnection42'

0 rows affected
RUN create user xconnection43@localhost identified by  'xconnection43'

0 rows affected
RUN create user xconnection44@localhost identified by  'xconnection44'

0 rows affected
RUN create user xconnection45@localhost identified by  'xconnection45'

0 rows affected
RUN create user xconnection46@localhost identified by  'xconnection46'

0 rows affected
RUN create user xconnection47@localhost identified by  'xconnection47'

0 rows affected
RUN create user xconnection48@localhost identified by  'xconnection48'

0 rows affected
RUN create user xconnection49@localhost identified by  'xconnection49'

0 rows affected
RUN create user xconnection50@localhost identified by  'xconnection50'

0 rows affected
Test data
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	sql_session
10	root	localhost	$SESSION
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0 
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
create and activate new session xconnection1
connecting...
active session is now 'xconnection1'
connecting...
active session is now 'xconnection2'
connecting...
active session is now 'xconnection3'
connecting...
active session is now 'xconnection4'
connecting...
active session is now 'xconnection5'
connecting...
active session is now 'xconnection6'
connecting...
active session is now 'xconnection7'
connecting...
active session is now 'xconnection8'
connecting...
active session is now 'xconnection9'
connecting...
active session is now 'xconnection10'
connecting...
active session is now 'xconnection11'
connecting...
active session is now 'xconnection12'
connecting...
active session is now 'xconnection13'
connecting...
active session is now 'xconnection14'
connecting...
active session is now 'xconnection15'
connecting...
active session is now 'xconnection16'
connecting...
active session is now 'xconnection17'
connecting...
active session is now 'xconnection18'
connecting...
active session is now 'xconnection19'
connecting...
active session is now 'xconnection20'
connecting...
active session is now 'xconnection21'
connecting...
active session is now 'xconnection22'
connecting...
active session is now 'xconnection23'
connecting...
active session is now 'xconnection24'
connecting...
active session is now 'xconnection25'
connecting...
active session is now 'xconnection26'
connecting...
active session is now 'xconnection27'
connecting...
active session is now 'xconnection28'
connecting...
active session is now 'xconnection29'
connecting...
active session is now 'xconnection30'
connecting...
active session is now 'xconnection31'
connecting...
active session is now 'xconnection32'
connecting...
active session is now 'xconnection33'
connecting...
active session is now 'xconnection34'
connecting...
active session is now 'xconnection35'
connecting...
active session is now 'xconnection36'
connecting...
active session is now 'xconnection37'
connecting...
active session is now 'xconnection38'
connecting...
active session is now 'xconnection39'
connecting...
active session is now 'xconnection40'
connecting...
active session is now 'xconnection41'
connecting...
active session is now 'xconnection42'
connecting...
active session is now 'xconnection43'
connecting...
active session is now 'xconnection44'
connecting...
active session is now 'xconnection45'
connecting...
active session is now 'xconnection46'
connecting...
active session is now 'xconnection47'
connecting...
active session is now 'xconnection48'
connecting...
active session is now 'xconnection49'
connecting...
active session is now 'xconnection50'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
60	xconnection50	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
switched to session default
list all connected clients
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
10	root	localhost
11	xconnection1	localhost
12	xconnection2	localhost
13	xconnection3	localhost
14	xconnection4	localhost
15	xconnection5	localhost
16	xconnection6	localhost
17	xconnection7	localhost
18	xconnection8	localhost
19	xconnection9	localhost
20	xconnection10	localhost
21	xconnection11	localhost
22	xconnection12	localhost
23	xconnection13	localhost
24	xconnection14	localhost
25	xconnection15	localhost
26	xconnection16	localhost
27	xconnection17	localhost
28	xconnection18	localhost
29	xconnection19	localhost
30	xconnection20	localhost
31	xconnection21	localhost
32	xconnection22	localhost
33	xconnection23	localhost
34	xconnection24	localhost
35	xconnection25	localhost
36	xconnection26	localhost
37	xconnection27	localhost
38	xconnection28	localhost
39	xconnection29	localhost
40	xconnection30	localhost
41	xconnection31	localhost
42	xconnection32	localhost
43	xconnection33	localhost
44	xconnection34	localhost
45	xconnection35	localhost
46	xconnection36	localhost
47	xconnection37	localhost
48	xconnection38	localhost
49	xconnection39	localhost
50	xconnection40	localhost
51	xconnection41	localhost
52	xconnection42	localhost
53	xconnection43	localhost
54	xconnection44	localhost
55	xconnection45	localhost
56	xconnection46	localhost
57	xconnection47	localhost
58	xconnection48	localhost
59	xconnection49	localhost
60	xconnection50	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=0 
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	2
0 rows affected
RUN show status like 'Mysqlx_sessions%'

Variable_name	Value
Mysqlx_sessions	51
Mysqlx_sessions_accepted	60
Mysqlx_sessions_closed	9
Mysqlx_sessions_fatal_error	0
Mysqlx_sessions_killed	4
Mysqlx_sessions_rejected	0
0 rows affected
killing all newly connected clients except root,one by one
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 11
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 12
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 13
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 14
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 15
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 16
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 17
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 18
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 19
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 20
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 21
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 22
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 23
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 24
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 25
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 26
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 27
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 28
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 29
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 30
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 31
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 32
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 33
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 34
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 35
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 36
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 37
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 38
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 39
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 40
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 41
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 42
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 43
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 44
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 45
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 46
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 47
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 48
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 49
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 50
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 51
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 52
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 53
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 54
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 55
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 56
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 57
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 58
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 59
    }
  }
  namespace: "xplugin"
}


command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 60
    }
  }
  namespace: "xplugin"
}


command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
10	root	localhost
command ok
expect Mysqlx_stmt_list_clients=3 and Mysqlx_stmt_kill_client=49
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	50
Mysqlx_stmt_list_clients	3
0 rows affected
RUN show status like 'Mysqlx_sessions%'

Variable_name	Value
Mysqlx_sessions	1
Mysqlx_sessions_accepted	60
Mysqlx_sessions_closed	59
Mysqlx_sessions_fatal_error	0
Mysqlx_sessions_killed	54
Mysqlx_sessions_rejected	0
0 rows affected
RUN drop user xconnection1@localhost

0 rows affected
RUN drop user xconnection2@localhost

0 rows affected
RUN drop user xconnection3@localhost

0 rows affected
RUN drop user xconnection4@localhost

0 rows affected
RUN drop user xconnection5@localhost

0 rows affected
RUN drop user xconnection6@localhost

0 rows affected
RUN drop user xconnection7@localhost

0 rows affected
RUN drop user xconnection8@localhost

0 rows affected
RUN drop user xconnection9@localhost

0 rows affected
RUN drop user xconnection10@localhost

0 rows affected
RUN drop user xconnection11@localhost

0 rows affected
RUN drop user xconnection12@localhost

0 rows affected
RUN drop user xconnection13@localhost

0 rows affected
RUN drop user xconnection14@localhost

0 rows affected
RUN drop user xconnection15@localhost

0 rows affected
RUN drop user xconnection16@localhost

0 rows affected
RUN drop user xconnection17@localhost

0 rows affected
RUN drop user xconnection18@localhost

0 rows affected
RUN drop user xconnection19@localhost

0 rows affected
RUN drop user xconnection20@localhost

0 rows affected
RUN drop user xconnection21@localhost

0 rows affected
RUN drop user xconnection22@localhost

0 rows affected
RUN drop user xconnection23@localhost

0 rows affected
RUN drop user xconnection24@localhost

0 rows affected
RUN drop user xconnection25@localhost

0 rows affected
RUN drop user xconnection26@localhost

0 rows affected
RUN drop user xconnection27@localhost

0 rows affected
RUN drop user xconnection28@localhost

0 rows affected
RUN drop user xconnection29@localhost

0 rows affected
RUN drop user xconnection30@localhost

0 rows affected
RUN drop user xconnection31@localhost

0 rows affected
RUN drop user xconnection32@localhost

0 rows affected
RUN drop user xconnection33@localhost

0 rows affected
RUN drop user xconnection34@localhost

0 rows affected
RUN drop user xconnection35@localhost

0 rows affected
RUN drop user xconnection36@localhost

0 rows affected
RUN drop user xconnection37@localhost

0 rows affected
RUN drop user xconnection38@localhost

0 rows affected
RUN drop user xconnection39@localhost

0 rows affected
RUN drop user xconnection40@localhost

0 rows affected
RUN drop user xconnection41@localhost

0 rows affected
RUN drop user xconnection42@localhost

0 rows affected
RUN drop user xconnection43@localhost

0 rows affected
RUN drop user xconnection44@localhost

0 rows affected
RUN drop user xconnection45@localhost

0 rows affected
RUN drop user xconnection46@localhost

0 rows affected
RUN drop user xconnection47@localhost

0 rows affected
RUN drop user xconnection48@localhost

0 rows affected
RUN drop user xconnection49@localhost

0 rows affected
RUN drop user xconnection50@localhost

0 rows affected
Mysqlx.Ok {
  msg: "bye!"
}
ok
execute list_clients,kill_client with sql namespace,expect error
change result file once error messages are fixed
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "sql"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'list_clients' at line 1 (code 1064)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 11
    }
  }
  namespace: "sql"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: Too many arguments (code 5015)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 11
    }
  }
  namespace: ""
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: Unknown namespace  (code 5162)
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 11
    }
  }
  namespace: "invalid"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: Unknown namespace invalid (code 5162)
expect Mysqlx_stmt_list_clients=0 and Mysqlx_stmt_kill_client=0 as these are not executed on right namespace
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	0
0 rows affected
Mysqlx.Ok {
  msg: "bye!"
}
ok
open xconnection with ssl and kill,expect success
RUN create user con1@localhost identified by 'con1'

0 rows affected
RUN create user con2@localhost identified by 'con2'

0 rows affected
RUN set @@global.mysqlx_max_connections=3

0 rows affected
Test data
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
62	sslcon	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
create and activate new session con1
connecting...
active session is now 'con1'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
63	con1	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
open 3rd xprotocol connection where 2 sessions already opened
connecting...
active session is now 'con2'
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	0
0 rows affected
switched to session default
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
62	sslcon	localhost
63	con1	localhost
64	con2	localhost
command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 63
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk

command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 64
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk

command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
62	sslcon	localhost
command ok
expect Mysqlx_stmt_list_clients=3 and Mysqlx_stmt_kill_client=2
RUN drop user con1@localhost

0 rows affected
RUN drop user con2@localhost

0 rows affected
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	2
Mysqlx_stmt_list_clients	3
0 rows affected
Mysqlx.Ok {
  msg: "bye!"
}
ok
open xconnection with ssl root user kill,expect success
RUN create user con1@localhost identified by 'con1'

0 rows affected
RUN create user con2@localhost identified by 'con2'

0 rows affected
RUN set @@global.mysqlx_max_connections=3

0 rows affected
Test data
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
65	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
create and activate new session con1
connecting...
active session is now 'con1      con1    con1'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
65	root	localhost
66	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
open 3rd xprotocol connection where 2 sessions already opened
connecting...
active session is now 'con2      con2    con2'
switched to session default
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
65	root	localhost
66	root	localhost
67	root	localhost
command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 66
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk

command ok
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 67
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk

command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
65	root	localhost
command ok
RUN drop user con1@localhost

0 rows affected
RUN drop user con2@localhost

0 rows affected
Mysqlx.Ok {
  msg: "bye!"
}
ok
show status like 'Mysqlx%client%';
Variable_name	Value
Mysqlx_stmt_kill_client	72
Mysqlx_stmt_list_clients	26
# restart: --show_compatibility_56=OFF
drop user abc@localhost;
drop user xplugin@localhost;
drop user process@localhost;
drop user expire@localhost;
set @@global.mysqlx_max_connections=100;
show status like 'Mysqlx%client%';
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	0
select sleep(0.5);
sleep(0.5)
0
RUN create user abc@localhost identified by 'abc'

0 rows affected
RUN create user xplugin@localhost identified by 'xplugin'

0 rows affected
RUN grant all on *.* to xplugin@localhost

0 rows affected
RUN create user process@localhost identified by 'process'

0 rows affected
RUN grant process on *.* to process@localhost

0 rows affected
RUN create user expire@localhost identified by 'expire'

0 rows affected
RUN grant all on *.* to expire@localhost

0 rows affected
RUN alter user expire@localhost password expire

0 rows affected
Test data
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
create and activate new session
connecting...
active session is now 'aux'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
2	root	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
expect Mysqlx_stmt_list_clients=1 and Mysqlx_stmt_kill_client=0 even with another new root session
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	1
0 rows affected
switch back to default session
switched to session default
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect error
client_id	user	host	
1	root	localhost
2	root	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=0 with default root session where list_clients already executed
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	0
Mysqlx_stmt_list_clients	2
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 2
    }
  }
  namespace: "xplugin"
}


command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
1	root	localhost
command ok
expect Mysqlx_stmt_list_clients=3 and Mysqlx_stmt_kill_client=1 with default root session where list_clients executed 3 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	3
0 rows affected
create and activate new session abc
expect only abc user session id 
connecting...
active session is now 'abc'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
3	abc	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
killing root user session with unprivileged user 'abc' which should be unsuccessful
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 1
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: You are not owner of thread (code 1095)
expect ERROR: SELECT command denied to user 'abc'@'localhost' for table 'session_status' (code 1142) for show status command
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	1
0 rows affected
open another session of abc user and kill first session of abc user,which should be successful
connecting...
active session is now 'abc1'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
3	abc	localhost
4	abc	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 3
    }
  }
  namespace: "xplugin"
}


command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
4	abc	localhost
command ok
expect ERROR: SELECT command denied to user 'abc'@'localhost' for table 'session_status' (code 1142) for show status command
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	2
0 rows affected
killing abc user session with its own session 'abc' which should be successful
expect right error instead of End of File
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 4
    }
  }
  namespace: "xplugin"
}

switch back to default session
Server disconnected
closing session abc1
switched to session default
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
client_id	user	host	
1	root	localhost
command ok
expect Mysqlx_stmt_list_clients=4 and Mysqlx_stmt_kill_client=1 with default root session where list_clients executed 4 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	4
0 rows affected
open process only privileged user seession and kill root user session,expect error "You are not owner of thread"
connecting...
active session is now 'process'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
5	process	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 1
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk
Got expected error: You are not owner of thread (code 1095)
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
checking list of clients after root user session killed by xplugin user
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
5	process	localhost
command ok
expect ERROR: SELECT command denied to user 'process'@'localhost' for table 'session_status' (code 1142) for show command
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	2
0 rows affected
open privileged user seession and kill root user session,expect success
connecting...
active session is now 'xplugin'
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
1	root	localhost
5	process	localhost
6	xplugin	localhost
command ok
Namespace 'xplugin' is deprecated, please use 'mysqlx' instead
send Mysqlx.Sql.StmtExecute {
  stmt: "kill_client"
  args {
    type: SCALAR
    scalar {
      type: V_UINT
      v_unsigned_int: 1
    }
  }
  namespace: "xplugin"
}

expect Mysqlx.Sql.StmtExecuteOk

command ok
RUN select sleep(0.5)
sleep(0.5)
0
0 rows affected
checking list of clients after root user session killed by xplugin user
send Mysqlx.Sql.StmtExecute {
  stmt: "list_clients"
  namespace: "xplugin"
}

client_id	user	host	
5	process	localhost
6	xplugin	localhost
command ok
expect Mysqlx_stmt_list_clients=2 and Mysqlx_stmt_kill_client=1 with xplugin user where list_clients executed 2 times and kill_client once
RUN show status like 'Mysqlx%client%'
Variable_name	Value
Mysqlx_stmt_kill_client	1
Mysqlx_stmt_list_clients	2
0 rows affected
Cleanup
RUN drop schema if exists xtest

0 rows affected
closing session xplugin
Mysqlx.Ok {
  msg: "bye!"
}
ok
show status like 'Mysqlx%client%';
Variable_name	Value
Mysqlx_stmt_kill_client	6
Mysqlx_stmt_list_clients	12
uninstall plugin mysqlx;
drop user abc@localhost;
drop user xplugin@localhost;
drop user process@localhost;
drop user expire@localhost;
drop user sslcon@localhost;

Man Man