2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
|
|
|
ID: issue-5606
|
|
|
|
ISSUE: 5606
|
2024-05-15 19:26:01 +02:00
|
|
|
TITLE: Trace session leads FB 4.0 to hang after 2nd launch of trivial .sql script. Neither attach to any database nor regular restart of FB service can be done.
|
2022-01-25 22:55:48 +01:00
|
|
|
DESCRIPTION:
|
|
|
|
Ticket issue was reproduced on trivial trace config with single line ("enabled = true").
|
|
|
|
We prepare such config, launch trace session in async mode and run THREE times isql with logging its output.
|
|
|
|
Then we stop trace session and open isql log - it should contain three 'packets' of table records.
|
|
|
|
If FB becomes unavaliable, this (and all subsequent) test will not finish at all.
|
|
|
|
JIRA: CORE-5330
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_5330
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
import pytest
|
|
|
|
from firebird.qa import *
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
db = db_factory()
|
2021-12-06 19:23:35 +01:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
act = python_act('db')
|
2021-12-06 19:23:35 +01:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
test_script = """
|
2021-12-06 19:23:35 +01:00
|
|
|
recreate table ttt(id int generated by default as identity, x int, y int);
|
|
|
|
commit;
|
|
|
|
|
|
|
|
set term ^;
|
|
|
|
execute block as
|
|
|
|
declare s varchar(200) = 'insert into ttt(x, y) values(?, ?)';
|
|
|
|
declare n int = 3;
|
|
|
|
begin
|
|
|
|
while (n>0) do
|
|
|
|
begin
|
|
|
|
execute statement (s) (:n, :n * 2);
|
|
|
|
n = n - 1;
|
|
|
|
end
|
|
|
|
end
|
|
|
|
^
|
|
|
|
set term ;^
|
|
|
|
commit;
|
|
|
|
set list on;
|
|
|
|
select * from ttt;
|
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
expected_stdout = """
|
2021-04-26 20:07:00 +02:00
|
|
|
ID 1
|
|
|
|
X 3
|
|
|
|
Y 6
|
|
|
|
|
|
|
|
ID 2
|
|
|
|
X 2
|
|
|
|
Y 4
|
|
|
|
|
|
|
|
ID 3
|
|
|
|
X 1
|
|
|
|
Y 2
|
|
|
|
|
|
|
|
ID 1
|
|
|
|
X 3
|
|
|
|
Y 6
|
|
|
|
|
|
|
|
ID 2
|
|
|
|
X 2
|
|
|
|
Y 4
|
|
|
|
|
|
|
|
ID 3
|
|
|
|
X 1
|
|
|
|
Y 2
|
|
|
|
|
|
|
|
ID 1
|
|
|
|
X 3
|
|
|
|
Y 6
|
|
|
|
|
|
|
|
ID 2
|
|
|
|
X 2
|
|
|
|
Y 4
|
|
|
|
|
|
|
|
ID 3
|
|
|
|
X 1
|
|
|
|
Y 2
|
2021-12-06 19:23:35 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
trace = ['database=',
|
|
|
|
'{',
|
|
|
|
'enabled = true',
|
|
|
|
'}']
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
|
2024-05-15 19:26:01 +02:00
|
|
|
@pytest.mark.trace
|
2021-12-06 19:23:35 +01:00
|
|
|
@pytest.mark.version('>=4.0')
|
2022-01-25 22:55:48 +01:00
|
|
|
def test_1(act: Action, capsys):
|
|
|
|
with act.trace(config=trace, keep_log=False):
|
2021-12-07 20:09:36 +01:00
|
|
|
for i in range(3, 0, -1):
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
|
|
|
act.isql(switches=[], input=test_script)
|
|
|
|
print(act.stdout)
|
2021-12-06 19:23:35 +01:00
|
|
|
# Check
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
|
|
|
act.expected_stdout = expected_stdout
|
|
|
|
act.stdout = capsys.readouterr().out
|
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|