Files
greptimedb/tests/cases/standalone/common/tql/aggr_over_time.sql
Ruihang Xia 4ac73a7e9e feat: adapt prometheus 3.x selector and lookback behavior (#7688)
* feat: adapt prometheus 3.x selector and lookback behavior

Signed-off-by: Ruihang Xia <waynestxia@gmail.com>

* remove commit hash from comment

Signed-off-by: Ruihang Xia <waynestxia@gmail.com>

---------

Signed-off-by: Ruihang Xia <waynestxia@gmail.com>
2026-02-10 04:00:45 +00:00

188 lines
5.5 KiB
SQL

-- Port from Prometheus `promql/promqltest/testdata/functions.test`.
-- Include stddev/stdvar over time
-- load 10s
-- metric 0 8 8 2 3
create table metric (ts timestamp(3) time index, val double);
insert into metric values
(0,0),
(10000,8),
(20000,8),
(30000,2),
(40000,3);
-- SQLNESS SORT_RESULT 2 1
select * from metric;
-- eval instant at 1m stdvar_over_time(metric[2m])
-- {} 10.56
tql eval (60, 60, '1s') stdvar_over_time(metric[2m]);
-- eval instant at 1m stddev_over_time(metric[2m])
-- {} 3.249615
tql eval (60, 60, '1s') stddev_over_time(metric[2m]);
-- eval instant at 1m stddev_over_time((metric[2m]))
-- {} 3.249615
tql eval (60, 60, '1s') stddev_over_time((metric[2m]));
drop table metric;
-- load 10s
-- metric 1.5990505637277868 1.5990505637277868 1.5990505637277868
create table metric (ts timestamp(3) time index, val double);
insert into metric values
(0,1.5990505637277868),
(10000,1.5990505637277868),
(20000,1.5990505637277868);
-- eval instant at 55s stdvar_over_time(metric[1m])
-- {} 0
tql eval (55, 55, '1s') stdvar_over_time(metric[1m]);
-- eval instant at 55s stddev_over_time(metric[1m])
-- {} 0
tql eval (55, 55, '1s') stddev_over_time(metric[1m]);
drop table metric;
-- Port from functions.test L632 - L680, commit 001ee2620e094970e5657ce39275b2fccdbd1359
-- Include quantile over time
-- load 10s
-- data{test="two samples"} 0 1
-- data{test="three samples"} 0 1 2
-- data{test="uneven samples"} 0 1 4
create table data (ts timestamp(3) time index, val double, test string primary key);
insert into data values
(0, 0, "two samples"),
(10000, 1, "two samples"),
(0, 0, "three samples"),
(10000, 1, "three samples"),
(20000, 2, "three samples"),
(0, 0, "uneven samples"),
(10000, 1, "uneven samples"),
(20000, 4, "uneven samples");
-- eval instant at 1m quantile_over_time(0, data[2m])
-- {test="two samples"} 0
-- {test="three samples"} 0
-- {test="uneven samples"} 0
--
-- Prometheus `v3.9.1` updates these cases to use a larger range to avoid the (t-r) boundary.
-- See PR #13904 ("left-open and right-closed lookback/matrix selections").
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(0, data[2m]);
-- eval instant at 1m quantile_over_time(0.5, data[2m])
-- {test="two samples"} 0.5
-- {test="three samples"} 1
-- {test="uneven samples"} 1
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(0.5, data[2m]);
-- eval instant at 1m quantile_over_time(0.75, data[2m])
-- {test="two samples"} 0.75
-- {test="three samples"} 1.5
-- {test="uneven samples"} 2.5
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(0.75, data[2m]);
-- eval instant at 1m quantile_over_time(0.8, data[2m])
-- {test="two samples"} 0.8
-- {test="three samples"} 1.6
-- {test="uneven samples"} 2.8
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(0.8, data[2m]);
-- eval instant at 1m quantile_over_time(1, data[2m])
-- {test="two samples"} 1
-- {test="three samples"} 2
-- {test="uneven samples"} 4
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(1, data[2m]);
-- eval instant at 1m quantile_over_time(-1, data[2m])
-- {test="two samples"} -Inf
-- {test="three samples"} -Inf
-- {test="uneven samples"} -Inf
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(-1, data[2m]);
-- eval instant at 1m quantile_over_time(2, data[2m])
-- {test="two samples"} +Inf
-- {test="three samples"} +Inf
-- {test="uneven samples"} +Inf
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') quantile_over_time(2, data[2m]);
-- eval instant at 1m (quantile_over_time(2, (data[2m])))
-- {test="two samples"} +Inf
-- {test="three samples"} +Inf
-- {test="uneven samples"} +Inf
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') (quantile_over_time(2, (data[2m])));
drop table data;
-- Port from functions.test L773 - L802, commit 001ee2620e094970e5657ce39275b2fccdbd1359
-- Include max/min/last over time
-- load 10s
-- data{type="numbers"} 2 0 3
-- data{type="some_nan"} 2 0 NaN
-- data{type="some_nan2"} 2 NaN 1
-- data{type="some_nan3"} NaN 0 1
-- data{type="only_nan"} NaN NaN NaN
create table data (ts timestamp(3) time index, val double, ty string primary key);
insert into data values
(0, 2::double, 'numbers'),
(10000, 0::double, 'numbers'),
(20000, 3::double, 'numbers'),
(0, 2::double, 'some_nan'),
(10000, 0::double, 'some_nan'),
(20000, 'NaN'::double, 'some_nan'),
(0, 2::double, 'some_nan2'),
(10000, 'NaN'::double, 'some_nan2'),
(20000, 1::double, 'some_nan2'),
(0, 'NaN'::double, 'some_nan3'),
(10000, 0::double, 'some_nan3'),
(20000, 1::double, 'some_nan3'),
(0, 'NaN'::double, 'only_nan'),
(10000, 'NaN'::double, 'only_nan'),
(20000, 'NaN'::double, 'only_nan');
-- eval instant at 1m min_over_time(data[2m])
-- {type="numbers"} 0
-- {type="some_nan"} 0
-- {type="some_nan2"} 1
-- {type="some_nan3"} 0
-- {type="only_nan"} NaN
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') min_over_time(data[2m]);
-- eval instant at 1m max_over_time(data[2m])
-- {type="numbers"} 3
-- {type="some_nan"} 2
-- {type="some_nan2"} 2
-- {type="some_nan3"} 1
-- {type="only_nan"} NaN
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') max_over_time(data[2m]);
-- eval instant at 1m last_over_time(data[2m])
-- data{type="numbers"} 3
-- data{type="some_nan"} NaN
-- data{type="some_nan2"} 1
-- data{type="some_nan3"} 1
-- data{type="only_nan"} NaN
-- SQLNESS SORT_RESULT 2 1
tql eval (60, 60, '1s') last_over_time(data[2m]);
drop table data;