config root man

Current Path : /home/usr.opt/mysql57/mysql-test/suite/auth_sec/t/

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 : //home/usr.opt/mysql57/mysql-test/suite/auth_sec/t/access_credential_control.test

###############################################################################
#                                                                             #
# User access, credential update, permission grant/revoke, alter user,        #
# drop user, create user, grant user, set password and rename user commands   #
# functional and integration test                                             #
#                                                                             #
#                                                                             #
# Creation Date: 2012-12-27                                                   #
# Author : Tanjot Singh Uppal                                                 #
#                                                                             #
#                                                                             #
# Description:Test Cases of creation, alteration and controlling of           #
# the user access                                                             #
#                                                                             #
###############################################################################

--source include/not_embedded.inc
--source include/have_ssl.inc
--source include/have_sha256_rsa_auth.inc
--source include/mysql_upgrade_preparation.inc

# This test will intentionally generate errors in the server error log
# when a broken password is inserted into the mysql.user table.
# The below suppression is to clear those errors.
--disable_query_log
call mtr.add_suppression(".*Password salt for user.*");
--enable_query_log

--disable_query_log
call mtr.add_suppression(".*Tanjotuser3@localhost.*");
--enable_query_log


--echo
--echo 
--echo =======================================================================
--echo Checking the password plugin assignment with create user command
--echo =======================================================================
--echo 

#### Checking the password plugin assignment with create user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

select @@session.old_passwords;
--echo 0 Expected

CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED BY 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Validating the plugin assigned for the above 3 users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='Tanjotuser1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='Tanjotuser3' and Host='localhost')='sha256_password';
--echo 1 Expected


## Dropping the created users

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';



--echo
--echo 
--echo =======================================================================
--echo Checking the password plugin assignment with grant user command
--echo =======================================================================
--echo 

#### Checking the password plugin assignment with grant user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;
GRANT usage on mysql.* to 'Tanjotuser1'@'localhost' IDENTIFIED BY 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;
GRANT usage on mysql.* to 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password' BY '123';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Validating the plugin assigned for the above 3 users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='Tanjotuser1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='Tanjotuser3' and Host='localhost')='sha256_password';
--echo 1 Expected


## Dropping the created users

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';


--echo
--echo 
--echo =======================================================================
--echo Checking the functionality and integrity of the DROP user command
--echo =======================================================================
--echo 

#### Checking the functionality and integrity of the DROP user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;

CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED BY 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Creating a user with respect to all the 3 password authentication plugin

--echo Connecting a session each with the above 3 users

--disable_warnings
connect(con1,localhost,Tanjotuser1,abc,,);
connect(con3,localhost,Tanjotuser3,abc,,);
--enable_warnings

## Now dropping the above 3 users with each having a open session

--echo dropping the above 3 users with each having a open session

connection default;

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';

## Now trying opening a new session for the above dropped user

--echo Now trying opening a new session for the above dropped user

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con4,localhost,Tanjotuser1,abc,,);
--enable_query_log

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con6,localhost,Tanjotuser3,abc,,);
--enable_query_log


## Accessing the open sessions for the above dropped user

--echo Accessing the open sessions for the above dropped user


connection con1;
select user(), current_user();


connection con3;
select user(), current_user();


disconnect con1;
disconnect con3;


--echo
--echo 
--echo =======================================================================
--echo Checking the privellages post renaming the user
--echo =======================================================================
--echo 

#### Checking the rename user command

## Creating a user with respect to all the 3 password authentication plugin

connection default;

--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;

CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED BY 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Validating the plugin assigned for the above 3 users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='Tanjotuser1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='Tanjotuser3' and Host='localhost')='sha256_password';
--echo 1 Expected

## Connecting a session to each of the above created users


--disable_warnings
connect(con7,localhost,Tanjotuser1,abc,,);
select user(), current_user();

connect(con9,localhost,Tanjotuser3,abc,,);
select user(), current_user();
--enable_warnings



## Validating the integrity of the rename user command

connection default;

--echo **** Validating the integrity of the rename user command

RENAME USER 'Tanjotuser1'@'localhost' to 'user1'@'localhost';
RENAME USER 'Tanjotuser3'@'localhost' to 'user3'@'localhost';

## Validating the plugin assigned for the renamed users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='user1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='user3' and Host='localhost')='sha256_password';
--echo 1 Expected


## Validating the users post renaming

--echo **** Validating the user connections post renaming

connection con7;
select user(), current_user();

connection con9;
select user(), current_user();


