mirror of
https://github.com/postgres/postgres.git
synced 2025-05-02 11:44:50 +03:00
Add some test cases to improve test coverage of parse_expr.c.
I chanced to notice while thumbing through lcov reports that we had exactly no coverage of BETWEEN SYMMETRIC, nor of current_time(N) and localtime(N). Improve that. parse_expr.c still has a pretty awful coverage number, but a large part of that is due to lack of coverage of the operator_precedence_warning logic. I have zero desire to write tests for that; I think ripping it out would be more sensible at this point.
This commit is contained in:
parent
79b94716e7
commit
cf20cc00a9
@ -1,5 +1,5 @@
|
||||
--
|
||||
-- expression evaluated tests that don't fit into a more specific file
|
||||
-- expression evaluation tests that don't fit into a more specific file
|
||||
--
|
||||
--
|
||||
-- Tests for SQLVAlueFunction
|
||||
@ -18,12 +18,24 @@ SELECT now()::timetz::text = current_time::text;
|
||||
t
|
||||
(1 row)
|
||||
|
||||
SELECT now()::timetz(4)::text = current_time(4)::text;
|
||||
?column?
|
||||
----------
|
||||
t
|
||||
(1 row)
|
||||
|
||||
SELECT now()::time::text = localtime::text;
|
||||
?column?
|
||||
----------
|
||||
t
|
||||
(1 row)
|
||||
|
||||
SELECT now()::time(3)::text = localtime(3)::text;
|
||||
?column?
|
||||
----------
|
||||
t
|
||||
(1 row)
|
||||
|
||||
-- current_timestamp / localtimestamp (always matches because of transactional behaviour)
|
||||
SELECT current_timestamp = NOW();
|
||||
?column?
|
||||
@ -75,3 +87,74 @@ SELECT current_schema;
|
||||
(1 row)
|
||||
|
||||
RESET search_path;
|
||||
--
|
||||
-- Tests for BETWEEN
|
||||
--
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 between '1997-01-01' and '1998-01-01';
|
||||
QUERY PLAN
|
||||
-----------------------------------------------------------------------------
|
||||
Aggregate
|
||||
-> Seq Scan on date_tbl
|
||||
Filter: ((f1 >= '01-01-1997'::date) AND (f1 <= '01-01-1998'::date))
|
||||
(3 rows)
|
||||
|
||||
select count(*) from date_tbl
|
||||
where f1 between '1997-01-01' and '1998-01-01';
|
||||
count
|
||||
-------
|
||||
3
|
||||
(1 row)
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 not between '1997-01-01' and '1998-01-01';
|
||||
QUERY PLAN
|
||||
--------------------------------------------------------------------------
|
||||
Aggregate
|
||||
-> Seq Scan on date_tbl
|
||||
Filter: ((f1 < '01-01-1997'::date) OR (f1 > '01-01-1998'::date))
|
||||
(3 rows)
|
||||
|
||||
select count(*) from date_tbl
|
||||
where f1 not between '1997-01-01' and '1998-01-01';
|
||||
count
|
||||
-------
|
||||
12
|
||||
(1 row)
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 between symmetric '1997-01-01' and '1998-01-01';
|
||||
QUERY PLAN
|
||||
----------------------------------------------------------------------------------------------------------------------------------------------
|
||||
Aggregate
|
||||
-> Seq Scan on date_tbl
|
||||
Filter: (((f1 >= '01-01-1997'::date) AND (f1 <= '01-01-1998'::date)) OR ((f1 >= '01-01-1998'::date) AND (f1 <= '01-01-1997'::date)))
|
||||
(3 rows)
|
||||
|
||||
select count(*) from date_tbl
|
||||
where f1 between symmetric '1997-01-01' and '1998-01-01';
|
||||
count
|
||||
-------
|
||||
3
|
||||
(1 row)
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 not between symmetric '1997-01-01' and '1998-01-01';
|
||||
QUERY PLAN
|
||||
-----------------------------------------------------------------------------------------------------------------------------------------
|
||||
Aggregate
|
||||
-> Seq Scan on date_tbl
|
||||
Filter: (((f1 < '01-01-1997'::date) OR (f1 > '01-01-1998'::date)) AND ((f1 < '01-01-1998'::date) OR (f1 > '01-01-1997'::date)))
|
||||
(3 rows)
|
||||
|
||||
select count(*) from date_tbl
|
||||
where f1 not between symmetric '1997-01-01' and '1998-01-01';
|
||||
count
|
||||
-------
|
||||
12
|
||||
(1 row)
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
--
|
||||
-- expression evaluated tests that don't fit into a more specific file
|
||||
-- expression evaluation tests that don't fit into a more specific file
|
||||
--
|
||||
|
||||
--
|
||||
@ -13,7 +13,9 @@ SELECT date(now())::text = current_date::text;
|
||||
|
||||
-- current_time / localtime
|
||||
SELECT now()::timetz::text = current_time::text;
|
||||
SELECT now()::timetz(4)::text = current_time(4)::text;
|
||||
SELECT now()::time::text = localtime::text;
|
||||
SELECT now()::time(3)::text = localtime(3)::text;
|
||||
|
||||
-- current_timestamp / localtimestamp (always matches because of transactional behaviour)
|
||||
SELECT current_timestamp = NOW();
|
||||
@ -34,3 +36,32 @@ SELECT current_schema;
|
||||
SET search_path = 'pg_catalog';
|
||||
SELECT current_schema;
|
||||
RESET search_path;
|
||||
|
||||
|
||||
--
|
||||
-- Tests for BETWEEN
|
||||
--
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 between '1997-01-01' and '1998-01-01';
|
||||
select count(*) from date_tbl
|
||||
where f1 between '1997-01-01' and '1998-01-01';
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 not between '1997-01-01' and '1998-01-01';
|
||||
select count(*) from date_tbl
|
||||
where f1 not between '1997-01-01' and '1998-01-01';
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 between symmetric '1997-01-01' and '1998-01-01';
|
||||
select count(*) from date_tbl
|
||||
where f1 between symmetric '1997-01-01' and '1998-01-01';
|
||||
|
||||
explain (costs off)
|
||||
select count(*) from date_tbl
|
||||
where f1 not between symmetric '1997-01-01' and '1998-01-01';
|
||||
select count(*) from date_tbl
|
||||
where f1 not between symmetric '1997-01-01' and '1998-01-01';
|
||||
|
Loading…
x
Reference in New Issue
Block a user