6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-22 21:43:06 +01:00
firebird-qa/tests/bugs/core_5847_test.py

37 lines
937 B
Python
Raw Normal View History

2021-04-26 20:07:00 +02:00
#coding:utf-8
2022-01-26 21:10:46 +01:00
"""
ID: issue-6108
ISSUE: 6108
TITLE: "Malformed string" instead of key value in PK violation error message
DESCRIPTION:
JIRA: CORE-5847
"""
2021-04-26 20:07:00 +02:00
import pytest
2022-01-26 21:10:46 +01:00
from firebird.qa import *
from firebird.driver import DatabaseError
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
init_script = """
2021-04-26 20:07:00 +02:00
recreate table test(
uid char(16) character set octets,
constraint test_uid_pk primary key(uid) using index test_uid_pk
2021-04-26 20:07:00 +02:00
);
commit;
insert into test values( gen_uuid() );
commit;
"""
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
db = db_factory(init=init_script)
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
act = python_act('db')
2021-04-26 20:07:00 +02:00
2022-01-26 21:10:46 +01:00
@pytest.mark.version('>=3')
def test_1(act: Action):
with act.db.connect(charset='utf8') as con1, act.db.connect() as con2:
c1 = con1.cursor()
c2 = con2.cursor()
for c in [c1, c2]:
with pytest.raises(DatabaseError, match='.*Problematic key value is.*'):
2022-01-26 21:10:46 +01:00
c.execute('insert into test(uid) select uid from test rows 1')