2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
"""
|
|
|
|
ID: issue-1609
|
|
|
|
ISSUE: 1609
|
|
|
|
TITLE: View cannot be created if its WHERE clause contains IN <subquery> with a procedure reference
|
|
|
|
DESCRIPTION:
|
|
|
|
JIRA: CORE-1183
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_1183
|
2022-01-19 17:54:56 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
import pytest
|
|
|
|
from firebird.qa import *
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
init_script = """
|
2021-04-26 20:07:00 +02:00
|
|
|
set term ^;
|
|
|
|
create or alter procedure p
|
|
|
|
returns (col int)
|
|
|
|
as
|
|
|
|
begin
|
|
|
|
col = 1;
|
|
|
|
suspend;
|
|
|
|
end^
|
|
|
|
set term ;^
|
|
|
|
commit;
|
2022-01-19 17:54:56 +01:00
|
|
|
|
2021-04-26 20:07:00 +02:00
|
|
|
create or alter view v
|
|
|
|
as
|
|
|
|
select
|
|
|
|
rdb$description v_descr,
|
|
|
|
rdb$relation_id v_rel_id,
|
|
|
|
rdb$character_set_name v_cset_name
|
|
|
|
from rdb$database
|
|
|
|
where 1 in ( select col from p );
|
|
|
|
commit;
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
db = db_factory(init=init_script)
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
test_script = """
|
2021-04-26 20:07:00 +02:00
|
|
|
set list on;
|
|
|
|
select v_descr, sign(v_rel_id) as v_rel_id, v_cset_name
|
|
|
|
from v;
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
act = isql_act('db', test_script)
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
expected_stdout = """
|
2021-04-26 20:07:00 +02:00
|
|
|
V_DESCR <null>
|
|
|
|
V_REL_ID 1
|
2022-01-19 17:54:56 +01:00
|
|
|
V_CSET_NAME NONE
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-19 17:54:56 +01:00
|
|
|
@pytest.mark.version('>=3')
|
|
|
|
def test_1(act: Action):
|
|
|
|
act.expected_stdout = expected_stdout
|
|
|
|
act.execute()
|
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|
2021-04-26 20:07:00 +02:00
|
|
|
|