--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con10,localhost,Tanjotuser1,abc,,);
--enable_query_log

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con12,localhost,Tanjotuser3,abc,,);
--enable_query_log


--disable_warnings
connect(con13,localhost,user1,abc,,);
select user(), current_user();

connect(con15,localhost,user3,abc,,);
select user(), current_user();
--enable_warnings


## Disconnecting the open sessions and dropping the created users

--echo **** Disconnecting the open sessions and dropping the created users

connection default;

disconnect con7;
disconnect con9;
disconnect con13;
disconnect con15;

connection default;

Drop user 'user1'@'localhost';
Drop user 'user3'@'localhost';


--echo
--echo 
--echo =======================================================================
--echo Checking the privillages with grant user command
--echo =======================================================================
--echo 

#### Checking the password plugin assignment with grant user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;
GRANT select on mysql.* to 'Tanjotuser1'@'localhost' IDENTIFIED BY 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;
GRANT select on mysql.* to 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password' BY '123';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Granting and revoking the privellages from the above users

--echo **** Validating the granted privilleges

connect(con16,localhost,Tanjotuser1,abc,,);
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
--echo mysql_native_password Expected


connect(con18,localhost,Tanjotuser3,abc,,);
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
--echo sha256_password Expected

# Revoking select on mysql database
--echo **** Revoking select on mysql database

connection default;

Revoke select on mysql.* from 'Tanjotuser1'@'localhost';
Revoke select on mysql.* from 'Tanjotuser3'@'localhost';

--echo **** Validating the Revoked privilleges

connection con16;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
select user(), current_user();

connection con18;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
select user(), current_user();


## Granting and revoking the privellages from the above users


connection default;

Grant usage on mysql.* to 'Tanjotuser1'@'localhost';
Grant usage on mysql.* to 'Tanjotuser3'@'localhost';


--echo **** Validating the granted privilleges

connection con16;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
select user(), current_user();

connection con18;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
select user(), current_user();


# Granting All on mysql database

--echo **** Validating the granted privilleges

connection default;

Grant All on mysql.* to 'Tanjotuser1'@'localhost';
Grant All on mysql.* to 'Tanjotuser3'@'localhost';

connect(con50,localhost,Tanjotuser1,abc,,);
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
--echo mysql_native_password Expected

connect(con52,localhost,Tanjotuser3,abc,,);
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
--echo sha256_password Expected



## Disconnecting the open sessions and dropping the created users

--echo **** Disconnecting the open sessions and dropping the created users

connection default;

disconnect con16;
disconnect con18;

disconnect con50;
disconnect con52;

connection default;

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';



--echo
--echo 
--echo =============================================================================
--echo Checking the password assignment using the update command on the user table
--echo =============================================================================
--echo 

#### Checking the password plugin assignment and password hashing based on the update command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin
--disable_warnings
CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED WITH 'mysql_native_password';
set @@session.old_passwords=0;
UPDATE mysql.user SET Authentication_string=PASSWORD('abc') WHERE User='Tanjotuser1' AND Host='localhost';
FLUSH PRIVILEGES;



--echo **** Creating user with sha256_password plugin

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
set @@session.old_passwords=2;
UPDATE IGNORE mysql.user SET Authentication_string=PASSWORD('abc') WHERE User='Tanjotuser3' AND Host='localhost';
FLUSH PRIVILEGES;
--enable_warnings


connect(con19,localhost,Tanjotuser1,abc,,);
select user(), current_user();
set password='abcd';

# Below section is hashed out till Bug #16050188 is fixed

#connect(con21,localhost,Tanjotuser3,abc,,);
#select user(), current_user();


connect(con22,localhost,Tanjotuser1,abcd,,);
select user(), current_user();


#connect(con24,localhost,Tanjotuser3,abcd,,);
#select user(), current_user();



## Disconnecting the open sessions and dropping the created users

--echo **** Disconnecting the open sessions and dropping the created users

connection default;

disconnect con19;
#disconnect con21;
disconnect con22;
#disconnect con24;

connection default;

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';



--echo
--echo 
--echo ===================================================================================================
--echo Starting the server with default auth as sha256_password and checking the above validations again.
--echo ===================================================================================================
--echo

--echo # Restart server with default-authentication-plugin=sha256_password;

let $restart_file= $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
--exec echo "wait" > $restart_file
--shutdown_server 
--source include/wait_until_disconnected.inc
-- exec echo "restart:--default-authentication-plugin=sha256_password  " > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
-- enable_reconnect
-- source include/wait_until_connected_again.inc


