2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
2022-01-25 22:55:48 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
ID: issue-5654
|
2024-11-08 08:19:22 +01:00
|
|
|
ISSUE: https://github.com/FirebirdSQL/firebird/issues/5654
|
2022-01-25 22:55:48 +01:00
|
|
|
TITLE: Regression: could not execute query (select from view with nested view)
|
|
|
|
DESCRIPTION:
|
2024-11-17 13:03:39 +01:00
|
|
|
Test uses queries from ticket but creates user tables instead of rdb$ ones. We ask FB only to prepare query.
|
|
|
|
Before fix this query preparation lasted ~130 seconds with raising '335544382 : request size limit exceeded.
|
2022-01-25 22:55:48 +01:00
|
|
|
JIRA: CORE-5381
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_5381
|
2024-11-08 08:19:22 +01:00
|
|
|
NOTES:
|
2024-11-17 13:03:39 +01:00
|
|
|
[17.11.2024] pzotov
|
|
|
|
Re-implemented. No sense to check execution time or execution plan.
|
|
|
|
We have to ensure only ability of engine to complete prerape_statement.
|
2024-11-08 08:19:22 +01:00
|
|
|
|
2024-11-19 08:13:30 +01:00
|
|
|
[19.11.2024] pzotov
|
|
|
|
Added max allowed time for prepare duration and appropriate check (suggested by dimitr).
|
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
Confirmed bug on 3.0.1.32609 (27-sep-2016), got in trace:
|
|
|
|
2024-11-08T00:42:49.8710 ERROR AT JStatement::prepare
|
|
|
|
335544382 : request size limit exceeded
|
|
|
|
|
2024-11-10 13:37:21 +01:00
|
|
|
Checked on 3.0.13.33794, 4.0.6.3168, 5.0.2.1553, 6.0.0.520
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
2024-11-19 08:13:30 +01:00
|
|
|
import datetime as py_dt
|
|
|
|
from datetime import timedelta
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
import pytest
|
2022-01-25 22:55:48 +01:00
|
|
|
from firebird.qa import *
|
2024-11-08 08:19:22 +01:00
|
|
|
from firebird.driver import DatabaseError
|
|
|
|
|
2024-11-19 08:13:30 +01:00
|
|
|
###################
|
|
|
|
MAX_PREPARE_TIME_MS=1000
|
|
|
|
###################
|
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
init_sql = """
|
|
|
|
recreate view test_view as select 1 x from rdb$database;
|
|
|
|
recreate view inner_view as select 1 x from rdb$database;
|
|
|
|
|
|
|
|
recreate table rdb_types(
|
|
|
|
id int generated by default as identity constraint pk_rdb_types primary key
|
|
|
|
,type_id int
|
|
|
|
);
|
2022-01-25 22:55:48 +01:00
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
recreate table rdb_rels(
|
|
|
|
id int generated by default as identity constraint pk_rdb_rels primary key
|
|
|
|
,rel_id int
|
|
|
|
);
|
2022-01-25 22:55:48 +01:00
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
recreate table rdb_deps(
|
|
|
|
id int generated by default as identity constraint pk_rdb_deps primary key
|
|
|
|
,dep_type int
|
|
|
|
);
|
2022-01-25 22:55:48 +01:00
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
recreate table rdb_colls(
|
|
|
|
id int generated by default as identity constraint pk_rdb_colls primary key
|
|
|
|
,coll_id int
|
|
|
|
);
|
|
|
|
|
|
|
|
recreate table rdb_flds(
|
|
|
|
id int generated by default as identity constraint pk_rdb_flds primary key
|
|
|
|
,fld_type_id int
|
|
|
|
);
|
|
|
|
|
|
|
|
recreate table rdb_csets(
|
|
|
|
id int generated by default as identity constraint pk_rdb_csets primary key
|
|
|
|
,cset_id int
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
recreate table t1(id bigint not null primary key using index pk_t1_id);
|
|
|
|
recreate table t2(id bigint not null primary key using index pk_t2_id);
|
|
|
|
recreate table t3(id bigint not null primary key using index pk_t3_id);
|
|
|
|
recreate table t4(id bigint not null primary key using index pk_t4_id);
|
|
|
|
recreate table t5(id bigint not null primary key using index pk_t5_id);
|
|
|
|
recreate table t6(id bigint not null primary key using index pk_t6_id);
|
|
|
|
recreate table t7(id bigint not null primary key using index pk_t7_id);
|
|
|
|
recreate table t8(id bigint not null primary key using index pk_t8_id);
|
|
|
|
|
2024-11-17 13:03:39 +01:00
|
|
|
recreate view inner_view as
|
2024-11-08 08:19:22 +01:00
|
|
|
select t1.id
|
|
|
|
from t1
|
|
|
|
inner join t8 b on b.id = t1.id
|
|
|
|
inner join t2 c on c.id = t1.id
|
|
|
|
left join t4 d on d.id = t1.id
|
|
|
|
inner join t5 e on e.id = t1.id
|
|
|
|
left join t6 f on f.id = t1.id
|
|
|
|
inner join rdb_types g1 on g1.type_id = t1.id
|
|
|
|
inner join rdb_rels g2 on g2.rel_id = t1.id
|
|
|
|
inner join rdb_deps g3 on g3.dep_type = t1.id
|
|
|
|
inner join rdb_colls g4 on g4.coll_id = t1.id
|
|
|
|
inner join rdb_flds g5 on g5.fld_type_id = t1.id
|
|
|
|
inner join rdb_csets g6 on g6.cset_id = t1.id
|
2021-04-26 20:07:00 +02:00
|
|
|
;
|
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
recreate view test_view
|
2022-01-25 22:55:48 +01:00
|
|
|
as
|
2024-11-08 08:19:22 +01:00
|
|
|
select t1.id
|
|
|
|
from t1
|
|
|
|
inner join inner_view on inner_view.id = t1.id
|
|
|
|
inner join t7 on t7.id = t1.id
|
|
|
|
left join t3 on t3.id = t1.id
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
inner join rdb_types d1 on d1.type_id = t1.id
|
|
|
|
inner join rdb_rels d2 on d2.rel_id = t1.id
|
|
|
|
inner join rdb_deps d3 on d3.dep_type = t1.id
|
|
|
|
inner join rdb_colls d4 on d4.coll_id = t1.id
|
|
|
|
inner join rdb_flds d5 on d5.fld_type_id = t1.id
|
|
|
|
;
|
|
|
|
commit;
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2024-11-08 08:19:22 +01:00
|
|
|
db = db_factory(init = init_sql)
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2024-11-08 08:19:22 +01:00
|
|
|
act = python_act('db')
|
|
|
|
|
|
|
|
#-----------------------------------------------------------
|
|
|
|
|
|
|
|
@pytest.mark.version('>=3.0.1')
|
|
|
|
def test_1(act: Action, capsys):
|
|
|
|
|
|
|
|
test_sql = """
|
|
|
|
select count(*)
|
|
|
|
from test_view a
|
|
|
|
inner join rdb_types d1 on d1.type_id = a.id
|
|
|
|
inner join rdb_rels d2 on d2.rel_id = a.id
|
|
|
|
inner join rdb_deps d3 on d3.dep_type = a.id
|
|
|
|
where a.id = 1
|
|
|
|
;
|
|
|
|
"""
|
2024-11-19 08:13:30 +01:00
|
|
|
td = 86400000
|
2024-11-08 08:19:22 +01:00
|
|
|
with act.db.connect() as con:
|
|
|
|
cur = con.cursor()
|
|
|
|
ps = None
|
|
|
|
try:
|
2024-11-19 08:13:30 +01:00
|
|
|
t1=py_dt.datetime.now()
|
2024-11-08 08:19:22 +01:00
|
|
|
ps = cur.prepare(test_sql)
|
2024-11-19 08:13:30 +01:00
|
|
|
t2=py_dt.datetime.now()
|
|
|
|
td = int((t2-t1).total_seconds() * 1000) # milliseconds
|
2024-11-17 13:03:39 +01:00
|
|
|
print('Completed.')
|
2024-11-08 08:19:22 +01:00
|
|
|
except DatabaseError as e:
|
|
|
|
print(e.__str__())
|
|
|
|
print(e.gds_codes)
|
|
|
|
finally:
|
|
|
|
if ps:
|
|
|
|
ps.free()
|
|
|
|
|
2024-11-17 13:03:39 +01:00
|
|
|
act.expected_stdout = 'Completed.'
|
2024-11-08 08:19:22 +01:00
|
|
|
act.stdout = capsys.readouterr().out
|
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|
2024-11-19 08:13:30 +01:00
|
|
|
assert td < MAX_PREPARE_TIME_MS, f'Prepare time: {td} ms - greater than max allowed {MAX_PREPARE_TIME_MS} ms.'
|
|
|
|
|