prometheus/promql/promqltest/testdata/operators.test
Björn Rabenstein 125a90899c
promqltest: Complete the tests for info annotations (#15429)
promqltest: Complete the tests for info annotations

So far, we did not test for the _absence_ of an info annotation
(because many tests triggered info annotations, which we haven't taken
into account so far).

The test for info annotations was also missed for range queries.

This completes the tests for info annotations (and refactors the many
`if` statements into a somewhat more compact `switch` statement).

It fixes most tests to not emit an info annotation anymore. Or it
changes the `eval` to `eval_info` where we actually want to test for
the info annotation.

It also fixes a few spelling errors in comments.

---------

Signed-off-by: beorn7 <beorn@grafana.com>
Signed-off-by: Björn Rabenstein <github@rabenste.in>
Co-authored-by: Arve Knudsen <arve.knudsen@gmail.com>
2024-11-21 14:20:38 +01:00

857 lines
32 KiB
Plaintext

load 5m
http_requests_total{job="api-server", instance="0", group="production"} 0+10x10
http_requests_total{job="api-server", instance="1", group="production"} 0+20x10
http_requests_total{job="api-server", instance="0", group="canary"} 0+30x10
http_requests_total{job="api-server", instance="1", group="canary"} 0+40x10
http_requests_total{job="app-server", instance="0", group="production"} 0+50x10
http_requests_total{job="app-server", instance="1", group="production"} 0+60x10
http_requests_total{job="app-server", instance="0", group="canary"} 0+70x10
http_requests_total{job="app-server", instance="1", group="canary"} 0+80x10
http_requests_histogram{job="app-server", instance="1", group="production"} {{schema:1 sum:15 count:10 buckets:[3 2 5 7 9]}}x11
load 5m
vector_matching_a{l="x"} 0+1x100
vector_matching_a{l="y"} 0+2x50
vector_matching_b{l="x"} 0+4x25
eval instant at 50m SUM(http_requests_total) BY (job) - COUNT(http_requests_total) BY (job)
{job="api-server"} 996
{job="app-server"} 2596
eval instant at 50m 2 - SUM(http_requests_total) BY (job)
{job="api-server"} -998
{job="app-server"} -2598
eval instant at 50m -http_requests_total{job="api-server",instance="0",group="production"}
{job="api-server",instance="0",group="production"} -100
eval instant at 50m +http_requests_total{job="api-server",instance="0",group="production"}
http_requests_total{job="api-server",instance="0",group="production"} 100
eval instant at 50m - - - SUM(http_requests_total) BY (job)
{job="api-server"} -1000
{job="app-server"} -2600
eval instant at 50m - - - 1
-1
eval instant at 50m -2^---1*3
-1.5
eval instant at 50m 2/-2^---1*3+2
-10
eval instant at 50m -10^3 * - SUM(http_requests_total) BY (job) ^ -1
{job="api-server"} 1
{job="app-server"} 0.38461538461538464
eval instant at 50m 1000 / SUM(http_requests_total) BY (job)
{job="api-server"} 1
{job="app-server"} 0.38461538461538464
eval instant at 50m SUM(http_requests_total) BY (job) - 2
{job="api-server"} 998
{job="app-server"} 2598
eval instant at 50m SUM(http_requests_total) BY (job) % 3
{job="api-server"} 1
{job="app-server"} 2
eval instant at 50m SUM(http_requests_total) BY (job) % 0.3
{job="api-server"} 0.1
{job="app-server"} 0.2
eval instant at 50m SUM(http_requests_total) BY (job) ^ 2
{job="api-server"} 1000000
{job="app-server"} 6760000
eval instant at 50m SUM(http_requests_total) BY (job) % 3 ^ 2
{job="api-server"} 1
{job="app-server"} 8
eval instant at 50m SUM(http_requests_total) BY (job) % 2 ^ (3 ^ 2)
{job="api-server"} 488
{job="app-server"} 40
eval instant at 50m SUM(http_requests_total) BY (job) % 2 ^ 3 ^ 2
{job="api-server"} 488
{job="app-server"} 40
eval instant at 50m SUM(http_requests_total) BY (job) % 2 ^ 3 ^ 2 ^ 2
{job="api-server"} 1000
{job="app-server"} 2600
eval instant at 50m COUNT(http_requests_total) BY (job) ^ COUNT(http_requests_total) BY (job)
{job="api-server"} 256
{job="app-server"} 256
eval instant at 50m SUM(http_requests_total) BY (job) / 0
{job="api-server"} +Inf
{job="app-server"} +Inf
eval instant at 50m http_requests_total{group="canary", instance="0", job="api-server"} / 0
{group="canary", instance="0", job="api-server"} +Inf
eval instant at 50m -1 * http_requests_total{group="canary", instance="0", job="api-server"} / 0
{group="canary", instance="0", job="api-server"} -Inf
eval instant at 50m 0 * http_requests_total{group="canary", instance="0", job="api-server"} / 0
{group="canary", instance="0", job="api-server"} NaN
eval instant at 50m 0 * http_requests_total{group="canary", instance="0", job="api-server"} % 0
{group="canary", instance="0", job="api-server"} NaN
eval instant at 50m SUM(http_requests_total) BY (job) + SUM(http_requests_total) BY (job)
{job="api-server"} 2000
{job="app-server"} 5200
eval instant at 50m (SUM((http_requests_total)) BY (job)) + SUM(http_requests_total) BY (job)
{job="api-server"} 2000
{job="app-server"} 5200
eval instant at 50m http_requests_total{job="api-server", group="canary"}
http_requests_total{group="canary", instance="0", job="api-server"} 300
http_requests_total{group="canary", instance="1", job="api-server"} 400
eval instant at 50m http_requests_total{job="api-server", group="canary"} + rate(http_requests_total{job="api-server"}[10m]) * 5 * 60
{group="canary", instance="0", job="api-server"} 330
{group="canary", instance="1", job="api-server"} 440
eval instant at 50m rate(http_requests_total[25m]) * 25 * 60
{group="canary", instance="0", job="api-server"} 150
{group="canary", instance="0", job="app-server"} 350
{group="canary", instance="1", job="api-server"} 200
{group="canary", instance="1", job="app-server"} 400
{group="production", instance="0", job="api-server"} 50
{group="production", instance="0", job="app-server"} 249.99999999999997
{group="production", instance="1", job="api-server"} 100
{group="production", instance="1", job="app-server"} 300
eval instant at 50m (rate((http_requests_total[25m])) * 25) * 60
{group="canary", instance="0", job="api-server"} 150
{group="canary", instance="0", job="app-server"} 350
{group="canary", instance="1", job="api-server"} 200
{group="canary", instance="1", job="app-server"} 400
{group="production", instance="0", job="api-server"} 50
{group="production", instance="0", job="app-server"} 249.99999999999997
{group="production", instance="1", job="api-server"} 100
{group="production", instance="1", job="app-server"} 300
eval instant at 50m http_requests_total{group="canary"} and http_requests_total{instance="0"}
http_requests_total{group="canary", instance="0", job="api-server"} 300
http_requests_total{group="canary", instance="0", job="app-server"} 700
eval instant at 50m (http_requests_total{group="canary"} + 1) and http_requests_total{instance="0"}
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
eval instant at 50m (http_requests_total{group="canary"} + 1) and on(instance, job) http_requests_total{instance="0", group="production"}
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
eval instant at 50m (http_requests_total{group="canary"} + 1) and on(instance) http_requests_total{instance="0", group="production"}
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
eval instant at 50m (http_requests_total{group="canary"} + 1) and ignoring(group) http_requests_total{instance="0", group="production"}
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
eval instant at 50m (http_requests_total{group="canary"} + 1) and ignoring(group, job) http_requests_total{instance="0", group="production"}
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
eval instant at 50m http_requests_total{group="canary"} or http_requests_total{group="production"}
http_requests_total{group="canary", instance="0", job="api-server"} 300
http_requests_total{group="canary", instance="0", job="app-server"} 700
http_requests_total{group="canary", instance="1", job="api-server"} 400
http_requests_total{group="canary", instance="1", job="app-server"} 800
http_requests_total{group="production", instance="0", job="api-server"} 100
http_requests_total{group="production", instance="0", job="app-server"} 500
http_requests_total{group="production", instance="1", job="api-server"} 200
http_requests_total{group="production", instance="1", job="app-server"} 600
# On overlap the rhs samples must be dropped.
eval instant at 50m (http_requests_total{group="canary"} + 1) or http_requests_total{instance="1"}
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
{group="canary", instance="1", job="api-server"} 401
{group="canary", instance="1", job="app-server"} 801
http_requests_total{group="production", instance="1", job="api-server"} 200
http_requests_total{group="production", instance="1", job="app-server"} 600
# Matching only on instance excludes everything that has instance=0/1 but includes
# entries without the instance label.
eval instant at 50m (http_requests_total{group="canary"} + 1) or on(instance) (http_requests_total or cpu_count or vector_matching_a)
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
{group="canary", instance="1", job="api-server"} 401
{group="canary", instance="1", job="app-server"} 801
vector_matching_a{l="x"} 10
vector_matching_a{l="y"} 20
eval instant at 50m (http_requests_total{group="canary"} + 1) or ignoring(l, group, job) (http_requests_total or cpu_count or vector_matching_a)
{group="canary", instance="0", job="api-server"} 301
{group="canary", instance="0", job="app-server"} 701
{group="canary", instance="1", job="api-server"} 401
{group="canary", instance="1", job="app-server"} 801
vector_matching_a{l="x"} 10
vector_matching_a{l="y"} 20
eval instant at 50m http_requests_total{group="canary"} unless http_requests_total{instance="0"}
http_requests_total{group="canary", instance="1", job="api-server"} 400
http_requests_total{group="canary", instance="1", job="app-server"} 800
eval instant at 50m http_requests_total{group="canary"} unless on(job) http_requests_total{instance="0"}
eval instant at 50m http_requests_total{group="canary"} unless on(job, instance) http_requests_total{instance="0"}
http_requests_total{group="canary", instance="1", job="api-server"} 400
http_requests_total{group="canary", instance="1", job="app-server"} 800
eval instant at 50m http_requests_total{group="canary"} / on(instance,job) http_requests_total{group="production"}
{instance="0", job="api-server"} 3
{instance="0", job="app-server"} 1.4
{instance="1", job="api-server"} 2
{instance="1", job="app-server"} 1.3333333333333333
eval instant at 50m http_requests_total{group="canary"} unless ignoring(group, instance) http_requests_total{instance="0"}
eval instant at 50m http_requests_total{group="canary"} unless ignoring(group) http_requests_total{instance="0"}
http_requests_total{group="canary", instance="1", job="api-server"} 400
http_requests_total{group="canary", instance="1", job="app-server"} 800
eval instant at 50m http_requests_total{group="canary"} / ignoring(group) http_requests_total{group="production"}
{instance="0", job="api-server"} 3
{instance="0", job="app-server"} 1.4
{instance="1", job="api-server"} 2
{instance="1", job="app-server"} 1.3333333333333333
# https://github.com/prometheus/prometheus/issues/1489
eval instant at 50m http_requests_total AND ON (dummy) vector(1)
http_requests_total{group="canary", instance="0", job="api-server"} 300
http_requests_total{group="canary", instance="0", job="app-server"} 700
http_requests_total{group="canary", instance="1", job="api-server"} 400
http_requests_total{group="canary", instance="1", job="app-server"} 800
http_requests_total{group="production", instance="0", job="api-server"} 100
http_requests_total{group="production", instance="0", job="app-server"} 500
http_requests_total{group="production", instance="1", job="api-server"} 200
http_requests_total{group="production", instance="1", job="app-server"} 600
eval instant at 50m http_requests_total AND IGNORING (group, instance, job) vector(1)
http_requests_total{group="canary", instance="0", job="api-server"} 300
http_requests_total{group="canary", instance="0", job="app-server"} 700
http_requests_total{group="canary", instance="1", job="api-server"} 400
http_requests_total{group="canary", instance="1", job="app-server"} 800
http_requests_total{group="production", instance="0", job="api-server"} 100
http_requests_total{group="production", instance="0", job="app-server"} 500
http_requests_total{group="production", instance="1", job="api-server"} 200
http_requests_total{group="production", instance="1", job="app-server"} 600
# Comparisons.
eval instant at 50m SUM(http_requests_total) BY (job) > 1000
{job="app-server"} 2600
eval instant at 50m 1000 < SUM(http_requests_total) BY (job)
{job="app-server"} 2600
eval instant at 50m SUM(http_requests_total) BY (job) <= 1000
{job="api-server"} 1000
eval instant at 50m SUM(http_requests_total) BY (job) != 1000
{job="app-server"} 2600
eval instant at 50m SUM(http_requests_total) BY (job) == 1000
{job="api-server"} 1000
eval instant at 50m SUM(http_requests_total) BY (job) == bool 1000
{job="api-server"} 1
{job="app-server"} 0
eval instant at 50m SUM(http_requests_total) BY (job) == bool SUM(http_requests_total) BY (job)
{job="api-server"} 1
{job="app-server"} 1
eval instant at 50m SUM(http_requests_total) BY (job) != bool SUM(http_requests_total) BY (job)
{job="api-server"} 0
{job="app-server"} 0
eval instant at 50m 0 == bool 1
0
eval instant at 50m 1 == bool 1
1
eval instant at 50m http_requests_total{job="api-server", instance="0", group="production"} == bool 100
{job="api-server", instance="0", group="production"} 1
# The histogram is ignored here so the result doesn't change but it has an info annotation now.
eval_info instant at 5m {job="app-server"} == 80
http_requests_total{group="canary", instance="1", job="app-server"} 80
eval_info instant at 5m http_requests_histogram != 80
eval_info instant at 5m http_requests_histogram > 80
eval_info instant at 5m http_requests_histogram < 80
eval_info instant at 5m http_requests_histogram >= 80
eval_info instant at 5m http_requests_histogram <= 80
# Should produce valid results in case of (in)equality between two histograms.
eval instant at 5m http_requests_histogram == http_requests_histogram
http_requests_histogram{job="app-server", instance="1", group="production"} {{schema:1 sum:15 count:10 buckets:[3 2 5 7 9]}}
eval instant at 5m http_requests_histogram != http_requests_histogram
# group_left/group_right.
clear
load 5m
node_var{instance="abc",job="node"} 2
node_role{instance="abc",job="node",role="prometheus"} 1
load 5m
node_cpu{instance="abc",job="node",mode="idle"} 3
node_cpu{instance="abc",job="node",mode="user"} 1
node_cpu{instance="def",job="node",mode="idle"} 8
node_cpu{instance="def",job="node",mode="user"} 2
load 5m
random{foo="bar"} 1
load 5m
threshold{instance="abc",job="node",target="a@b.com"} 0
# Copy machine role to node variable.
eval instant at 1m node_role * on (instance) group_right (role) node_var
{instance="abc",job="node",role="prometheus"} 2
eval instant at 1m node_var * on (instance) group_left (role) node_role
{instance="abc",job="node",role="prometheus"} 2
eval instant at 1m node_var * ignoring (role) group_left (role) node_role
{instance="abc",job="node",role="prometheus"} 2
eval instant at 1m node_role * ignoring (role) group_right (role) node_var
{instance="abc",job="node",role="prometheus"} 2
# Copy machine role to node variable with instrumentation labels.
eval instant at 1m node_cpu * ignoring (role, mode) group_left (role) node_role
{instance="abc",job="node",mode="idle",role="prometheus"} 3
{instance="abc",job="node",mode="user",role="prometheus"} 1
eval instant at 1m node_cpu * on (instance) group_left (role) node_role
{instance="abc",job="node",mode="idle",role="prometheus"} 3
{instance="abc",job="node",mode="user",role="prometheus"} 1
# Ratio of total.
eval instant at 1m node_cpu / on (instance) group_left sum by (instance,job)(node_cpu)
{instance="abc",job="node",mode="idle"} .75
{instance="abc",job="node",mode="user"} .25
{instance="def",job="node",mode="idle"} .80
{instance="def",job="node",mode="user"} .20
eval instant at 1m sum by (mode, job)(node_cpu) / on (job) group_left sum by (job)(node_cpu)
{job="node",mode="idle"} 0.7857142857142857
{job="node",mode="user"} 0.21428571428571427
eval instant at 1m sum(sum by (mode, job)(node_cpu) / on (job) group_left sum by (job)(node_cpu))
{} 1.0
eval instant at 1m node_cpu / ignoring (mode) group_left sum without (mode)(node_cpu)
{instance="abc",job="node",mode="idle"} .75
{instance="abc",job="node",mode="user"} .25
{instance="def",job="node",mode="idle"} .80
{instance="def",job="node",mode="user"} .20
eval instant at 1m node_cpu / ignoring (mode) group_left(dummy) sum without (mode)(node_cpu)
{instance="abc",job="node",mode="idle"} .75
{instance="abc",job="node",mode="user"} .25
{instance="def",job="node",mode="idle"} .80
{instance="def",job="node",mode="user"} .20
eval instant at 1m sum without (instance)(node_cpu) / ignoring (mode) group_left sum without (instance, mode)(node_cpu)
{job="node",mode="idle"} 0.7857142857142857
{job="node",mode="user"} 0.21428571428571427
eval instant at 1m sum(sum without (instance)(node_cpu) / ignoring (mode) group_left sum without (instance, mode)(node_cpu))
{} 1.0
# Copy over label from metric with no matching labels, without having to list cross-job target labels ('job' here).
eval instant at 1m node_cpu + on(dummy) group_left(foo) random*0
{instance="abc",job="node",mode="idle",foo="bar"} 3
{instance="abc",job="node",mode="user",foo="bar"} 1
{instance="def",job="node",mode="idle",foo="bar"} 8
{instance="def",job="node",mode="user",foo="bar"} 2
# Use threshold from metric, and copy over target.
eval instant at 1m node_cpu > on(job, instance) group_left(target) threshold
node_cpu{instance="abc",job="node",mode="idle",target="a@b.com"} 3
node_cpu{instance="abc",job="node",mode="user",target="a@b.com"} 1
# Use threshold from metric, and a default (1) if it's not present.
eval instant at 1m node_cpu > on(job, instance) group_left(target) (threshold or on (job, instance) (sum by (job, instance)(node_cpu) * 0 + 1))
node_cpu{instance="abc",job="node",mode="idle",target="a@b.com"} 3
node_cpu{instance="abc",job="node",mode="user",target="a@b.com"} 1
node_cpu{instance="def",job="node",mode="idle"} 8
node_cpu{instance="def",job="node",mode="user"} 2
# Check that binops drop the metric name.
eval instant at 1m node_cpu + 2
{instance="abc",job="node",mode="idle"} 5
{instance="abc",job="node",mode="user"} 3
{instance="def",job="node",mode="idle"} 10
{instance="def",job="node",mode="user"} 4
eval instant at 1m node_cpu - 2
{instance="abc",job="node",mode="idle"} 1
{instance="abc",job="node",mode="user"} -1
{instance="def",job="node",mode="idle"} 6
{instance="def",job="node",mode="user"} 0
eval instant at 1m node_cpu / 2
{instance="abc",job="node",mode="idle"} 1.5
{instance="abc",job="node",mode="user"} 0.5
{instance="def",job="node",mode="idle"} 4
{instance="def",job="node",mode="user"} 1
eval instant at 1m node_cpu * 2
{instance="abc",job="node",mode="idle"} 6
{instance="abc",job="node",mode="user"} 2
{instance="def",job="node",mode="idle"} 16
{instance="def",job="node",mode="user"} 4
eval instant at 1m node_cpu ^ 2
{instance="abc",job="node",mode="idle"} 9
{instance="abc",job="node",mode="user"} 1
{instance="def",job="node",mode="idle"} 64
{instance="def",job="node",mode="user"} 4
eval instant at 1m node_cpu % 2
{instance="abc",job="node",mode="idle"} 1
{instance="abc",job="node",mode="user"} 1
{instance="def",job="node",mode="idle"} 0
{instance="def",job="node",mode="user"} 0
clear
load 5m
random{foo="bar"} 2
metricA{baz="meh"} 3
metricB{baz="meh"} 4
# On with no labels, for metrics with no common labels.
eval instant at 1m random + on() metricA
{} 5
# Ignoring with no labels is the same as no ignoring.
eval instant at 1m metricA + ignoring() metricB
{baz="meh"} 7
eval instant at 1m metricA + metricB
{baz="meh"} 7
clear
# Test duplicate labelset in promql output.
load 5m
testmetric1{src="a",dst="b"} 0
testmetric2{src="a",dst="b"} 1
eval_fail instant at 0m -{__name__=~'testmetric1|testmetric2'}
clear
load 5m
test_total{instance="localhost"} 50
test_smaller{instance="localhost"} 10
eval instant at 1m test_total > bool test_smaller
{instance="localhost"} 1
eval instant at 1m test_total > test_smaller
test_total{instance="localhost"} 50
eval instant at 1m test_total < bool test_smaller
{instance="localhost"} 0
eval instant at 1m test_total < test_smaller
clear
# Testing atan2.
load 5m
trigy{} 10
trigx{} 20
trigNaN{} NaN
eval instant at 1m trigy atan2 trigx
{} 0.4636476090008061
eval instant at 1m trigy atan2 trigNaN
{} NaN
eval instant at 1m 10 atan2 20
0.4636476090008061
eval instant at 1m 10 atan2 NaN
NaN
clear
# Test comparison operations with floats and histograms.
load 6m
left_floats 1 2 _ _ 3 stale 4 5 NaN Inf -Inf
right_floats 4 _ _ 5 3 7 -1 20 NaN Inf -Inf
left_histograms {{schema:3 sum:4 count:4 buckets:[1 2 1]}} {{schema:3 sum:4.5 count:5 buckets:[1 3 1]}} _ _ {{schema:3 sum:4.5 count:5 buckets:[1 3 1]}}
right_histograms {{schema:3 sum:4 count:4 buckets:[1 2 1]}} {{schema:3 sum:4 count:4 buckets:[1 2 1]}} {{schema:3 sum:4 count:4 buckets:[1 2 1]}} _ _
right_floats_for_histograms 0 -1 2 3 4
eval range from 0 to 60m step 6m left_floats == right_floats
left_floats _ _ _ _ 3 _ _ _ _ Inf -Inf
eval range from 0 to 60m step 6m left_floats == bool right_floats
{} 0 _ _ _ 1 _ 0 0 0 1 1
eval range from 0 to 60m step 6m left_floats == does_not_match
# No results.
eval range from 0 to 24m step 6m left_histograms == right_histograms
left_histograms {{schema:3 sum:4 count:4 buckets:[1 2 1]}} _ _ _ _
eval range from 0 to 24m step 6m left_histograms == bool right_histograms
{} 1 0 _ _ _
eval_info range from 0 to 24m step 6m left_histograms == right_floats_for_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms == bool right_floats_for_histograms
# No results.
eval range from 0 to 60m step 6m left_floats != right_floats
left_floats 1 _ _ _ _ _ 4 5 NaN _ _
eval range from 0 to 60m step 6m left_floats != bool right_floats
{} 1 _ _ _ 0 _ 1 1 1 0 0
eval range from 0 to 24m step 6m left_histograms != right_histograms
left_histograms _ {{schema:3 sum:4.5 count:5 buckets:[1 3 1]}} _ _ _
eval range from 0 to 24m step 6m left_histograms != bool right_histograms
{} 0 1 _ _ _
eval_info range from 0 to 24m step 6m left_histograms != right_floats_for_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms != bool right_floats_for_histograms
# No results.
eval range from 0 to 60m step 6m left_floats > right_floats
left_floats _ _ _ _ _ _ 4 _ _ _ _
eval range from 0 to 60m step 6m left_floats > bool right_floats
{} 0 _ _ _ 0 _ 1 0 0 0 0
eval_info range from 0 to 24m step 6m left_histograms > right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms > bool right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms > right_floats_for_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms > bool right_floats_for_histograms
# No results.
eval range from 0 to 60m step 6m left_floats >= right_floats
left_floats _ _ _ _ 3 _ 4 _ _ Inf -Inf
eval range from 0 to 60m step 6m left_floats >= bool right_floats
{} 0 _ _ _ 1 _ 1 0 0 1 1
eval_info range from 0 to 24m step 6m left_histograms >= right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= bool right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= right_floats_for_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= bool right_floats_for_histograms
# No results.
eval range from 0 to 60m step 6m left_floats < right_floats
left_floats 1 _ _ _ _ _ _ 5 _ _ _
eval range from 0 to 60m step 6m left_floats < bool right_floats
{} 1 _ _ _ 0 _ 0 1 0 0 0
eval_info range from 0 to 24m step 6m left_histograms < right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms < bool right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms < right_floats_for_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms < bool right_floats_for_histograms
# No results.
eval range from 0 to 60m step 6m left_floats <= right_floats
left_floats 1 _ _ _ 3 _ _ 5 _ Inf -Inf
eval range from 0 to 60m step 6m left_floats <= bool right_floats
{} 1 _ _ _ 1 _ 0 1 0 1 1
eval_info range from 0 to 24m step 6m left_histograms <= right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= bool right_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= right_floats_for_histograms
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= bool right_floats_for_histograms
# No results.
# Vector / scalar combinations with scalar on right side
eval range from 0 to 60m step 6m left_floats == 3
left_floats _ _ _ _ 3 _ _ _ _ _ _
eval range from 0 to 60m step 6m left_floats != 3
left_floats 1 2 _ _ _ _ 4 5 NaN Inf -Inf
eval range from 0 to 60m step 6m left_floats > 3
left_floats _ _ _ _ _ _ 4 5 _ Inf _
eval range from 0 to 60m step 6m left_floats >= 3
left_floats _ _ _ _ 3 _ 4 5 _ Inf _
eval range from 0 to 60m step 6m left_floats < 3
left_floats 1 2 _ _ _ _ _ _ _ _ -Inf
eval range from 0 to 60m step 6m left_floats <= 3
left_floats 1 2 _ _ 3 _ _ _ _ _ -Inf
eval range from 0 to 60m step 6m left_floats == bool 3
{} 0 0 _ _ 1 _ 0 0 0 0 0
eval range from 0 to 60m step 6m left_floats == Inf
left_floats _ _ _ _ _ _ _ _ _ Inf _
eval range from 0 to 60m step 6m left_floats == bool Inf
{} 0 0 _ _ 0 _ 0 0 0 1 0
eval range from 0 to 60m step 6m left_floats == NaN
# No results.
eval range from 0 to 60m step 6m left_floats == bool NaN
{} 0 0 _ _ 0 _ 0 0 0 0 0
eval_info range from 0 to 24m step 6m left_histograms == 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms == 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms != 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms != 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms > 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms > 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms < 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms < 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms == bool 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms == bool 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms != bool 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms != bool 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms > bool 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms > bool 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= bool 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms >= bool 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms < bool 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms < bool 0
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= bool 3
# No results.
eval_info range from 0 to 24m step 6m left_histograms <= bool 0
# No results.
# Vector / scalar combinations with scalar on left side
eval range from 0 to 60m step 6m 3 == left_floats
left_floats _ _ _ _ 3 _ _ _ _ _ _
eval range from 0 to 60m step 6m 3 != left_floats
left_floats 1 2 _ _ _ _ 4 5 NaN Inf -Inf
eval range from 0 to 60m step 6m 3 < left_floats
left_floats _ _ _ _ _ _ 4 5 _ Inf _
eval range from 0 to 60m step 6m 3 <= left_floats
left_floats _ _ _ _ 3 _ 4 5 _ Inf _
eval range from 0 to 60m step 6m 3 > left_floats
left_floats 1 2 _ _ _ _ _ _ _ _ -Inf
eval range from 0 to 60m step 6m 3 >= left_floats
left_floats 1 2 _ _ 3 _ _ _ _ _ -Inf
eval range from 0 to 60m step 6m 3 == bool left_floats
{} 0 0 _ _ 1 _ 0 0 0 0 0
eval range from 0 to 60m step 6m Inf == left_floats
left_floats _ _ _ _ _ _ _ _ _ Inf _
eval range from 0 to 60m step 6m Inf == bool left_floats
{} 0 0 _ _ 0 _ 0 0 0 1 0
eval range from 0 to 60m step 6m NaN == left_floats
# No results.
eval range from 0 to 60m step 6m NaN == bool left_floats
{} 0 0 _ _ 0 _ 0 0 0 0 0
eval_info range from 0 to 24m step 6m 3 == left_histograms
# No results.
eval_info range from 0 to 24m step 6m 0 == left_histograms
# No results.
eval_info range from 0 to 24m step 6m 3 != left_histograms
# No results.
eval_info range from 0 to 24m step 6m 0 != left_histograms
# No results.
eval_info range from 0 to 24m step 6m 3 < left_histograms
# No results.
eval_info range from 0 to 24m step 6m 0 < left_histograms
# No results.
eval_info range from 0 to 24m step 6m 3 < left_histograms
# No results.
eval_info range from 0 to 24m step 6m 0 < left_histograms
# No results.
eval_info range from 0 to 24m step 6m 3 > left_histograms
# No results.
eval_info range from 0 to 24m step 6m 0 > left_histograms
# No results.
eval_info range from 0 to 24m step 6m 3 >= left_histograms
# No results.
eval_info range from 0 to 24m step 6m 0 >= left_histograms
# No results.
clear
# Test completely discarding or completely including series in results with "and on"
load_with_nhcb 5m
testhistogram_bucket{le="0.1", id="1"} 0+5x10
testhistogram_bucket{le="0.2", id="1"} 0+7x10
testhistogram_bucket{le="+Inf", id="1"} 0+12x10
testhistogram_bucket{le="0.1", id="2"} 0+4x10
testhistogram_bucket{le="0.2", id="2"} 0+6x10
testhistogram_bucket{le="+Inf", id="2"} 0+11x10
# Include all series when "and on" with non-empty vector.
eval instant at 10m (testhistogram_bucket) and on() (vector(1) == 1)
{__name__="testhistogram_bucket", le="0.1", id="1"} 10.0
{__name__="testhistogram_bucket", le="0.2", id="1"} 14.0
{__name__="testhistogram_bucket", le="+Inf", id="1"} 24.0
{__name__="testhistogram_bucket", le="0.1", id="2"} 8.0
{__name__="testhistogram_bucket", le="0.2", id="2"} 12.0
{__name__="testhistogram_bucket", le="+Inf", id="2"} 22.0
eval range from 0 to 10m step 5m (testhistogram_bucket) and on() (vector(1) == 1)
{__name__="testhistogram_bucket", le="0.1", id="1"} 0.0 5.0 10.0
{__name__="testhistogram_bucket", le="0.2", id="1"} 0.0 7.0 14.0
{__name__="testhistogram_bucket", le="+Inf", id="1"} 0.0 12.0 24.0
{__name__="testhistogram_bucket", le="0.1", id="2"} 0.0 4.0 8.0
{__name__="testhistogram_bucket", le="0.2", id="2"} 0.0 6.0 12.0
{__name__="testhistogram_bucket", le="+Inf", id="2"} 0.0 11.0 22.0
# Exclude all series when "and on" with empty vector.
eval instant at 10m (testhistogram_bucket) and on() (vector(-1) == 1)
eval range from 0 to 10m step 5m (testhistogram_bucket) and on() (vector(-1) == 1)
# Include all native histogram series when "and on" with non-empty vector.
eval instant at 10m (testhistogram) and on() (vector(1) == 1)
{__name__="testhistogram", id="1"} {{schema:-53 sum:0 count:24 buckets:[10 4 10] custom_values:[0.1 0.2]}}
{__name__="testhistogram", id="2"} {{schema:-53 sum:0 count:22 buckets:[8 4 10] custom_values:[0.1 0.2]}}
eval range from 0 to 10m step 5m (testhistogram) and on() (vector(1) == 1)
{__name__="testhistogram", id="1"} {{schema:-53 sum:0 count:0 custom_values:[0.1 0.2]}} {{schema:-53 sum:0 count:12 buckets:[5 2 5] custom_values:[0.1 0.2]}} {{schema:-53 sum:0 count:24 buckets:[10 4 10] custom_values:[0.1 0.2]}}
{__name__="testhistogram", id="2"} {{schema:-53 sum:0 count:0 custom_values:[0.1 0.2]}} {{schema:-53 sum:0 count:11 buckets:[4 2 5] custom_values:[0.1 0.2]}} {{schema:-53 sum:0 count:22 buckets:[8 4 10] custom_values:[0.1 0.2]}}
# Exclude all native histogram series when "and on" with empty vector.
eval instant at 10m (testhistogram) and on() (vector(-1) == 1)
eval range from 0 to 10m step 5m (testhistogram) and on() (vector(-1) == 1)
clear