mirror of
https://github.com/FirebirdSQL/firebird-qa.git
synced 2025-01-22 13:33:07 +01:00
135 lines
5.0 KiB
Python
135 lines
5.0 KiB
Python
#coding:utf-8
|
|
|
|
"""
|
|
ID: issue-5033
|
|
ISSUE: 5033
|
|
TITLE: Provide ability to do: REcreate user <user_name> password <user_pwd>
|
|
DESCRIPTION:
|
|
JIRA: CORE-4726
|
|
FBTEST: bugs.core_4726
|
|
"""
|
|
|
|
import pytest
|
|
from firebird.qa import *
|
|
|
|
db = db_factory()
|
|
|
|
# This fixture is there only to ensure user cleanup
|
|
tmp_user = user_factory('db', name='tmp$c4726', password='123', plugin='Srp', do_not_create=True)
|
|
|
|
test_script = """
|
|
set width usrname 10;
|
|
set width firstname 10;
|
|
set width sec_plugin 20;
|
|
set width sec_attr_key 20;
|
|
set width sec_attr_val 20;
|
|
set width sec_plugin 20;
|
|
|
|
|
|
recreate user tmp$c4726 password '123' using plugin Srp;
|
|
recreate user tmp$c4726 password '123' using plugin Srp;
|
|
drop user tmp$c4726 using plugin Srp;
|
|
commit;
|
|
|
|
recreate view v_users as
|
|
select
|
|
su.sec$user_name as usrname
|
|
,su.sec$first_name as firstname
|
|
,su.sec$plugin as sec_plugin
|
|
,su.sec$admin as sec_is_admin
|
|
,su.sec$active as su_active
|
|
,sa.sec$key as sec_attr_key
|
|
,sa.sec$value as sec_attr_val
|
|
from sec$users su left
|
|
join sec$user_attributes sa using(sec$user_name, sec$plugin)
|
|
where su.sec$user_name = upper('TMP$C4726');
|
|
commit;
|
|
|
|
-- set echo on;
|
|
|
|
----------------------------- Create Or Alter tests -----------------------------------
|
|
|
|
create or alter user tmp$c4726 password '123'
|
|
inactive
|
|
grant admin role -- 16.10.2019: must be specified BEFORE 'using plugin ...' clause!
|
|
using plugin Srp
|
|
tags (initname='Ozzy', surname='Osbourne', groupname='Black Sabbath', birthday = '03.12.1948')
|
|
-- grant admin role -- 16.10.2019: parsing error if will be here
|
|
;
|
|
|
|
commit;
|
|
select 1 as step, v.* from v_users v;
|
|
|
|
create or alter user tmp$c4726 password '123'
|
|
active
|
|
revoke admin role
|
|
using plugin Srp
|
|
tags (initname='Ian', surname='Gillan', groupname='Deep Purple', drop birthday)
|
|
;
|
|
commit;
|
|
select 2 as step, v.* from v_users v;
|
|
|
|
drop user tmp$c4726 using plugin Srp;
|
|
commit;
|
|
|
|
---------------------------------- REcreate test ---------------------------------------
|
|
|
|
recreate user tmp$c4726 password '123'
|
|
inactive
|
|
grant admin role
|
|
using plugin Srp
|
|
tags (initname='John', surname='Bonham', groupname='Led Zeppelin', birthday = '31.05.1948')
|
|
;
|
|
commit;
|
|
select 3 as step, v.* from v_users v;
|
|
|
|
recreate user tmp$c4726 password '123' active
|
|
revoke admin role
|
|
using plugin Srp
|
|
tags (initname='Roger', surname='Waters', groupname='Pink Floyd', drop birthday)
|
|
;
|
|
commit;
|
|
|
|
select 4 as step, v.* from v_users v;
|
|
"""
|
|
|
|
act = isql_act('db', test_script, substitutions=[('[ \t]+', ' '), ('=', '')])
|
|
|
|
expected_stdout = """
|
|
STEP USRNAME FIRSTNAME SEC_PLUGIN SEC_IS_ADMIN SU_ACTIVE SEC_ATTR_KEY SEC_ATTR_VAL
|
|
|
|
1 TMP$C4726 <null> Srp <true> <false> BIRTHDAY 03.12.1948
|
|
1 TMP$C4726 <null> Srp <true> <false> GROUPNAME Black Sabbath
|
|
1 TMP$C4726 <null> Srp <true> <false> INITNAME Ozzy
|
|
1 TMP$C4726 <null> Srp <true> <false> SURNAME Osbourne
|
|
|
|
|
|
STEP USRNAME FIRSTNAME SEC_PLUGIN SEC_IS_ADMIN SU_ACTIVE SEC_ATTR_KEY SEC_ATTR_VAL
|
|
|
|
2 TMP$C4726 <null> Srp <false> <true> GROUPNAME Deep Purple
|
|
2 TMP$C4726 <null> Srp <false> <true> INITNAME Ian
|
|
2 TMP$C4726 <null> Srp <false> <true> SURNAME Gillan
|
|
|
|
|
|
STEP USRNAME FIRSTNAME SEC_PLUGIN SEC_IS_ADMIN SU_ACTIVE SEC_ATTR_KEY SEC_ATTR_VAL
|
|
|
|
3 TMP$C4726 <null> Srp <true> <false> BIRTHDAY 31.05.1948
|
|
3 TMP$C4726 <null> Srp <true> <false> GROUPNAME Led Zeppelin
|
|
3 TMP$C4726 <null> Srp <true> <false> INITNAME John
|
|
3 TMP$C4726 <null> Srp <true> <false> SURNAME Bonham
|
|
|
|
|
|
STEP USRNAME FIRSTNAME SEC_PLUGIN SEC_IS_ADMIN SU_ACTIVE SEC_ATTR_KEY SEC_ATTR_VAL
|
|
|
|
4 TMP$C4726 <null> Srp <false> <true> GROUPNAME Pink Floyd
|
|
4 TMP$C4726 <null> Srp <false> <true> INITNAME Roger
|
|
4 TMP$C4726 <null> Srp <false> <true> SURNAME Waters
|
|
"""
|
|
|
|
@pytest.mark.version('>=4.0')
|
|
def test_1(act: Action, tmp_user: User):
|
|
act.expected_stdout = expected_stdout
|
|
act.execute()
|
|
assert act.clean_stdout == act.clean_expected_stdout
|
|
|