6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-23 05:53:06 +01:00
firebird-qa/tests/functional/procedure/create/test_16.py

59 lines
1.4 KiB
Python
Raw Normal View History

2021-04-26 20:07:00 +02:00
#coding:utf-8
2022-02-04 19:05:19 +01:00
"""
ID: procedure.create-10
ISSUE: 1161
TITLE: Type Flag for Stored Procedures
DESCRIPTION:
FBTEST: functional.procedure.create.16
JIRA: CORE-779
"""
2021-04-26 20:07:00 +02:00
2022-02-04 19:05:19 +01:00
import pytest
from firebird.qa import *
2021-04-26 20:07:00 +02:00
2022-02-04 19:05:19 +01:00
init_script = """
2021-04-26 20:07:00 +02:00
set term ^;
create or alter procedure with_suspend (nom1 varchar(20) character set iso8859_1 collate fr_fr)
returns (nom3 varchar(20) character set iso8859_1 collate iso8859_1) as
declare variable nom2 varchar(20) character set iso8859_1 collate fr_ca;
begin
nom2=nom1;
nom3=nom2;
suspend;
end ^
2022-02-04 19:05:19 +01:00
2021-04-26 20:07:00 +02:00
create or alter procedure no_suspend returns(p1 smallint) as
begin
p1=1;
end ^
set term ;^
commit;
"""
2022-02-04 19:05:19 +01:00
db = db_factory(init=init_script)
2021-04-26 20:07:00 +02:00
2022-02-04 19:05:19 +01:00
test_script = """
2021-04-26 20:07:00 +02:00
set list on;
select p.rdb$procedure_name, p.rdb$procedure_type
from rdb$procedures p
where upper(p.rdb$procedure_name) in ( upper('with_suspend'), upper('no_suspend') )
2022-02-04 19:05:19 +01:00
order by 1;
"""
2021-04-26 20:07:00 +02:00
2022-02-04 19:05:19 +01:00
act = isql_act('db', test_script)
2021-04-26 20:07:00 +02:00
2022-02-04 19:05:19 +01:00
expected_stdout = """
2021-04-26 20:07:00 +02:00
RDB$PROCEDURE_NAME NO_SUSPEND
RDB$PROCEDURE_TYPE 2
RDB$PROCEDURE_NAME WITH_SUSPEND
RDB$PROCEDURE_TYPE 1
"""
2021-04-26 20:07:00 +02:00
2022-02-04 19:05:19 +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