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_5305_test.py

166 lines
4.6 KiB
Python

#coding:utf-8
#
# id: bugs.core_5305
# title: CASCADE UPDATE fails for self-referencing FK
# decription:
# Checked on 4.0.0.326, WI-V3.0.1.32573
#
# tracker_id: CORE-5305
# min_versions: ['3.0.1']
# versions: 3.0.1
# qmid: None
import pytest
from firebird.qa import db_factory, isql_act, Action
# version: 3.0.1
# resources: None
substitutions_1 = []
init_script_1 = """"""
db_1 = db_factory(sql_dialect=3, init=init_script_1)
test_script_1 = """
set list on;
recreate table test1(
x int,
y int,
constraint test1_pk primary key(x),
constraint test1_fk foreign key(y) references test1(x) on update cascade
);
commit;
insert into test1 (x, y) values (1, null);
insert into test1 (x, y) values (2, null);
insert into test1 (x, y) values (3, 1);
commit;
-- 4.0.0.322 - OK
-- 3.0.0.32483:
-- Statement failed, SQLSTATE = 23000
-- violation of FOREIGN KEY constraint "test1_FK" on table "test1"
-- -Foreign key reference target does not exist
-- -Problematic key value is ("y" = 1)
update test1 set x = -x;
select 'test1' as what, a.* from test1 a order by x;
commit;
--------------------------------------------------------------------------------------
-- Sample from core-3362, 03/Jan/14 05:07 PM:
-- ==========================================
recreate table test2(
x int, y int,
constraint t_pk primary key(x),
constraint t_fk foreign key(y) references test2(x) on update cascade -- SELF-REFERENCING
);
create descending index t_x_desc on test2(x);
commit;
insert into test2(x, y) values(1, null);
insert into test2(x, y) values(2, 1 );
insert into test2(x, y) values(3, 2 );
insert into test2(x, y) values(4, 3 );
insert into test2(x, y) values(5, 4 );
update test2 set y=5 where x=1; -- "closure" of chain
commit;
update test2 set x = y + 1;
select 'test2' as what, a.* from test2 a order by x;
commit;
----------------------------------------------------------------------------
-- Sample from core-3362, 14/May/15 06:40 AM
-- =========================================
recreate table test3(
id int constraint test_pk_id primary key using index test_pk_id,
pid int constraint test_fk_pid2id references test3(id)
on update SET NULL
);
commit;
insert into test3 values( 5, null );
insert into test3 values( 4, 5 );
insert into test3 values( 3, 4 );
insert into test3 values( 2, 3 );
insert into test3 values( 1, 2 );
update test3 set pid=1 where id=5; --"closure" of chain
commit;
update test3 set id = id + 1 order by id desc;
select 'test3' as what, a.* from test3 a order by id;
commit;
"""
act_1 = isql_act('db_1', test_script_1, substitutions=substitutions_1)
expected_stdout_1 = """
WHAT test1
X -3
Y -1
WHAT test1
X -2
Y <null>
WHAT test1
X -1
Y <null>
WHAT test2
X 2
Y 6
WHAT test2
X 3
Y 2
WHAT test2
X 4
Y 3
WHAT test2
X 5
Y 4
WHAT test2
X 6
Y 5
WHAT test3
ID 2
PID <null>
WHAT test3
ID 3
PID <null>
WHAT test3
ID 4
PID <null>
WHAT test3
ID 5
PID <null>
WHAT test3
ID 6
PID <null>
"""
@pytest.mark.version('>=3.0.1')
def test_1(act_1: Action):
act_1.expected_stdout = expected_stdout_1
act_1.execute()
assert act_1.clean_expected_stdout == act_1.clean_stdout