2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
2022-01-23 20:41:55 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
ID: issue-4710
|
|
|
|
ISSUE: 4710
|
|
|
|
TITLE: SELECT WITH LOCK may enter an infinite loop for a single record
|
|
|
|
DESCRIPTION:
|
|
|
|
JIRA: CORE-4388
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_4388
|
2022-01-23 20:41:55 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
import pytest
|
2021-11-26 19:20:43 +01:00
|
|
|
import subprocess
|
|
|
|
import time
|
|
|
|
from pathlib import Path
|
2022-01-23 20:41:55 +01:00
|
|
|
from firebird.qa import *
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-23 20:41:55 +01:00
|
|
|
init_script = """
|
2021-04-26 20:07:00 +02:00
|
|
|
create table test(id int primary key, x int);
|
|
|
|
commit;
|
|
|
|
insert into test values(1, 100);
|
|
|
|
commit;
|
2021-11-26 19:20:43 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-23 20:41:55 +01:00
|
|
|
db = db_factory(sql_dialect=3, init=init_script)
|
2021-11-26 19:20:43 +01:00
|
|
|
|
2022-01-23 20:41:55 +01:00
|
|
|
act = python_act('db',
|
|
|
|
substitutions=[('(-)?concurrent\\s+transaction\\s+number(\\s+is)?\\s+\\d+',
|
|
|
|
'concurrent transaction'),
|
|
|
|
('After\\s+line\\s+\\d+.*', '')])
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-23 20:41:55 +01:00
|
|
|
expected_stdout = """
|
2021-04-26 20:07:00 +02:00
|
|
|
Statement failed, SQLSTATE = 40001
|
|
|
|
deadlock
|
|
|
|
-update conflicts with concurrent update
|
|
|
|
-concurrent transaction number is 13
|
2021-11-26 19:20:43 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-23 20:41:55 +01:00
|
|
|
script_file = temp_file('test-script.sql')
|
2021-11-26 19:20:43 +01:00
|
|
|
script_out = temp_file('test-script.out')
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2021-11-26 19:20:43 +01:00
|
|
|
@pytest.mark.version('>=3.0')
|
2022-01-23 20:41:55 +01:00
|
|
|
def test_1(act: Action, script_file: Path, script_out: Path):
|
|
|
|
with act.db.connect() as att1:
|
2021-11-26 19:20:43 +01:00
|
|
|
# Delete record but not yet commit - it's a time
|
|
|
|
# to make another connection:
|
|
|
|
att1.execute_immediate("delete from test where id = 1")
|
2022-01-23 20:41:55 +01:00
|
|
|
script_file.write_text("""
|
2021-11-26 19:20:43 +01:00
|
|
|
set list on;
|
|
|
|
-- set echo on;
|
|
|
|
commit;
|
|
|
|
set transaction lock timeout 20;
|
|
|
|
select x from test where id = 1 with lock;
|
|
|
|
""")
|
|
|
|
try:
|
|
|
|
with open(script_out, mode='w') as output:
|
2022-01-23 20:41:55 +01:00
|
|
|
p_test_sql = subprocess.Popen([act.vars['isql'], '-n', '-i', str(script_file),
|
|
|
|
'-user', act.db.user,
|
|
|
|
'-password', act.db.password, act.db.dsn],
|
2021-11-26 19:20:43 +01:00
|
|
|
stdout=output, stderr=subprocess.STDOUT)
|
|
|
|
#
|
|
|
|
time.sleep(2)
|
|
|
|
finally:
|
|
|
|
att1.commit()
|
|
|
|
p_test_sql.wait()
|
|
|
|
# Check
|
2022-01-23 20:41:55 +01:00
|
|
|
act.expected_stdout = expected_stdout
|
|
|
|
act.stdout = script_out.read_text()
|
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|