2021-04-26 20:07:00 +02:00
|
|
|
#coding:utf-8
|
2022-01-25 22:55:48 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
ID: issue-5500
|
|
|
|
ISSUE: 5500
|
2022-02-02 15:46:19 +01:00
|
|
|
TITLE: ISQL -X: double quotes are missed for COLLATE <C> of CREATE DOMAIN statement
|
|
|
|
when <C> is from any non-ascii charset
|
2022-01-25 22:55:48 +01:00
|
|
|
DESCRIPTION:
|
|
|
|
We create in init_script two collations with non-ascii names and two varchar domains which use these collations.
|
|
|
|
Then we extract metadata and save it to file as .sql script to be applied further.
|
|
|
|
This script should contain CORRECT domains definition, i.e. collations should be enclosed in double quotes.
|
|
|
|
We check correctness by removing from database all objects and applying this script: no errors should occur at that point.
|
|
|
|
Then we extract metadata second time, store it to second .sql and COMPARE this file with result of first metadata extraction.
|
|
|
|
These files should be equal, i.e. difference should be empty.
|
|
|
|
JIRA: CORE-5220
|
2022-02-02 15:46:19 +01:00
|
|
|
FBTEST: bugs.core_5220
|
2023-11-25 23:18:17 +01:00
|
|
|
NOTES:
|
|
|
|
[25.11.2023] pzotov
|
|
|
|
Writing code requires more care since 6.0.0.150: ISQL does not allow specifying duplicate delimiters without any statements between them (two semicolon, two carets etc).
|
2022-01-25 22:55:48 +01:00
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
|
|
|
import pytest
|
2021-11-30 19:13:50 +01:00
|
|
|
from difflib import unified_diff
|
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
|
|
|
init_script = """
|
2021-11-30 19:13:50 +01:00
|
|
|
create collation "Циферки" for utf8 from unicode case insensitive 'NUMERIC-SORT=1';
|
2023-11-25 23:18:17 +01:00
|
|
|
create collation "Испания" for iso8859_1 from es_es_ci_ai 'SPECIALS-FIRST=1';
|
2021-11-30 19:13:50 +01:00
|
|
|
commit;
|
|
|
|
create domain "Артикулы" varchar(12) character set utf8 collate "Циферки";
|
|
|
|
create domain "Комрады" varchar(40) character set iso8859_1 collate "Испания";
|
|
|
|
commit;
|
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
db = db_factory(init=init_script, charset='UTF8')
|
2021-11-30 19:13:50 +01:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
act = python_act('db')
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2022-01-25 22:55:48 +01:00
|
|
|
expected_stdout = """
|
2021-11-30 19:13:50 +01:00
|
|
|
Records affected: 0
|
|
|
|
Records affected: 0
|
|
|
|
"""
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2021-11-30 19:13:50 +01:00
|
|
|
remove_metadata = """
|
|
|
|
drop domain "Комрады";
|
|
|
|
drop domain "Артикулы";
|
|
|
|
drop collation "Испания";
|
|
|
|
drop collation "Циферки";
|
|
|
|
commit;
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2021-11-30 19:13:50 +01:00
|
|
|
set list on;
|
|
|
|
set count on;
|
|
|
|
select f.rdb$field_name
|
|
|
|
from rdb$fields f
|
|
|
|
where
|
|
|
|
f.rdb$system_flag is distinct from 1
|
|
|
|
and f.rdb$field_name not starting with upper('rdb$');
|
2021-04-26 20:07:00 +02:00
|
|
|
|
2021-11-30 19:13:50 +01:00
|
|
|
select r.rdb$collation_name
|
|
|
|
from rdb$collations r
|
|
|
|
where
|
|
|
|
r.rdb$system_flag is distinct from 1;
|
|
|
|
"""
|
|
|
|
|
2024-10-31 11:17:14 +01:00
|
|
|
@pytest.mark.intl
|
2021-11-30 19:13:50 +01:00
|
|
|
@pytest.mark.version('>=3.0')
|
2022-01-25 22:55:48 +01:00
|
|
|
def test_1(act: Action):
|
2021-11-30 19:13:50 +01:00
|
|
|
#
|
2023-11-25 23:18:17 +01:00
|
|
|
act.isql(switches=['-x'], combine_output = True)
|
2022-01-25 22:55:48 +01:00
|
|
|
metadata = act.stdout
|
|
|
|
act.reset()
|
2023-11-25 23:18:17 +01:00
|
|
|
|
|
|
|
# Remove metadata
|
2022-01-25 22:55:48 +01:00
|
|
|
act.expected_stdout = expected_stdout
|
2023-11-25 23:18:17 +01:00
|
|
|
act.isql(switches=[], input=remove_metadata, combine_output = True)
|
2022-01-25 22:55:48 +01:00
|
|
|
assert act.clean_stdout == act.clean_expected_stdout
|
2023-11-25 23:18:17 +01:00
|
|
|
act.reset()
|
|
|
|
|
2021-11-30 19:13:50 +01:00
|
|
|
# Apply metadata
|
2023-11-25 23:18:17 +01:00
|
|
|
act.isql(switches=[], input=metadata, combine_output = True)
|
2022-01-25 22:55:48 +01:00
|
|
|
act.reset()
|
2023-11-25 23:18:17 +01:00
|
|
|
|
2021-11-30 19:13:50 +01:00
|
|
|
# Extract metadatata again
|
2023-11-25 23:18:17 +01:00
|
|
|
act.isql(switches=['-x'], combine_output = True)
|
|
|
|
|
2021-11-30 19:13:50 +01:00
|
|
|
# Check metadata
|
2022-01-25 22:55:48 +01:00
|
|
|
meta_diff = list(unified_diff(metadata.splitlines(), act.stdout.splitlines()))
|
2021-11-30 19:13:50 +01:00
|
|
|
assert meta_diff == []
|