2 @message |
firebird.driver.types.InterfaceError: Result code does not match request code
LOG DETAILS:
2025-06-30 16:13:22.092
2025-06-30 16:13:22.099 act = <firebird.qa.plugin.Action object at [hex]>
2025-06-30 16:13:22.107 capsys = <_pytest.capture.CaptureFixture object at [hex]>
2025-06-30 16:13:22.116
2025-06-30 16:13:22.123 @pytest.mark.encryption
2025-06-30 16:13:22.129 @pytest.mark.version('>=3.0.2')
2025-06-30 16:13:22.135 def test_1(act: Action, capsys):
2025-06-30 16:13:22.141 map_dbo = {}
2025-06-30 16:13:22.147
2025-06-30 16:13:22.155 # Query to find first generators page number:
2025-06-30 16:13:22.163 first_gens_page_sql = f"""
2025-06-30 16:13:22.172 select p.rdb$page_number
2025-06-30 16:13:22.184 from rdb$pages p
2025-06-30 16:13:22.193 where p.rdb$page_type = {GENS_PAGE}
2025-06-30 16:13:22.200 order by p.rdb$page_number desc
2025-06-30 16:13:22.206 rows 1
2025-06-30 16:13:22.216 """
2025-06-30 16:13:22.228
2025-06-30 16:13:22.237 # Query to find relation_id and first PP for 'TEST' table:
2025-06-30 16:13:22.247 first_pp_sql = f"""
2025-06-30 16:13:22.256 select p.rdb$relation_id, p.rdb$page_number
2025-06-30 16:13:22.264 from rdb$pages p
2025-06-30 16:13:22.272 join rdb$relations r on p.rdb$relation_id = r.rdb$relation_id
2025-06-30 16:13:22.280 where r.rdb$relation_name=upper('TEST') and p.rdb$page_type = {POINTER_PAGE}
2025-06-30 16:13:22.289 order by p.rdb$page_number
2025-06-30 16:13:22.296 rows 1
2025-06-30 16:13:22.303 """
2025-06-30 16:13:22.310
2025-06-30 16:13:22.320 broken_pages_map = { POINTER_PAGE : [], DATA_PAGE : [], IDX_ROOT_PAGE : [], IDX_B_TREE : [], BLOB_PAGE : [], GENS_PAGE : [] }
2025-06-30 16:13:22.331 with act.db.connect() as con:
2025-06-30 16:13:22.341 fill_dbo(con, map_dbo)
2025-06-30 16:13:22.350 c = con.cursor()
2025-06-30 16:13:22.357
2025-06-30 16:13:22.363 broken_pages_map[GENS_PAGE] = [c.execute(first_gens_page_sql).fetchone()[0],]
2025-06-30 16:13:22.377
2025-06-30 16:13:22.388 test_rel_id, test_rel_first_pp = c.execute(first_pp_sql).fetchone()
2025-06-30 16:13:22.398
2025-06-30 16:13:22.404 # Found first page for each of three types: Data, Index and Blob
2025-06-30 16:13:22.409 # (loop starts from first PointerPage of table 'TEST')
2025-06-30 16:13:22.418 brk_datapage = brk_indxpage = brk_blobpage = -1
2025-06-30 16:13:22.425
2025-06-30 16:13:22.431 for page_no in range(test_rel_first_pp, con.info.pages_allocated):
2025-06-30 16:13:22.438 > page_type, relation_id, page_info = parse_page_header(con, page_no, map_dbo)
2025-06-30 16:13:22.444
2025-06-30 16:13:22.450 tests/bugs/core_5501_test.py:423:
2025-06-30 16:13:22.456 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
2025-06-30 16:13:22.464
2025-06-30 16:13:22.470 con = Connection[3000], page_number = 406
2025-06-30 16:13:22.476 map_dbo = {(128, -1): ('TEST', ''), (128, 0): ('TEST', 'TEST_S_UNQ')}
2025-06-30 16:13:22.481
2025-06-30 16:13:22.487 def parse_page_header(con: Connection, page_number: int, map_dbo: Dict):
2025-06-30 16:13:22.493 > page_buffer = con.info.get_page_content(page_number)
2025-06-30 16:13:22.499
2025-06-30 16:13:22.507 tests/bugs/core_5501_test.py:263:
2025-06-30 16:13:22.518 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
2025-06-30 16:13:22.529
2025-06-30 16:13:22.540 self = <firebird.driver.core.DatabaseInfoProvider object at [hex]>
2025-06-30 16:13:22.552 page_number = 406
2025-06-30 16:13:22.561
2025-06-30 16:13:22.567 def get_page_content(self, page_number: int) -> bytes:
2025-06-30 16:13:22.573 """Returns content of single database page.
2025-06-30 16:13:22.578
2025-06-30 16:13:22.588 Arguments:
2025-06-30 16:13:22.600 page_number: Sequence number of database page to be fetched from server.
2025-06-30 16:13:22.610 """
2025-06-30 16:13:22.620 > return self.get_info(DbInfoCode.PAGE_CONTENTS, page_number)
2025-06-30 16:13:22.630
2025-06-30 16:13:22.638 ../lib/python3.11/site-packages/firebird/driver/core.py:1338:
2025-06-30 16:13:22.646 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
2025-06-30 16:13:22.658
2025-06-30 16:13:22.669 self = <firebird.driver.core.DatabaseInfoProvider object at [hex]>
2025-06-30 16:13:22.677 info_code = <DbInfoCode.PAGE_CONTENTS: 113>, page_number = 406
2025-06-30 16:13:22.684
2025-06-30 16:13:22.692 def get_info(self, info_code: DbInfoCode, page_number: int=None) -> Any:
2025-06-30 16:13:22.699 """Returns requested information from associated attachment.
2025-06-30 16:13:22.707
2025-06-30 16:13:22.718 Arguments:
2025-06-30 16:13:22.731 info_code: A code specifying the required information.
2025-06-30 16:13:22.739 page_number: A page number for `DbInfoCode.PAGE_CONTENTS` request. Ignored for other requests.
2025-06-30 16:13:22.748
2025-06-30 16:13:22.761 Returns:
2025-06-30 16:13:22.774 The data type of returned value depends on information required.
2025-06-30 16:13:22.788 """
2025-06-30 16:13:22.802 if info_code in self._cache:
2025-06-30 16:13:22.811 return self._cache[info_code]
2025-06-30 16:13:22.818 if info_code not in self._handlers:
2025-06-30 16:13:22.825 raise NotSupportedError(f"Info code {info_code} not supported by engine version {self.__engine_version}")
2025-06-30 16:13:22.831 self.response.clear()
2025-06-30 16:13:22.837 request = bytes([info_code])
2025-06-30 16:13:22.843 if info_code == DbInfoCode.PAGE_CONTENTS:
2025-06-30 16:13:22.849 request += (4).to_bytes(2, 'little')
2025-06-30 16:13:22.856 request += page_number.to_bytes(4, 'little')
2025-06-30 16:13:22.863 if len(self.response.raw) < self.page_size + 10:
2025-06-30 16:13:22.870 self.response.resize(self.page_size + 10)
2025-06-30 16:13:22.883 self._get_data(request)
2025-06-30 16:13:22.892 tag = self.response.get_tag()
2025-06-30 16:13:22.900 if request[0] != tag:
2025-06-30 16:13:22.907 if info_code in (DbInfoCode.ACTIVE_TRANSACTIONS, DbInfoCode.LIMBO):
2025-06-30 16:13:22.912 # isc_info_active_transactions and isc_info_limbo with no transactions to
2025-06-30 16:13:22.921 # report returns empty buffer and does not follow this rule
2025-06-30 16:13:22.929 pass
2025-06-30 16:13:22.937 elif tag == isc_info_error: # pragma: no cover
2025-06-30 16:13:22.945 raise InterfaceError("An error response was received")
2025-06-30 16:13:22.951 else: # pragma: no cover
2025-06-30 16:13:22.957 > raise InterfaceError("Result code does not match request code")
2025-06-30 16:13:22.962 E firebird.driver.types.InterfaceError: Result code does not match request code
2025-06-30 16:13:22.972
2025-06-30 16:13:22.979 ../lib/python3.11/site-packages/firebird/driver/core.py:1316: InterfaceError
2025-06-30 16:13:22.986 ---------------------------- Captured stdout setup -----------------------------
2025-06-30 16:13:22.993 Creating db: localhost:/var/tmp/qa_2024/test_11120/test.fdb [page_size=8192, sql_dialect=None, charset='NONE', user=SYSDBA, password=masterkey]
|
3 #text |
act = <firebird.qa.plugin.Action pytest object at [hex]>
capsys = <_pytest.capture.CaptureFixture pytest object at [hex]>
@pytest.mark.encryption
@pytest.mark.version('>=3.0.2')
def test_1(act: Action, capsys):
map_dbo = {}
# Query to find first generators page number:
first_gens_page_sql = f"""
select p.rdb$page_number
from rdb$pages p
where p.rdb$page_type = {GENS_PAGE}
order by p.rdb$page_number desc
rows 1
"""
# Query to find relation_id and first PP for 'TEST' table:
first_pp_sql = f"""
select p.rdb$relation_id, p.rdb$page_number
from rdb$pages p
join rdb$relations r on p.rdb$relation_id = r.rdb$relation_id
where r.rdb$relation_name=upper('TEST') and p.rdb$page_type = {POINTER_PAGE}
order by p.rdb$page_number
rows 1
"""
broken_pages_map = { POINTER_PAGE : [], DATA_PAGE : [], IDX_ROOT_PAGE : [], IDX_B_TREE : [], BLOB_PAGE : [], GENS_PAGE : [] }
with act.db.connect() as con:
fill_dbo(con, map_dbo)
c = con.cursor()
broken_pages_map[GENS_PAGE] = [c.execute(first_gens_page_sql).fetchone()[0],]
test_rel_id, test_rel_first_pp = c.execute(first_pp_sql).fetchone()
# Found first page for each of three types: Data, Index and Blob
# (loop starts from first PointerPage of table 'TEST')
brk_datapage = brk_indxpage = brk_blobpage = -1
for page_no in range(test_rel_first_pp, con.info.pages_allocated):
> page_type, relation_id, page_info = parse_page_header(con, page_no, map_dbo)
tests/bugs/core_5501_test.py:423:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
con = Connection[3000], page_number = 406
map_dbo = {(128, -1): ('TEST', ''), (128, 0): ('TEST', 'TEST_S_UNQ')}
def parse_page_header(con: Connection, page_number: int, map_dbo: Dict):
> page_buffer = con.info.get_page_content(page_number)
tests/bugs/core_5501_test.py:263:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = <firebird.driver.core.DatabaseInfoProvider pytest object at [hex]>
page_number = 406
def get_page_content(self, page_number: int) -> bytes:
"""Returns content of single database page.
Arguments:
page_number: Sequence number of database page to be fetched from server.
"""
> return self.get_info(DbInfoCode.PAGE_CONTENTS, page_number)
../lib/python3.11/site-packages/firebird/driver/core.py:1338:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = <firebird.driver.core.DatabaseInfoProvider pytest object at [hex]>
info_code = <DbInfoCode.PAGE_CONTENTS: 113>, page_number = 406
def get_info(self, info_code: DbInfoCode, page_number: int=None) -> Any:
"""Returns requested information from associated attachment.
Arguments:
info_code: A code specifying the required information.
page_number: A page number for `DbInfoCode.PAGE_CONTENTS` request. Ignored for other requests.
Returns:
The data type of returned value depends on information required.
"""
if info_code in self._cache:
return self._cache[info_code]
if info_code not in self._handlers:
raise NotSupportedError(f"Info code {info_code} not supported by engine version {self.__engine_version}")
self.response.clear()
request = bytes([info_code])
if info_code == DbInfoCode.PAGE_CONTENTS:
request += (4).to_bytes(2, 'little')
request += page_number.to_bytes(4, 'little')
if len(self.response.raw) < self.page_size + 10:
self.response.resize(self.page_size + 10)
self._get_data(request)
tag = self.response.get_tag()
if request[0] != tag:
if info_code in (DbInfoCode.ACTIVE_TRANSACTIONS, DbInfoCode.LIMBO):
# isc_info_active_transactions and isc_info_limbo with no transactions to
# report returns empty buffer and does not follow this rule
pass
elif tag == isc_info_error: # pragma: no cover
raise InterfaceError("An error response was received")
else: # pragma: no cover
> raise InterfaceError("Result code does not match request code")
E firebird.driver.types.InterfaceError: Result code does not match request code
../lib/python3.11/site-packages/firebird/driver/core.py:1316: InterfaceError
|