6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-22 13:33:07 +01:00
firebird-qa/tests/bugs/core_5389_test.py

61 lines
1.7 KiB
Python
Raw Normal View History

2021-04-26 20:07:00 +02:00
#coding:utf-8
2022-01-25 22:55:48 +01:00
"""
ID: issue-5662
ISSUE: 5662
TITLE: Query cannot be executed if win1251 characters used in field aliases
DESCRIPTION:
JIRA: CORE-5389
FBTEST: bugs.core_5389
2022-01-25 22:55:48 +01:00
"""
2021-04-26 20:07:00 +02:00
import pytest
2021-12-06 19:23:35 +01:00
from pathlib import Path
2022-01-25 22:55:48 +01:00
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', substitutions=[('.*After line [0-9]+ in file .*', '')])
2021-04-26 20:07:00 +02:00
2022-01-25 22:55:48 +01:00
expected_stdout = """
2021-12-06 19:23:35 +01:00
ФИО
Д.рождения
Город
Расшифровка выступлений
"""
2021-04-26 20:07:00 +02:00
2022-01-25 22:55:48 +01:00
expected_stderr = """
2021-12-06 19:23:35 +01:00
Statement failed, SQLSTATE = 22018
arithmetic exception, numeric overflow, or string truncation
-Cannot transliterate character between character sets
"""
2022-01-25 22:55:48 +01:00
test_script = """
2021-12-06 19:23:35 +01:00
set bail on;
set list on;
-- set names win1251;
2021-04-26 20:07:00 +02:00
2021-12-06 19:23:35 +01:00
select
'' as "ФИО"
,'' as "Д.рождения"
,'' as "Город"
,'' as "Расшифровка выступлений"
from rdb$database;
"""
2021-04-26 20:07:00 +02:00
2021-12-06 19:23:35 +01:00
script_file = temp_file('test-script.sql')
@pytest.mark.intl
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, script_file: Path):
script_file.write_text(test_script, encoding='cp1251')
2021-12-06 19:23:35 +01:00
# check-1: attempt to apply DDL with non-ascii characters __WITHOUT__ charset specifying (for ISQL)
2022-01-25 22:55:48 +01:00
act.expected_stderr = expected_stderr
act.isql(switches=['-q'], input_file=script_file, charset=None)
assert act.clean_stderr == act.clean_expected_stderr
2021-12-06 19:23:35 +01:00
# check-2: attempt to apply DDL with non-ascii characters ___WITH___ specifying: ISQL ... -ch WIN1251
2022-01-25 22:55:48 +01:00
act.reset()
act.expected_stdout = expected_stdout
act.isql(switches=['-q'], input_file=script_file, charset='WIN1251')
assert act.clean_stdout == act.clean_expected_stdout