2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
2022-01-25 22:55:48 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
ID: issue-5569
|
|
|
|
ISSUE: 5569
|
2022-09-20 10:15:10 +02:00
|
|
|
TITLE: Error messages differ when regular user tries to RESTORE database, depending on his default role and (perhaps) system privilege USE_GBAK_UTILITY
|
2022-01-25 22:55:48 +01:00
|
|
|
DESCRIPTION:
|
|
|
|
JIRA: CORE-5291
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_5291
|
2022-09-20 10:15:10 +02:00
|
|
|
NOTES:
|
|
|
|
[20.09.2022] pzotov
|
|
|
|
One need to take in account that gbak produces error message with specifying PORT number after localhost,
|
|
|
|
i.e.: "failed to create database localhost/NNNNN:<dbname>" (perhaps, only for non-default ports?).
|
|
|
|
Checked on 5.0.0.591, 4.0.1.2692.
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
import pytest
|
2021-12-06 19:23:35 +01:00
|
|
|
from pathlib import Path
|
2022-01-25 22:55:48 +01:00
|
|
|
from firebird.qa import *
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2023-11-30 21:09:21 +01:00
|
|
|
substitutions = [ ('gbak: ERROR:([ \t])*no permission for CREATE access to DATABASE.*', 'gbak: ERROR:no permission for CREATE access to DATABASE'),
|
|
|
|
('gbak: ERROR:([ \t])*failed to create database .*', 'gbak: ERROR:failed to create database')
|
|
|
|
]
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-09-20 10:15:10 +02:00
|
|
|
db = db_factory()
|
2021-12-06 19:23:35 +01:00
|
|
|
|
2022-09-20 10:15:10 +02:00
|
|
|
tmp_user_1 = user_factory('db', name='tmp$c5291_1', password='123')
|
|
|
|
tmp_user_2 = user_factory('db', name='tmp$c5291_2', password='456')
|
|
|
|
tmp_role = role_factory('db', name='role_for_use_gbak_utility')
|
2021-12-06 19:23:35 +01:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
act = python_act('db', substitutions=substitutions)
|
2021-12-14 20:56:34 +01:00
|
|
|
|
2021-12-06 19:23:35 +01:00
|
|
|
fbk_file = temp_file('tmp_core_5291.fbk')
|
|
|
|
fdb_file_1 = temp_file('tmp_core_5291_1.fdb')
|
|
|
|
fdb_file_2 = temp_file('tmp_core_5291_2.fdb')
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2023-11-30 21:09:21 +01:00
|
|
|
expected_stdout = """
|
|
|
|
Restore using SERVICES, user has NO default role:
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak: ERROR:no permission for CREATE access to DATABASE
|
2023-11-30 21:09:21 +01:00
|
|
|
gbak: ERROR:failed to create database
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak: ERROR: Exiting before completion due to errors
|
|
|
|
gbak:Exiting before completion due to errors
|
2023-11-30 21:09:21 +01:00
|
|
|
Restore using GBAK, user has NO default role:
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak: ERROR:no permission for CREATE access to DATABASE
|
2023-11-30 21:09:21 +01:00
|
|
|
gbak: ERROR:failed to create database
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak:Exiting before completion due to errors
|
2023-11-30 21:09:21 +01:00
|
|
|
Restore using SERVICES, user HAS default role with system privileges:
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak: ERROR:no permission for CREATE access to DATABASE
|
2023-11-30 21:09:21 +01:00
|
|
|
gbak: ERROR:failed to create database
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak: ERROR: Exiting before completion due to errors
|
|
|
|
gbak:Exiting before completion due to errors
|
2023-11-30 21:09:21 +01:00
|
|
|
Restore using GBAK, user HAS default role with system privileges:
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak: ERROR:no permission for CREATE access to DATABASE
|
2023-11-30 21:09:21 +01:00
|
|
|
gbak: ERROR:failed to create database
|
2021-04-26 20:07:00 +02:00
|
|
|
gbak:Exiting before completion due to errors
|
2021-12-06 19:23:35 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
@pytest.mark.version('>=4.0')
|
2022-09-20 10:15:10 +02:00
|
|
|
def test_1(act: Action, tmp_user_1: User, tmp_user_2: User, fbk_file: Path, fdb_file_1: Path, fdb_file_2: Path, tmp_role: Role, capsys):
|
2022-01-25 22:55:48 +01:00
|
|
|
with act.db.connect() as con:
|
2022-09-20 10:15:10 +02:00
|
|
|
con.execute_immediate( f'alter role {tmp_role.name} set system privileges to USE_GBAK_UTILITY, SELECT_ANY_OBJECT_IN_DATABASE' )
|
|
|
|
con.execute_immediate( f'grant default {tmp_role.name} to user {tmp_user_2.name}' )
|
2021-12-14 20:56:34 +01:00
|
|
|
#
|
2022-01-25 22:55:48 +01:00
|
|
|
act.gbak(switches=['-b', act.db.dsn, str(fbk_file)])
|
2023-11-30 21:09:21 +01:00
|
|
|
|
|
|
|
#--------------------------------------------------------------------------
|
2021-12-14 20:56:34 +01:00
|
|
|
# User 1
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2023-11-30 21:09:21 +01:00
|
|
|
print('Restore using SERVICES, user has NO default role:')
|
|
|
|
act.gbak(switches=[ '-se', 'localhost:service_mgr'
|
|
|
|
,'-rep', str(fbk_file), str(fdb_file_1)
|
|
|
|
,'-user', tmp_user_1.name
|
|
|
|
,'-pas', tmp_user_1.password
|
|
|
|
]
|
|
|
|
,credentials=False, combine_output = True)
|
|
|
|
print(act.stdout)
|
|
|
|
#--------------------------------------------------------------------------
|
|
|
|
|
2021-12-14 20:56:34 +01:00
|
|
|
# User 1
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2023-11-30 21:09:21 +01:00
|
|
|
print('Restore using GBAK, user has NO default role:')
|
|
|
|
act.gbak(switches=[ '-rep', str(fbk_file), act.get_dsn(fdb_file_2)
|
|
|
|
,'-user', tmp_user_1.name, '-pas', tmp_user_1.password
|
|
|
|
]
|
|
|
|
,credentials=False, combine_output = True)
|
|
|
|
print(act.stdout)
|
|
|
|
#--------------------------------------------------------------------------
|
|
|
|
|
2021-12-14 20:56:34 +01:00
|
|
|
# User 2
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2023-11-30 21:09:21 +01:00
|
|
|
print('Restore using SERVICES, user HAS default role with system privileges:')
|
|
|
|
act.gbak(switches=[ '-se', f'{act.host}:service_mgr'
|
|
|
|
,'-rep', str(fbk_file), str(fdb_file_1)
|
|
|
|
,'-user', tmp_user_2.name
|
|
|
|
,'-pas', tmp_user_2.password
|
|
|
|
]
|
|
|
|
,credentials=False, combine_output = True)
|
|
|
|
print(act.stdout)
|
|
|
|
#--------------------------------------------------------------------------
|
|
|
|
|
2021-12-14 20:56:34 +01:00
|
|
|
# User 2
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2023-11-30 21:09:21 +01:00
|
|
|
print('Restore using GBAK, user HAS default role with system privileges:')
|
|
|
|
act.gbak(switches=[ '-rep', str(fbk_file), act.get_dsn(fdb_file_2),
|
|
|
|
'-user', tmp_user_2.name
|
|
|
|
,'-pas', tmp_user_2.password
|
|
|
|
]
|
|
|
|
,credentials=False, combine_output = True)
|
|
|
|
print(act.stdout)
|
2021-12-14 20:56:34 +01:00
|
|
|
#
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2023-11-30 21:09:21 +01:00
|
|
|
|
|
|
|
act.expected_stdout = expected_stdout
|
|
|
|
act.stdout = capsys.readouterr().out
|
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|