mirror of
https://github.com/FirebirdSQL/firebird-qa.git
synced 2025-01-22 21:43:06 +01:00
170 lines
5.4 KiB
Python
170 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
|
|
"""
|
|
|
|
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
|
|
|