mirror of
https://github.com/FirebirdSQL/firebird-qa.git
synced 2025-01-22 21:43:06 +01:00
Added/Updated bugs\core_3511_test.py: Checked on 5.0.0.501, 4.0.1.2692, 3.0.8.33535 - both on Linux and Windows 10. See details in the source.
This commit is contained in:
parent
e9345f3c8e
commit
dbf056192a
@ -3,150 +3,80 @@
|
||||
"""
|
||||
ID: issue-3869
|
||||
ISSUE: 3869
|
||||
JIRA: CORE-3511
|
||||
FBTEST: bugs.core_3511
|
||||
TITLE: Unquoted role names with non-ASCII characters passed in DPB are upper-cased wrongly
|
||||
DESCRIPTION:
|
||||
Test creates role with non-ascii characters and grants it to common user.
|
||||
Then we try to connect to database using this role and specify it WITHOUT double quotes.
|
||||
Then we try to connect to database using this role and specify it WITHOUT double quotes,
|
||||
with checking that mon$role data not in uppercase.
|
||||
|
||||
::: NB ::: DIFFERENT CODE FOR LINUX vs WINDOWS :::
|
||||
|
||||
We can usq isql only under LINUX.
|
||||
|
||||
As of Windows, only system code page can be used when ISQL passes user/role containing non-ascii characters
|
||||
NOTES:
|
||||
[28.05.2022] pzotov
|
||||
1. On Windows ISQL utility can *not* be used (in common case) for passing non-ascii data in user or role
|
||||
because it allows to use only data encoded in the same codepage as OS system codepage (e.g. 1251 for Russian etc).
|
||||
(see letter from dimitr, 12-mar-2016, 19:14).
|
||||
Because of this, connection using non-ascii user/role is established only via Python driver API.
|
||||
2. firebird.conf must contain 'Srp' in UserManager and AuthClient params for this test can work. Otherwise we get:
|
||||
"firebird.driver.types.DatabaseError: Error occurred during login, please check server firebird.log for details"
|
||||
|
||||
Because of this, it was decided to use Python FDB for connect with DPB that contains non-ascii data.
|
||||
FDB method connect() of class Connection has parameter 'utf8params' with possible values True | False.
|
||||
When this parameter is True, all info passed to DPB in UTF-8. Test uses this to form proper DPB and connect
|
||||
to database with non-ascii role. This role must be specified WITHOUT double quotes.
|
||||
JIRA: CORE-3511
|
||||
FBTEST: bugs.core_3511
|
||||
Checked on 5.0.0.501, 4.0.1.2692, 3.0.8.33535 - both on Linux (CentOS 7.9.2009) and Windows 10 (localized, Russian)
|
||||
"""
|
||||
|
||||
import pytest
|
||||
from firebird.qa import *
|
||||
import locale
|
||||
|
||||
db = db_factory()
|
||||
tmp_user = user_factory('db', name='tmp$c3511', password='123', plugin='Srp')
|
||||
db = db_factory(utf8filename=True, charset='utf8') # !!see also: core_4743_test.py
|
||||
|
||||
test_script_1 = """
|
||||
tmp_user = user_factory('db', name='"Björn Pålsson"', password='123', plugin='Srp')
|
||||
|
||||
#tmp_role1 = role_factory('db', name = '"MaîtreŀłØÐø"')
|
||||
tmp_role1 = role_factory('db', name = '"Maître"')
|
||||
tmp_role2 = role_factory('db', name = '"Groß"')
|
||||
|
||||
act = python_act('db')
|
||||
|
||||
@pytest.mark.version('>=3.0')
|
||||
def test_1(act: Action, tmp_user: User, tmp_role1: Role, tmp_role2: Role, capsys):
|
||||
init_script = f"""
|
||||
set wng off;
|
||||
set bail on;
|
||||
|
||||
create or alter view v_whoami as
|
||||
select current_user as cur_user,mon$role as mon_role,current_role as cur_role
|
||||
select current_user as who_am_i, mon$role as mon_role, iif( mon$role = upper(mon$role), 'WRONG: IN UPPERCASE!', 'Passed') as role_chk
|
||||
from mon$attachments
|
||||
where mon$attachment_id=current_connection;
|
||||
|
||||
revoke all on all from tmp$c3511;
|
||||
where mon$attachment_id = current_connection;
|
||||
commit;
|
||||
|
||||
create table test(id int);
|
||||
grant select on v_whoami to public;
|
||||
grant {tmp_role1.name} to {tmp_user.name};
|
||||
grant {tmp_role2.name} to {tmp_user.name};
|
||||
|
||||
create role "Gros";
|
||||
create role "Groß";
|
||||
create role "αβγδε";
|
||||
|
||||
grant "Gros" to tmp$c3511;
|
||||
grant "Groß" to tmp$c3511;
|
||||
grant "αβγδε" to tmp$c3511;
|
||||
commit;
|
||||
"""
|
||||
act.isql(switches=['-q'], input = init_script, combine_output=True, charset='utf8')
|
||||
|
||||
grant select on v_whoami to tmp$c3511;
|
||||
grant select on test to role "Gros";
|
||||
grant select on test to role "Groß";
|
||||
grant select on test to role "αβγδε";
|
||||
commit;
|
||||
expected_stdout = f"""
|
||||
WHO_AM_I : {tmp_user.name}
|
||||
MON_ROLE : {tmp_role1.name}
|
||||
ROLE_CHK : Passed
|
||||
|
||||
set list on;
|
||||
WHO_AM_I : {tmp_user.name}
|
||||
MON_ROLE : {tmp_role2.name}
|
||||
ROLE_CHK : Passed
|
||||
""".replace('"','')
|
||||
|
||||
set bail off;
|
||||
-- NB: do NOT enclose role name into double quotes here:
|
||||
connect '$(DSN)' user tmp$c3511 password '123' role αβγδε;
|
||||
select * from v_whoami;
|
||||
set plan on;
|
||||
select * from test;
|
||||
set plan off;
|
||||
commit;
|
||||
for r in (tmp_role1,tmp_role2):
|
||||
with act.db.connect(user = tmp_user.name, password = tmp_user.password, role = r.name.replace('"','')) as con:
|
||||
cur = con.cursor()
|
||||
cur.execute('select * from v_whoami')
|
||||
col = cur.description
|
||||
for r in cur:
|
||||
for i in range(len(col)):
|
||||
print(' '.join((col[i][0], ':', r[i])))
|
||||
|
||||
-- NB: do NOT enclose role name into double quotes here:
|
||||
connect '$(DSN)' user tmp$c3511 password '123' role Groß;
|
||||
select * from v_whoami;
|
||||
set plan on;
|
||||
select * from test;
|
||||
set plan off;
|
||||
commit;
|
||||
"""
|
||||
act.expected_stdout = expected_stdout
|
||||
act.stdout = capsys.readouterr().out
|
||||
assert act.clean_stdout == act.clean_expected_stdout
|
||||
|
||||
act_1 = isql_act('db', test_script_1)
|
||||
|
||||
expected_stdout_1 = """
|
||||
CUR_USER TMP$C3511
|
||||
MON_ROLE αβγδε
|
||||
CUR_ROLE αβγδε
|
||||
PLAN (TEST NATURAL)
|
||||
|
||||
CUR_USER TMP$C3511
|
||||
MON_ROLE Groß
|
||||
CUR_ROLE Groß
|
||||
PLAN (TEST NATURAL)
|
||||
"""
|
||||
|
||||
|
||||
@pytest.mark.version('>=3.0')
|
||||
@pytest.mark.platform('Linux')
|
||||
def test_1(act_1: Action, tmp_user: User):
|
||||
act_1.expected_stdout = expected_stdout_1
|
||||
act_1.execute()
|
||||
assert act_1.clean_stdout == act_1.clean_expected_stdout
|
||||
|
||||
|
||||
act_2 = python_act('db_2')
|
||||
|
||||
expected_stdout_2 = """
|
||||
Done.
|
||||
"""
|
||||
|
||||
@pytest.mark.skip('FIXME: Not IMPLEMENTED')
|
||||
@pytest.mark.version('>=3.0')
|
||||
@pytest.mark.platform('Windows')
|
||||
def test_2(act_2: Action, tmp_user: User):
|
||||
pytest.fail("Not IMPLEMENTED")
|
||||
|
||||
# test_script_2
|
||||
#---
|
||||
#
|
||||
# import os
|
||||
#
|
||||
# os.environ["ISC_USER"] = 'SYSDBA'
|
||||
# os.environ["ISC_PASSWORD"] = 'masterkey'
|
||||
#
|
||||
# cur = db_conn.cursor()
|
||||
# cur.execute("create or alter user tmp$c3511 password '123' using plugin Srp")
|
||||
# cur.execute('create table test(id int)')
|
||||
# cur.execute('create role "Groß"')
|
||||
# db_conn.commit()
|
||||
#
|
||||
# cur.execute('grant "Groß" to tmp$c3511')
|
||||
# cur.execute('grant select on test to "Groß"')
|
||||
# db_conn.commit()
|
||||
#
|
||||
# # NB: do NOT enclose rolename Groß in double quotes here
|
||||
# # (this was needed in FB 2.5.x only; should NOT be necessarry in FB 3.x+):
|
||||
# con=fdb.connect(dsn = dsn, charset = 'utf8', utf8params = True, user = 'tmp$c3511', password = '123', role='Groß')
|
||||
#
|
||||
# cur=con.cursor()
|
||||
# cur.execute("select * from test");
|
||||
# for r in cur:
|
||||
# pass
|
||||
#
|
||||
# print('Done.')
|
||||
# cur.close()
|
||||
# con.close()
|
||||
#
|
||||
# con=fdb.connect(dsn = dsn)
|
||||
# con.execute_immediate('drop user tmp$c3511 using plugin Srp')
|
||||
# con.commit()
|
||||
# con.close()
|
||||
#
|
||||
#
|
||||
#---
|
||||
|
Loading…
Reference in New Issue
Block a user