--echo
--echo 
--echo =======================================================================
--echo Checking the password plugin assignment with create user command
--echo =======================================================================
--echo 

#### Checking the password plugin assignment with create user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

select @@session.old_passwords;
--echo 0 Expected

CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED WITH  'mysql_native_password';
SET PASSWORD for 'Tanjotuser1'@'localhost' = 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Validating the plugin assigned for the above 3 users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='Tanjotuser1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='Tanjotuser3' and Host='localhost')='sha256_password';
--echo 1 Expected


## Dropping the created users

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';



--echo
--echo 
--echo =======================================================================
--echo Checking the password plugin assignment with grant user command
--echo =======================================================================
--echo 

#### Checking the password plugin assignment with grant user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;
GRANT usage on mysql.* to 'Tanjotuser1'@'localhost' IDENTIFIED WITH 'mysql_native_password' BY '123';
SET PASSWORD for 'Tanjotuser1'@'localhost' = 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;
GRANT usage on mysql.* to 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password' BY '123';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Validating the plugin assigned for the above 3 users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='Tanjotuser1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='Tanjotuser3' and Host='localhost')='sha256_password';
--echo 1 Expected


## Dropping the created users

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';


--echo
--echo 
--echo =======================================================================
--echo Checking the functionality and integrity of the DROP user command
--echo =======================================================================
--echo 

#### Checking the functionality and integrity of the DROP user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;

CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED BY 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Creating a user with respect to all the 3 password authentication plugin

--echo Connecting a session each with the above 3 users

--disable_warnings
connect(con1,localhost,Tanjotuser1,abc,,);
connect(con3,localhost,Tanjotuser3,abc,,);
--enable_warnings

## Now dropping the above 3 users with each having a open session

--echo dropping the above 3 users with each having a open session

connection default;

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';

## Now trying opening a new session for the above dropped user

--echo Now trying opening a new session for the above dropped user

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con4,localhost,Tanjotuser1,abc,,);
--enable_query_log

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con6,localhost,Tanjotuser3,abc,,);
--enable_query_log


## Accessing the open sessions for the above dropped user

--echo Accessing the open sessions for the above dropped user


connection con1;
select user(), current_user();


connection con3;
select user(), current_user();


disconnect con1;
disconnect con3;


--echo
--echo 
--echo =======================================================================
--echo Checking the privellages post renaming the user
--echo =======================================================================
--echo 

#### Checking the rename user command

## Creating a user with respect to all the 3 password authentication plugin

connection default;

--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;

CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED WITH 'mysql_native_password';
SET PASSWORD for 'Tanjotuser1'@'localhost' = 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Validating the plugin assigned for the above 3 users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='Tanjotuser1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='Tanjotuser3' and Host='localhost')='sha256_password';
--echo 1 Expected

## Connecting a session to each of the above created users


--disable_warnings
connect(con7,localhost,Tanjotuser1,abc,,);
select user(), current_user();

connect(con9,localhost,Tanjotuser3,abc,,);
select user(), current_user();
--enable_warnings



## Validating the integrity of the rename user command

connection default;

--echo **** Validating the integrity of the rename user command

RENAME USER 'Tanjotuser1'@'localhost' to 'user1'@'localhost';
RENAME USER 'Tanjotuser3'@'localhost' to 'user3'@'localhost';

## Validating the plugin assigned for the renamed users in the user table

--echo **** Validating the plugin names

select (select plugin from mysql.user where User='user1' and Host='localhost')='mysql_native_password';
--echo 1 Expected

select (select plugin from mysql.user where User='user3' and Host='localhost')='sha256_password';
--echo 1 Expected


## Validating the users post renaming

--echo **** Validating the user connections post renaming

connection con7;
select user(), current_user();

connection con9;
select user(), current_user();

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con10,localhost,Tanjotuser1,abc,,);
--enable_query_log

--replace_result $MASTER_MYSOCK MASTER_MYSOCK
--disable_query_log
--error ER_ACCESS_DENIED_ERROR
connect(con12,localhost,Tanjotuser3,abc,,);
--enable_query_log


--disable_warnings
connect(con13,localhost,user1,abc,,);
select user(), current_user();

connect(con15,localhost,user3,abc,,);
select user(), current_user();
--enable_warnings


## Disconnecting the open sessions and dropping the created users

--echo **** Disconnecting the open sessions and dropping the created users

connection default;

disconnect con7;
disconnect con9;
disconnect con13;
disconnect con15;

