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_3174_test.py

171 lines
5.4 KiB
Python

#coding:utf-8
"""
ID: issue-3548
ISSUE: 3548
TITLE: Expression index with TRIM may lead to incorrect indexed lookup
DESCRIPTION:
JIRA: CORE-3174
FBTEST: bugs.core_3174
"""
import pytest
from firebird.qa import *
init_script = """
create collation ps_yes for utf8 from unicode pad space;
create collation ps_no for utf8 from unicode no pad;
create table t (id int, c_pad varchar(10), c_nopad varchar(10) character set utf8 collate ps_no);
commit;
insert into t(id, c_pad, c_nopad) values (1, '123', '123');
insert into t(id, c_pad, c_nopad) values (2, ' 123', ' 123');
insert into t(id, c_pad, c_nopad) values (3, '123 ', '123 ');
insert into t(id, c_pad, c_nopad) values (4, ' 123 ', ' 123 ');
commit;
create index t_c_pad_trim_right on t computed by (trim(trailing from c_pad));
create index t_c_pad_trim_left on t computed by (trim(leading from c_pad));
create index t_c_nopad_trim_right on t computed by (trim(trailing from c_nopad));
create index t_c_nopad_trim_left on t computed by (trim(leading from c_nopad));
commit;
"""
db = db_factory(init=init_script)
test_script = """
set plan on;
--set echo on;
select '1.a' as test_no, id,'.' || c_pad || '.' as c_pad from t where trim(c_pad) = '123';
select '1.b' as test_no, id,'.' || c_pad || '.' as c_pad from t where trim(trailing from c_pad) = trim(leading from c_pad);
select '1.c' as test_no, id,'.' || c_pad || '.' as c_pad from t where trim(trailing from c_pad) = '123';
select '1.d' as test_no, id,'.' || c_pad || '.' as c_pad from t where trim(leading from c_pad) = '123';
select '1.e' as test_no, id,'.' || c_pad || '.' as c_pad from t where trim(trailing from c_pad) starting with '123';
select '1.f' as test_no, id,'.' || c_pad || '.' as c_pad from t where trim(leading from c_pad) starting with '123';
-------------------------------------------------------------------------
select '2.a' as test_no, id,'.' || c_nopad || '.' as c_nopad from t where trim(c_nopad) = '123';
select '2.b' as test_no, id,'.' || c_nopad || '.' as c_nopad from t where trim(trailing from c_nopad) = trim(leading from c_nopad);
select '2.c' as test_no, id,'.' || c_nopad || '.' as c_nopad from t where trim(trailing from c_nopad) = '123';
select '2.d' as test_no, id,'.' || c_nopad || '.' as c_nopad from t where trim(leading from c_nopad) = '123';
select '2.f' as test_no, id,'.' || c_nopad || '.' as c_nopad from t where trim(trailing from c_nopad) starting with '123';
select '2.g' as test_no, id,'.' || c_nopad || '.' as c_nopad from t where trim(leading from c_nopad) starting with '123';
"""
act = isql_act('db', test_script, substitutions=[('=.*', '')])
expected_stdout = """
PLAN (T NATURAL)
TEST_NO ID C_PAD
======= ============ ============
1.a 1 .123.
1.a 2 . 123.
1.a 3 .123 .
1.a 4 . 123 .
PLAN (T NATURAL)
TEST_NO ID C_PAD
======= ============ ============
1.b 1 .123.
1.b 3 .123 .
PLAN (T INDEX (T_C_PAD_TRIM_RIGHT))
TEST_NO ID C_PAD
======= ============ ============
1.c 1 .123.
1.c 3 .123 .
PLAN (T INDEX (T_C_PAD_TRIM_LEFT))
TEST_NO ID C_PAD
======= ============ ============
1.d 1 .123.
1.d 2 . 123.
1.d 3 .123 .
1.d 4 . 123 .
PLAN (T INDEX (T_C_PAD_TRIM_RIGHT))
TEST_NO ID C_PAD
======= ============ ============
1.e 1 .123.
1.e 3 .123 .
PLAN (T INDEX (T_C_PAD_TRIM_LEFT))
TEST_NO ID C_PAD
======= ============ ============
1.f 1 .123.
1.f 2 . 123.
1.f 3 .123 .
1.f 4 . 123 .
PLAN (T NATURAL)
TEST_NO ID C_NOPAD
======= ============ ================================================
2.a 1 .123.
2.a 2 . 123.
2.a 3 .123 .
2.a 4 . 123 .
PLAN (T NATURAL)
TEST_NO ID C_NOPAD
======= ============ ================================================
2.b 1 .123.
PLAN (T INDEX (T_C_NOPAD_TRIM_RIGHT))
TEST_NO ID C_NOPAD
======= ============ ================================================
2.c 1 .123.
2.c 3 .123 .
PLAN (T INDEX (T_C_NOPAD_TRIM_LEFT))
TEST_NO ID C_NOPAD
======= ============ ================================================
2.d 1 .123.
2.d 2 . 123.
PLAN (T INDEX (T_C_NOPAD_TRIM_RIGHT))
TEST_NO ID C_NOPAD
======= ============ ================================================
2.f 1 .123.
2.f 3 .123 .
PLAN (T INDEX (T_C_NOPAD_TRIM_LEFT))
TEST_NO ID C_NOPAD
======= ============ ================================================
2.g 1 .123.
2.g 2 . 123.
2.g 3 .123 .
2.g 4 . 123 .
"""
@pytest.mark.version('>=3.0')
def test_1(act: Action):
act.expected_stdout = expected_stdout
act.execute()
assert act.clean_stdout == act.clean_expected_stdout