6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-22 21:43:06 +01:00
firebird-qa/tests/bugs/core_1606_test.py

130 lines
4.7 KiB
Python

#coding:utf-8
"""
ID: issue-2027
ISSUE: 2027
TITLE: Ability to insert child record if parent record is locked but foreign key target unchanged
DESCRIPTION:
Master table has two record, both are updated but without changing PK field.
Than we check that we CAN add rows in detail table with references to existed PK from main,
and even can change FK-values in these added rows, but can do it only with maintenance that
MAIN table's PK exists for new values in FK
JIRA: CORE-1606
FBTEST: bugs.core_1606
"""
import pytest
from firebird.qa import *
db = db_factory()
test_script = """
set term ^;
execute block as
begin
execute statement 'drop sequence g';
when any do begin end
end
^
set term ;^
commit;
create sequence g;
commit;
recreate table tdetl(id int constraint tdetl_pk primary key, pid int);
commit;
recreate table tmain(id int constraint tmain_pk primary key, x int);
commit;
alter table tdetl add constraint tdetl_fk foreign key(pid) references tmain(id);
commit;
insert into tmain(id, x) values(1, 100);
insert into tmain(id, x) values(2, 200);
commit;
set list on;
set transaction no wait;
--set count on;
update tmain set id = id, x = -x*10 where id=1;
update tmain set id = id, x = -x*20 where id=2;
set term ^;
execute block returns(id int, pid int) as
declare s varchar(1024);
begin
s = 'insert into tdetl(id, pid) select gen_id(g,1), cast( ? as int) from rdb$types rows 3';
/*
-- todo later, after fix CORE-4796
'merge into tdetl t '
|| 'using ( select 5 as id, 1 as pid from rdb$types rows 2 ) s '
|| 'on t.id=s.id '
|| 'when matched then update set t.pid = s.pid '
|| 'when not matched then insert values( s.id, s.pid)';
*/
execute statement ( s ) ( 1 ) -------------------------------------- [1]: add rows with pid=1
on external 'localhost:' || rdb$get_context('SYSTEM','DB_NAME')
as user 'sysdba' password 'masterkey' role 'RCHILD';
execute statement ( s ) ( 2 ) -------------------------------------- [2]: add rows with pid=2
on external 'localhost:' || rdb$get_context('SYSTEM','DB_NAME')
as user 'sysdba' password 'masterkey' role 'RCHILD';
execute statement ('update tdetl set pid = 3 - pid') -- rows with pid=1 that were inserted on [1] will have pid=2 and vice versa
on external 'localhost:' || rdb$get_context('SYSTEM','DB_NAME')
as user 'sysdba' password 'masterkey' role 'RCHILD';
for
execute statement 'select id,pid from tdetl order by id'
on external 'localhost:' || rdb$get_context('SYSTEM','DB_NAME')
as user 'sysdba' password 'masterkey' role 'RCHILD'
into id,pid
do
suspend;
end
^
set term ;^
commit;
-- ||||||||||||||||||||||||||||
-- ###################################||| FB 4.0+, SS and SC |||##############################
-- ||||||||||||||||||||||||||||
-- If we check SS or SC and ExtConnPoolLifeTime > 0 (config parameter FB 4.0+) then current
-- DB (bugs.core_NNNN.fdb) will be 'captured' by firebird.exe process and fbt_run utility
-- will not able to drop this database at the final point of test.
-- Moreover, DB file will be hold until all activity in firebird.exe completed and AFTER this
-- we have to wait for <ExtConnPoolLifeTime> seconds after it (discussion and small test see
-- in the letter to hvlad and dimitr 13.10.2019 11:10).
-- This means that one need to kill all connections to prevent from exception on cleanup phase:
-- SQLCODE: -901 / lock time-out on wait transaction / object <this_test_DB> is in use
-- #############################################################################################
delete from mon$attachments where mon$attachment_id != current_connection;
commit;
"""
act = isql_act('db', test_script)
expected_stdout = """
ID 1
PID 2
ID 2
PID 2
ID 3
PID 2
ID 4
PID 1
ID 5
PID 1
ID 6
PID 1
"""
@pytest.mark.es_eds
@pytest.mark.version('>=3')
def test_1(act: Action):
act.expected_stdout = expected_stdout
act.execute()
assert act.clean_stdout == act.clean_expected_stdout