2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
2022-01-25 22:55:48 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
ID: issue-5896
|
|
|
|
ISSUE: 5896
|
|
|
|
TITLE: Can't create the shadow file
|
2024-12-30 10:02:31 +01:00
|
|
|
DESCRIPTION: Shadow file can not be created during restore when '-use_all_space' option is used
|
2022-01-25 22:55:48 +01:00
|
|
|
JIRA: CORE-5630
|
2024-12-30 10:02:31 +01:00
|
|
|
NOTES:
|
|
|
|
[30.12.2024] pzotov
|
|
|
|
Splitted expected out for FB 6.x because columns rdb$file_sequence, rdb$file_start and rdb$file_length
|
|
|
|
have NULLs instead of zeroes, see:
|
|
|
|
https://github.com/FirebirdSQL/firebird/commit/f0740d2a3282ed92a87b8e0547139ba8efe61173
|
|
|
|
("Wipe out multi-file database support (#8047)")
|
|
|
|
Checked on 6.0.0.565
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
2024-05-10 00:13:53 +02:00
|
|
|
import locale
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
import pytest
|
2021-12-09 19:26:42 +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
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
db = db_factory()
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2024-12-30 10:02:31 +01:00
|
|
|
act = python_act('db', substitutions=[('[ \t]+', ' ')])
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2024-12-30 10:02:31 +01:00
|
|
|
expected_stdout_5x = """
|
2021-04-26 20:07:00 +02:00
|
|
|
RDB$FILE_SEQUENCE 0
|
|
|
|
RDB$FILE_START 0
|
|
|
|
RDB$FILE_LENGTH 0
|
|
|
|
RDB$FILE_FLAGS 1
|
|
|
|
RDB$SHADOW_NUMBER 1
|
2024-12-30 10:02:31 +01:00
|
|
|
S_HASH 1499836372373901520
|
2021-12-09 19:26:42 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2024-12-30 10:02:31 +01:00
|
|
|
expected_stdout_6x = """
|
|
|
|
RDB$FILE_SEQUENCE <null>
|
|
|
|
RDB$FILE_START <null>
|
|
|
|
RDB$FILE_LENGTH <null>
|
2021-04-26 20:07:00 +02:00
|
|
|
RDB$FILE_FLAGS 1
|
|
|
|
RDB$SHADOW_NUMBER 1
|
2024-12-30 10:02:31 +01:00
|
|
|
S_HASH 1499836372373901520
|
2021-12-09 19:26:42 +01:00
|
|
|
"""
|
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
fdb_file = temp_file('core_5630.fdb')
|
|
|
|
fbk_file = temp_file('core_5630.fbk')
|
|
|
|
shd_file = temp_file('core_5630.shd')
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
@pytest.mark.version('>=3.0.3')
|
2022-01-25 22:55:48 +01:00
|
|
|
def test_1(act: Action, fdb_file: Path, fbk_file: Path, shd_file: Path):
|
2021-12-09 19:26:42 +01:00
|
|
|
init_ddl = f"""
|
2024-05-10 00:13:53 +02:00
|
|
|
set bail on;
|
|
|
|
set list on;
|
|
|
|
|
|
|
|
create database 'localhost:{fdb_file}' user {act.db.user} password '{act.db.password}';
|
|
|
|
|
|
|
|
recreate table test(s varchar(30));
|
|
|
|
commit;
|
|
|
|
|
|
|
|
create or alter view v_shadow_info as
|
|
|
|
select
|
|
|
|
rdb$file_sequence -- 0
|
|
|
|
,rdb$file_start -- 0
|
|
|
|
,rdb$file_length -- 0
|
|
|
|
,rdb$file_flags -- 1
|
|
|
|
,rdb$shadow_number -- 1
|
|
|
|
from rdb$files
|
|
|
|
where lower(rdb$file_name) containing lower('core_5630.shd')
|
|
|
|
;
|
|
|
|
|
|
|
|
insert into test select 'line #' || lpad(row_number()over(), 3, '0' ) from rdb$types rows 200;
|
|
|
|
commit;
|
|
|
|
|
|
|
|
create shadow 1 '{shd_file}';
|
|
|
|
commit;
|
|
|
|
set list on;
|
|
|
|
select * from v_shadow_info;
|
2024-12-30 10:02:31 +01:00
|
|
|
select hash( list(s) ) as s_hash from test;
|
2024-05-10 00:13:53 +02:00
|
|
|
quit;
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
2024-05-10 00:13:53 +02:00
|
|
|
|
2024-12-30 10:02:31 +01:00
|
|
|
act.expected_stdout = expected_stdout_5x if act.is_version('<6') else expected_stdout_6x
|
2024-05-10 00:13:53 +02:00
|
|
|
act.isql(switches=['-q'], input = init_ddl, connect_db=False, combine_output = True, io_enc = locale.getpreferredencoding())
|
2022-01-25 22:55:48 +01:00
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|
2021-12-09 19:26:42 +01:00
|
|
|
#
|
2022-01-25 22:55:48 +01:00
|
|
|
with act.connect_server() as srv:
|
|
|
|
srv.database.backup(database=fdb_file, backup=fbk_file)
|
2021-12-09 19:26:42 +01:00
|
|
|
srv.wait()
|
|
|
|
#
|
2022-01-25 22:55:48 +01:00
|
|
|
fdb_file.unlink()
|
|
|
|
shd_file.unlink()
|
2021-12-09 19:26:42 +01:00
|
|
|
#
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2024-05-10 00:13:53 +02:00
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------------
|
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
act.gbak(switches=['-c', '-use_all_space', str(fbk_file), act.get_dsn(fdb_file)])
|
2021-12-09 19:26:42 +01:00
|
|
|
# Check that we have the same data in DB tables
|
|
|
|
sql_text = """
|
|
|
|
set list on;
|
|
|
|
select * from v_shadow_info;
|
2024-12-30 10:02:31 +01:00
|
|
|
select hash( list(s) ) as s_hash from test;
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
|
|
|
act.reset()
|
2024-05-10 00:13:53 +02:00
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------------
|
2024-12-30 10:02:31 +01:00
|
|
|
act.expected_stdout = expected_stdout_5x if act.is_version('<6') else expected_stdout_6x
|
2024-05-10 00:13:53 +02:00
|
|
|
act.isql(switches=['-q', act.get_dsn(fdb_file)], input=sql_text, connect_db=False, combine_output = True, io_enc = locale.getpreferredencoding())
|
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|