2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
"""
|
|
|
|
ID: issue-3443
|
|
|
|
ISSUE: 3443
|
|
|
|
TITLE: Using both the procedure name and alias inside an explicit plan crashes the server
|
|
|
|
DESCRIPTION:
|
|
|
|
JIRA: CORE-3064
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_3064
|
2023-03-04 17:53:40 +01:00
|
|
|
NOTES:
|
|
|
|
[04.03.2023] pzotov
|
|
|
|
Expected output was splitted because FB 5.x now *allows* execution w/o error.
|
2022-01-22 21:59:15 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
import pytest
|
|
|
|
from firebird.qa import *
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
init_script = """
|
2021-04-26 20:07:00 +02:00
|
|
|
set term ^ ;
|
|
|
|
create or alter procedure get_dates (
|
|
|
|
adate_from date,
|
|
|
|
adate_to date )
|
|
|
|
returns (
|
|
|
|
out_date date )
|
|
|
|
as
|
|
|
|
declare variable d date;
|
|
|
|
begin
|
|
|
|
d = adate_from;
|
|
|
|
while (d<=adate_to) do
|
|
|
|
begin
|
|
|
|
out_date = d;
|
|
|
|
suspend;
|
|
|
|
d = d + 1;
|
|
|
|
end
|
|
|
|
end^
|
|
|
|
set term ; ^
|
|
|
|
commit;
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
db = db_factory(init=init_script)
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
test_script = """
|
2021-04-26 20:07:00 +02:00
|
|
|
set planonly;
|
|
|
|
select * from get_dates( 'yesterday', 'today' ) PLAN (GET_DATES NATURAL);
|
|
|
|
select * from get_dates( 'yesterday', 'today' ) p PLAN (P NATURAL);
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
act = isql_act('db', test_script, substitutions=[('offset .*', 'offset')])
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2023-03-04 17:53:40 +01:00
|
|
|
fb3x_expected_out = """
|
|
|
|
Statement failed, SQLSTATE = 42S02
|
|
|
|
Dynamic SQL Error
|
|
|
|
-SQL error code = -104
|
|
|
|
-Invalid command
|
|
|
|
-there is no alias or table named GET_DATES at this scope level
|
|
|
|
|
|
|
|
Statement failed, SQLSTATE = HY000
|
|
|
|
invalid request BLR at offset 50
|
|
|
|
-BLR syntax error: expected TABLE at offset 51, encountered 132
|
|
|
|
"""
|
|
|
|
|
|
|
|
fb5x_expected_out = """
|
|
|
|
PLAN (GET_DATES NATURAL)
|
|
|
|
PLAN (P NATURAL)
|
2021-12-22 20:23:11 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-22 21:59:15 +01:00
|
|
|
@pytest.mark.version('>=3')
|
|
|
|
def test_1(act: Action):
|
2023-03-04 17:53:40 +01:00
|
|
|
act.expected_stdout = fb3x_expected_out if act.is_version('<5') else fb5x_expected_out
|
|
|
|
act.execute(combine_output = True)
|
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|