connection default;

Drop user 'user1'@'localhost';
Drop user 'user3'@'localhost';


--echo
--echo 
--echo =======================================================================
--echo Checking the privillages with grant user command
--echo =======================================================================
--echo 

#### Checking the password plugin assignment with grant user command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin

set @@session.old_passwords=0;
GRANT select on mysql.* to 'Tanjotuser1'@'localhost' IDENTIFIED WITH 'mysql_native_password' BY '123';
SET PASSWORD for 'Tanjotuser1'@'localhost' = 'abc';


--echo **** Creating user with sha256_password plugin

set @@session.old_passwords=2;
GRANT select on mysql.* to 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password' BY '123';
SET PASSWORD for 'Tanjotuser3'@'localhost' = 'abc';


## Granting and revoking the privellages from the above users

--echo **** Validating the granted privilleges

connect(con16,localhost,Tanjotuser1,abc,,);
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
--echo mysql_native_password Expected

connect(con18,localhost,Tanjotuser3,abc,,);
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
--echo sha256_password Expected

# Revoking select on mysql database
--echo **** Revoking select on mysql database

connection default;

Revoke select on mysql.* from 'Tanjotuser1'@'localhost';
Revoke select on mysql.* from 'Tanjotuser3'@'localhost';

--echo **** Validating the Revoked privilleges

connection con16;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
select user(), current_user();

connection con18;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
select user(), current_user();


## Granting and revoking the privellages from the above users


connection default;

Grant usage on mysql.* to 'Tanjotuser1'@'localhost';
Grant usage on mysql.* to 'Tanjotuser3'@'localhost';


--echo **** Validating the granted privilleges

connection con16;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
select user(), current_user();

connection con18;
--error ER_TABLEACCESS_DENIED_ERROR
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
select user(), current_user();


# Granting All on mysql database

--echo **** Validating the granted privilleges

connection default;

Grant All on mysql.* to 'Tanjotuser1'@'localhost';
Grant All on mysql.* to 'Tanjotuser3'@'localhost';

connect(con50,localhost,Tanjotuser1,abc,,);
select plugin from mysql.user where user='Tanjotuser1' and host='localhost';
--echo mysql_native_password Expected

connect(con52,localhost,Tanjotuser3,abc,,);
select plugin from mysql.user where user='Tanjotuser3' and host='localhost';
--echo sha256_password Expected



## Disconnecting the open sessions and dropping the created users

--echo **** Disconnecting the open sessions and dropping the created users

connection default;

disconnect con16;
disconnect con18;

disconnect con50;
disconnect con52;

connection default;

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';



--echo
--echo 
--echo =============================================================================
--echo Checking the password assignment using the update command on the user table
--echo =============================================================================
--echo 

#### Checking the password plugin assignment and password hashing based on the update command

## Creating a user with respect to all the 3 password authentication plugin


--echo **** Creating user with mysql_native_password plugin
--disable_warnings
CREATE USER 'Tanjotuser1'@'localhost' IDENTIFIED WITH 'mysql_native_password';
set @@session.old_passwords=0;
UPDATE mysql.user SET Authentication_string=PASSWORD('abc') WHERE User='Tanjotuser1' AND Host='localhost';
FLUSH PRIVILEGES;



--echo **** Creating user with sha256_password plugin

CREATE USER 'Tanjotuser3'@'localhost' IDENTIFIED WITH 'sha256_password';
set @@session.old_passwords=2;
UPDATE IGNORE mysql.user SET Authentication_string=PASSWORD('abc') WHERE User='Tanjotuser3' AND Host='localhost';
FLUSH PRIVILEGES;
--enable_warnings


connect(con19,localhost,Tanjotuser1,abc,,);
select user(), current_user();
set password='abcd';

# Below section is hashed out till Bug #16050188 is fixed

#connect(con21,localhost,Tanjotuser3,abc,,);
#select user(), current_user();


connect(con22,localhost,Tanjotuser1,abcd,,);
select user(), current_user();


#connect(con24,localhost,Tanjotuser3,abcd,,);
#select user(), current_user();



## Disconnecting the open sessions and dropping the created users

--echo **** Disconnecting the open sessions and dropping the created users

connection default;

disconnect con19;
#disconnect con21;
disconnect con22;
#disconnect con24;

connection default;

Drop user 'Tanjotuser1'@'localhost';
Drop user 'Tanjotuser3'@'localhost';

## Final Cleanup
set @@session.old_passwords=default;

Man Man