6
0
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:
zotov 2022-05-28 11:48:07 +03:00
parent e9345f3c8e
commit dbf056192a

View File

@ -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()
#
#
#---