mirror of
https://github.com/prometheus/prometheus.git
synced 2025-03-05 20:59:13 -08:00
Moves TestNativeHistogram_MulDivOperator to promql testing framework (#14688)
Some checks are pending
buf.build / lint and publish (push) Waiting to run
CI / Go tests (push) Waiting to run
CI / More Go tests (push) Waiting to run
CI / Go tests with previous Go version (push) Waiting to run
CI / UI tests (push) Waiting to run
CI / Go tests on Windows (push) Waiting to run
CI / Mixins tests (push) Waiting to run
CI / Build Prometheus for common architectures (0) (push) Waiting to run
CI / Build Prometheus for common architectures (1) (push) Waiting to run
CI / Build Prometheus for common architectures (2) (push) Waiting to run
CI / Build Prometheus for all architectures (0) (push) Waiting to run
CI / Build Prometheus for all architectures (1) (push) Waiting to run
CI / Build Prometheus for all architectures (10) (push) Waiting to run
CI / Build Prometheus for all architectures (11) (push) Waiting to run
CI / Build Prometheus for all architectures (2) (push) Waiting to run
CI / Build Prometheus for all architectures (3) (push) Waiting to run
CI / Build Prometheus for all architectures (4) (push) Waiting to run
CI / Build Prometheus for all architectures (5) (push) Waiting to run
CI / Build Prometheus for all architectures (6) (push) Waiting to run
CI / Build Prometheus for all architectures (7) (push) Waiting to run
CI / Build Prometheus for all architectures (8) (push) Waiting to run
CI / Build Prometheus for all architectures (9) (push) Waiting to run
CI / Report status of build Prometheus for all architectures (push) Blocked by required conditions
CI / Check generated parser (push) Waiting to run
CI / golangci-lint (push) Waiting to run
CI / fuzzing (push) Waiting to run
CI / codeql (push) Waiting to run
CI / Publish main branch artifacts (push) Blocked by required conditions
CI / Publish release artefacts (push) Blocked by required conditions
CI / Publish UI on npm Registry (push) Blocked by required conditions
Scorecards supply-chain security / Scorecards analysis (push) Waiting to run
Some checks are pending
buf.build / lint and publish (push) Waiting to run
CI / Go tests (push) Waiting to run
CI / More Go tests (push) Waiting to run
CI / Go tests with previous Go version (push) Waiting to run
CI / UI tests (push) Waiting to run
CI / Go tests on Windows (push) Waiting to run
CI / Mixins tests (push) Waiting to run
CI / Build Prometheus for common architectures (0) (push) Waiting to run
CI / Build Prometheus for common architectures (1) (push) Waiting to run
CI / Build Prometheus for common architectures (2) (push) Waiting to run
CI / Build Prometheus for all architectures (0) (push) Waiting to run
CI / Build Prometheus for all architectures (1) (push) Waiting to run
CI / Build Prometheus for all architectures (10) (push) Waiting to run
CI / Build Prometheus for all architectures (11) (push) Waiting to run
CI / Build Prometheus for all architectures (2) (push) Waiting to run
CI / Build Prometheus for all architectures (3) (push) Waiting to run
CI / Build Prometheus for all architectures (4) (push) Waiting to run
CI / Build Prometheus for all architectures (5) (push) Waiting to run
CI / Build Prometheus for all architectures (6) (push) Waiting to run
CI / Build Prometheus for all architectures (7) (push) Waiting to run
CI / Build Prometheus for all architectures (8) (push) Waiting to run
CI / Build Prometheus for all architectures (9) (push) Waiting to run
CI / Report status of build Prometheus for all architectures (push) Blocked by required conditions
CI / Check generated parser (push) Waiting to run
CI / golangci-lint (push) Waiting to run
CI / fuzzing (push) Waiting to run
CI / codeql (push) Waiting to run
CI / Publish main branch artifacts (push) Blocked by required conditions
CI / Publish release artefacts (push) Blocked by required conditions
CI / Publish UI on npm Registry (push) Blocked by required conditions
Scorecards supply-chain security / Scorecards analysis (push) Waiting to run
PromQL: add test for mul and div operator Also, remove the converted test from the engine_test.go file. This also includes an extension of the test framework to allow NaN/Inf in histogram buckets. --------- Signed-off-by: Neeraj Gartia <neerajgartia211002@gmail.com>
This commit is contained in:
parent
e9e3d64b7c
commit
8c7bf39d96
|
@ -17,7 +17,6 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
|
||||||
"os"
|
"os"
|
||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
@ -3337,171 +3336,6 @@ func TestNativeHistogram_SubOperator(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNativeHistogram_MulDivOperator(t *testing.T) {
|
|
||||||
// TODO(codesome): Integrate histograms into the PromQL testing framework
|
|
||||||
// and write more tests there.
|
|
||||||
originalHistogram := histogram.Histogram{
|
|
||||||
Schema: 0,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 33,
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 3,
|
|
||||||
PositiveSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
PositiveBuckets: []int64{3, 0, 0},
|
|
||||||
NegativeSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
NegativeBuckets: []int64{3, 0, 0},
|
|
||||||
}
|
|
||||||
|
|
||||||
cases := []struct {
|
|
||||||
scalar float64
|
|
||||||
histogram histogram.Histogram
|
|
||||||
expectedMul histogram.FloatHistogram
|
|
||||||
expectedDiv histogram.FloatHistogram
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
scalar: 3,
|
|
||||||
histogram: originalHistogram,
|
|
||||||
expectedMul: histogram.FloatHistogram{
|
|
||||||
Schema: 0,
|
|
||||||
Count: 63,
|
|
||||||
Sum: 99,
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 9,
|
|
||||||
PositiveSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
PositiveBuckets: []float64{9, 9, 9},
|
|
||||||
NegativeSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
NegativeBuckets: []float64{9, 9, 9},
|
|
||||||
},
|
|
||||||
expectedDiv: histogram.FloatHistogram{
|
|
||||||
Schema: 0,
|
|
||||||
Count: 7,
|
|
||||||
Sum: 11,
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 1,
|
|
||||||
PositiveSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
PositiveBuckets: []float64{1, 1, 1},
|
|
||||||
NegativeSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
NegativeBuckets: []float64{1, 1, 1},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
scalar: 0,
|
|
||||||
histogram: originalHistogram,
|
|
||||||
expectedMul: histogram.FloatHistogram{
|
|
||||||
Schema: 0,
|
|
||||||
Count: 0,
|
|
||||||
Sum: 0,
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 0,
|
|
||||||
PositiveSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
PositiveBuckets: []float64{0, 0, 0},
|
|
||||||
NegativeSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
NegativeBuckets: []float64{0, 0, 0},
|
|
||||||
},
|
|
||||||
expectedDiv: histogram.FloatHistogram{
|
|
||||||
Schema: 0,
|
|
||||||
Count: math.Inf(1),
|
|
||||||
Sum: math.Inf(1),
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: math.Inf(1),
|
|
||||||
PositiveSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
PositiveBuckets: []float64{math.Inf(1), math.Inf(1), math.Inf(1)},
|
|
||||||
NegativeSpans: []histogram.Span{
|
|
||||||
{Offset: 0, Length: 3},
|
|
||||||
},
|
|
||||||
NegativeBuckets: []float64{math.Inf(1), math.Inf(1), math.Inf(1)},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
idx0 := int64(0)
|
|
||||||
for _, c := range cases {
|
|
||||||
for _, floatHisto := range []bool{true, false} {
|
|
||||||
t.Run(fmt.Sprintf("floatHistogram=%t %d", floatHisto, idx0), func(t *testing.T) {
|
|
||||||
storage := teststorage.New(t)
|
|
||||||
t.Cleanup(func() { storage.Close() })
|
|
||||||
|
|
||||||
seriesName := "sparse_histogram_series"
|
|
||||||
floatSeriesName := "float_series"
|
|
||||||
|
|
||||||
engine := newTestEngine()
|
|
||||||
|
|
||||||
ts := idx0 * int64(10*time.Minute/time.Millisecond)
|
|
||||||
app := storage.Appender(context.Background())
|
|
||||||
h := c.histogram
|
|
||||||
lbls := labels.FromStrings("__name__", seriesName)
|
|
||||||
// Since we mutate h later, we need to create a copy here.
|
|
||||||
var err error
|
|
||||||
if floatHisto {
|
|
||||||
_, err = app.AppendHistogram(0, lbls, ts, nil, h.Copy().ToFloat(nil))
|
|
||||||
} else {
|
|
||||||
_, err = app.AppendHistogram(0, lbls, ts, h.Copy(), nil)
|
|
||||||
}
|
|
||||||
require.NoError(t, err)
|
|
||||||
_, err = app.Append(0, labels.FromStrings("__name__", floatSeriesName), ts, c.scalar)
|
|
||||||
require.NoError(t, err)
|
|
||||||
require.NoError(t, app.Commit())
|
|
||||||
|
|
||||||
queryAndCheck := func(queryString string, exp promql.Vector) {
|
|
||||||
qry, err := engine.NewInstantQuery(context.Background(), storage, nil, queryString, timestamp.Time(ts))
|
|
||||||
require.NoError(t, err)
|
|
||||||
|
|
||||||
res := qry.Exec(context.Background())
|
|
||||||
require.NoError(t, res.Err)
|
|
||||||
|
|
||||||
vector, err := res.Vector()
|
|
||||||
require.NoError(t, err)
|
|
||||||
|
|
||||||
testutil.RequireEqual(t, exp, vector)
|
|
||||||
}
|
|
||||||
|
|
||||||
// histogram * scalar.
|
|
||||||
queryString := fmt.Sprintf(`%s * %f`, seriesName, c.scalar)
|
|
||||||
queryAndCheck(queryString, []promql.Sample{{T: ts, H: &c.expectedMul, Metric: labels.EmptyLabels(), DropName: true}})
|
|
||||||
|
|
||||||
// scalar * histogram.
|
|
||||||
queryString = fmt.Sprintf(`%f * %s`, c.scalar, seriesName)
|
|
||||||
queryAndCheck(queryString, []promql.Sample{{T: ts, H: &c.expectedMul, Metric: labels.EmptyLabels(), DropName: true}})
|
|
||||||
|
|
||||||
// histogram * float.
|
|
||||||
queryString = fmt.Sprintf(`%s * %s`, seriesName, floatSeriesName)
|
|
||||||
queryAndCheck(queryString, []promql.Sample{{T: ts, H: &c.expectedMul, Metric: labels.EmptyLabels()}})
|
|
||||||
|
|
||||||
// float * histogram.
|
|
||||||
queryString = fmt.Sprintf(`%s * %s`, floatSeriesName, seriesName)
|
|
||||||
queryAndCheck(queryString, []promql.Sample{{T: ts, H: &c.expectedMul, Metric: labels.EmptyLabels()}})
|
|
||||||
|
|
||||||
// histogram / scalar.
|
|
||||||
queryString = fmt.Sprintf(`%s / %f`, seriesName, c.scalar)
|
|
||||||
queryAndCheck(queryString, []promql.Sample{{T: ts, H: &c.expectedDiv, Metric: labels.EmptyLabels(), DropName: true}})
|
|
||||||
|
|
||||||
// histogram / float.
|
|
||||||
queryString = fmt.Sprintf(`%s / %s`, seriesName, floatSeriesName)
|
|
||||||
queryAndCheck(queryString, []promql.Sample{{T: ts, H: &c.expectedDiv, Metric: labels.EmptyLabels()}})
|
|
||||||
})
|
|
||||||
idx0++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestQueryLookbackDelta(t *testing.T) {
|
func TestQueryLookbackDelta(t *testing.T) {
|
||||||
var (
|
var (
|
||||||
load = `load 5m
|
load = `load 5m
|
||||||
|
|
|
@ -617,6 +617,16 @@ func lexBuckets(l *Lexer) stateFn {
|
||||||
l.bracketOpen = false
|
l.bracketOpen = false
|
||||||
l.emit(RIGHT_BRACKET)
|
l.emit(RIGHT_BRACKET)
|
||||||
return lexHistogram
|
return lexHistogram
|
||||||
|
case isAlpha(r):
|
||||||
|
// Current word is Inf or NaN.
|
||||||
|
word := l.input[l.start:l.pos]
|
||||||
|
if desc, ok := key[strings.ToLower(word)]; ok {
|
||||||
|
if desc == NUMBER {
|
||||||
|
l.emit(desc)
|
||||||
|
return lexStatements
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return lexBuckets
|
||||||
default:
|
default:
|
||||||
return l.errorf("invalid character in buckets description: %q", r)
|
return l.errorf("invalid character in buckets description: %q", r)
|
||||||
}
|
}
|
||||||
|
|
|
@ -639,6 +639,29 @@ var tests = []struct {
|
||||||
},
|
},
|
||||||
seriesDesc: true,
|
seriesDesc: true,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
input: `{} {{buckets: [Inf NaN] schema:1}}`,
|
||||||
|
expected: []Item{
|
||||||
|
{LEFT_BRACE, 0, `{`},
|
||||||
|
{RIGHT_BRACE, 1, `}`},
|
||||||
|
{SPACE, 2, ` `},
|
||||||
|
{OPEN_HIST, 3, `{{`},
|
||||||
|
{BUCKETS_DESC, 5, `buckets`},
|
||||||
|
{COLON, 12, `:`},
|
||||||
|
{SPACE, 13, ` `},
|
||||||
|
{LEFT_BRACKET, 14, `[`},
|
||||||
|
{NUMBER, 15, `Inf`},
|
||||||
|
{SPACE, 18, ` `},
|
||||||
|
{NUMBER, 19, `NaN`},
|
||||||
|
{RIGHT_BRACKET, 22, `]`},
|
||||||
|
{SPACE, 23, ` `},
|
||||||
|
{SCHEMA_DESC, 24, `schema`},
|
||||||
|
{COLON, 30, `:`},
|
||||||
|
{NUMBER, 31, `1`},
|
||||||
|
{CLOSE_HIST, 32, `}}`},
|
||||||
|
},
|
||||||
|
seriesDesc: true,
|
||||||
|
},
|
||||||
{ // Series with sum as -Inf and count as NaN.
|
{ // Series with sum as -Inf and count as NaN.
|
||||||
input: `{} {{buckets: [5 10 7] sum:Inf count:NaN}}`,
|
input: `{} {{buckets: [5 10 7] sum:Inf count:NaN}}`,
|
||||||
expected: []Item{
|
expected: []Item{
|
||||||
|
|
|
@ -718,6 +718,52 @@ eval instant at 10m histogram_fraction(-Inf, +Inf, histogram_fraction_4)
|
||||||
eval instant at 10m histogram_sum(scalar(histogram_fraction(-Inf, +Inf, sum(histogram_fraction_4))) * histogram_fraction_4)
|
eval instant at 10m histogram_sum(scalar(histogram_fraction(-Inf, +Inf, sum(histogram_fraction_4))) * histogram_fraction_4)
|
||||||
{} 100
|
{} 100
|
||||||
|
|
||||||
|
# Apply multiplication and division operator to histogram.
|
||||||
|
load 10m
|
||||||
|
histogram_mul_div {{schema:0 count:21 sum:33 z_bucket:3 z_bucket_w:0.001 buckets:[3 3 3] n_buckets:[3 3 3]}}x1
|
||||||
|
float_series_3 3+0x1
|
||||||
|
float_series_0 0+0x1
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div*3
|
||||||
|
{} {{schema:0 count:63 sum:99 z_bucket:9 z_bucket_w:0.001 buckets:[9 9 9] n_buckets:[9 9 9]}}
|
||||||
|
|
||||||
|
eval instant at 10m 3*histogram_mul_div
|
||||||
|
{} {{schema:0 count:63 sum:99 z_bucket:9 z_bucket_w:0.001 buckets:[9 9 9] n_buckets:[9 9 9]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div*float_series_3
|
||||||
|
{} {{schema:0 count:63 sum:99 z_bucket:9 z_bucket_w:0.001 buckets:[9 9 9] n_buckets:[9 9 9]}}
|
||||||
|
|
||||||
|
eval instant at 10m float_series_3*histogram_mul_div
|
||||||
|
{} {{schema:0 count:63 sum:99 z_bucket:9 z_bucket_w:0.001 buckets:[9 9 9] n_buckets:[9 9 9]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div/3
|
||||||
|
{} {{schema:0 count:7 sum:11 z_bucket:1 z_bucket_w:0.001 buckets:[1 1 1] n_buckets:[1 1 1]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div/float_series_3
|
||||||
|
{} {{schema:0 count:7 sum:11 z_bucket:1 z_bucket_w:0.001 buckets:[1 1 1] n_buckets:[1 1 1]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div*0
|
||||||
|
{} {{schema:0 count:0 sum:0 z_bucket:0 z_bucket_w:0.001 buckets:[0 0 0] n_buckets:[0 0 0]}}
|
||||||
|
|
||||||
|
eval instant at 10m 0*histogram_mul_div
|
||||||
|
{} {{schema:0 count:0 sum:0 z_bucket:0 z_bucket_w:0.001 buckets:[0 0 0] n_buckets:[0 0 0]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div*float_series_0
|
||||||
|
{} {{schema:0 count:0 sum:0 z_bucket:0 z_bucket_w:0.001 buckets:[0 0 0] n_buckets:[0 0 0]}}
|
||||||
|
|
||||||
|
eval instant at 10m float_series_0*histogram_mul_div
|
||||||
|
{} {{schema:0 count:0 sum:0 z_bucket:0 z_bucket_w:0.001 buckets:[0 0 0] n_buckets:[0 0 0]}}
|
||||||
|
|
||||||
|
# TODO: (NeerajGartia21) remove all the histogram buckets in case of division with zero. See: https://github.com/prometheus/prometheus/issues/13934
|
||||||
|
eval instant at 10m histogram_mul_div/0
|
||||||
|
{} {{schema:0 count:Inf sum:Inf z_bucket:Inf z_bucket_w:0.001 buckets:[Inf Inf Inf] n_buckets:[Inf Inf Inf]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div/float_series_0
|
||||||
|
{} {{schema:0 count:Inf sum:Inf z_bucket:Inf z_bucket_w:0.001 buckets:[Inf Inf Inf] n_buckets:[Inf Inf Inf]}}
|
||||||
|
|
||||||
|
eval instant at 10m histogram_mul_div*0/0
|
||||||
|
{} {{schema:0 count:NaN sum:NaN z_bucket:NaN z_bucket_w:0.001 buckets:[NaN NaN NaN] n_buckets:[NaN NaN NaN]}}
|
||||||
|
|
||||||
clear
|
clear
|
||||||
|
|
||||||
# Counter reset only noticeable in a single bucket.
|
# Counter reset only noticeable in a single bucket.
|
||||||
|
|
Loading…
Reference in a new issue