mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-13 06:47:28 -08:00
parent
67274f0794
commit
b2ac3d2d86
|
@ -327,48 +327,6 @@ func funcClampMin(ev *evaluator, args Expressions) Value {
|
||||||
return vec
|
return vec
|
||||||
}
|
}
|
||||||
|
|
||||||
// === drop_common_labels(node ValueTypeVector) Vector ===
|
|
||||||
func funcDropCommonLabels(ev *evaluator, args Expressions) Value {
|
|
||||||
vec := ev.evalVector(args[0])
|
|
||||||
if len(vec) < 1 {
|
|
||||||
return Vector{}
|
|
||||||
}
|
|
||||||
common := map[string]string{}
|
|
||||||
|
|
||||||
for _, l := range vec[0].Metric {
|
|
||||||
// TODO(julius): Should we also drop common metric names?
|
|
||||||
if l.Name == labels.MetricName {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
common[l.Name] = l.Value
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, el := range vec[1:] {
|
|
||||||
for k, v := range common {
|
|
||||||
for _, l := range el.Metric {
|
|
||||||
if l.Name == k && l.Value != v {
|
|
||||||
// Deletion of map entries while iterating over them is safe.
|
|
||||||
// From http://golang.org/ref/spec#For_statements:
|
|
||||||
// "If map entries that have not yet been reached are deleted during
|
|
||||||
// iteration, the corresponding iteration values will not be produced."
|
|
||||||
delete(common, k)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
cnames := []string{}
|
|
||||||
for n := range common {
|
|
||||||
cnames = append(cnames, n)
|
|
||||||
}
|
|
||||||
|
|
||||||
for i := range vec {
|
|
||||||
el := &vec[i]
|
|
||||||
el.Metric = labels.NewBuilder(el.Metric).Del(cnames...).Labels()
|
|
||||||
}
|
|
||||||
return vec
|
|
||||||
}
|
|
||||||
|
|
||||||
// === round(Vector ValueTypeVector, toNearest=1 Scalar) Vector ===
|
// === round(Vector ValueTypeVector, toNearest=1 Scalar) Vector ===
|
||||||
func funcRound(ev *evaluator, args Expressions) Value {
|
func funcRound(ev *evaluator, args Expressions) Value {
|
||||||
// round returns a number rounded to toNearest.
|
// round returns a number rounded to toNearest.
|
||||||
|
@ -405,14 +363,6 @@ func funcScalar(ev *evaluator, args Expressions) Value {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// === count_scalar(Vector ValueTypeVector) float64 ===
|
|
||||||
func funcCountScalar(ev *evaluator, args Expressions) Value {
|
|
||||||
return Scalar{
|
|
||||||
V: float64(len(ev.evalVector(args[0]))),
|
|
||||||
T: ev.Timestamp,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func aggrOverTime(ev *evaluator, args Expressions, aggrFn func([]Point) float64) Value {
|
func aggrOverTime(ev *evaluator, args Expressions, aggrFn func([]Point) float64) Value {
|
||||||
mat := ev.evalMatrix(args[0])
|
mat := ev.evalMatrix(args[0])
|
||||||
resultVector := Vector{}
|
resultVector := Vector{}
|
||||||
|
@ -1052,12 +1002,6 @@ var functions = map[string]*Function{
|
||||||
ReturnType: ValueTypeVector,
|
ReturnType: ValueTypeVector,
|
||||||
Call: funcCountOverTime,
|
Call: funcCountOverTime,
|
||||||
},
|
},
|
||||||
"count_scalar": {
|
|
||||||
Name: "count_scalar",
|
|
||||||
ArgTypes: []ValueType{ValueTypeVector},
|
|
||||||
ReturnType: ValueTypeScalar,
|
|
||||||
Call: funcCountScalar,
|
|
||||||
},
|
|
||||||
"days_in_month": {
|
"days_in_month": {
|
||||||
Name: "days_in_month",
|
Name: "days_in_month",
|
||||||
ArgTypes: []ValueType{ValueTypeVector},
|
ArgTypes: []ValueType{ValueTypeVector},
|
||||||
|
@ -1091,12 +1035,6 @@ var functions = map[string]*Function{
|
||||||
ReturnType: ValueTypeVector,
|
ReturnType: ValueTypeVector,
|
||||||
Call: funcDeriv,
|
Call: funcDeriv,
|
||||||
},
|
},
|
||||||
"drop_common_labels": {
|
|
||||||
Name: "drop_common_labels",
|
|
||||||
ArgTypes: []ValueType{ValueTypeVector},
|
|
||||||
ReturnType: ValueTypeVector,
|
|
||||||
Call: funcDropCommonLabels,
|
|
||||||
},
|
|
||||||
"exp": {
|
"exp": {
|
||||||
Name: "exp",
|
Name: "exp",
|
||||||
ArgTypes: []ValueType{ValueTypeVector},
|
ArgTypes: []ValueType{ValueTypeVector},
|
||||||
|
|
34
promql/testdata/legacy.test
vendored
34
promql/testdata/legacy.test
vendored
|
@ -125,14 +125,6 @@ eval instant at 50m rate(testcounter_zero_cutoff[20m])
|
||||||
{start="5m"} 0.6
|
{start="5m"} 0.6
|
||||||
|
|
||||||
|
|
||||||
# count_scalar for a non-empty vector should return scalar element count.
|
|
||||||
eval instant at 50m count_scalar(http_requests)
|
|
||||||
8
|
|
||||||
|
|
||||||
# count_scalar for an empty vector should return scalar 0.
|
|
||||||
eval instant at 50m count_scalar(nonexistent)
|
|
||||||
0
|
|
||||||
|
|
||||||
eval instant at 50m http_requests{group!="canary"}
|
eval instant at 50m http_requests{group!="canary"}
|
||||||
http_requests{group="production", instance="1", job="app-server"} 600
|
http_requests{group="production", instance="1", job="app-server"} 600
|
||||||
http_requests{group="production", instance="0", job="app-server"} 500
|
http_requests{group="production", instance="0", job="app-server"} 500
|
||||||
|
@ -149,9 +141,6 @@ eval instant at 50m http_requests{job!~"api-.+",group!="canary"}
|
||||||
http_requests{group="production", instance="1", job="app-server"} 600
|
http_requests{group="production", instance="1", job="app-server"} 600
|
||||||
http_requests{group="production", instance="0", job="app-server"} 500
|
http_requests{group="production", instance="0", job="app-server"} 500
|
||||||
|
|
||||||
eval instant at 50m count_scalar(http_requests{job=~"server"})
|
|
||||||
0
|
|
||||||
|
|
||||||
eval instant at 50m http_requests{group="production",job=~"api-.+"}
|
eval instant at 50m http_requests{group="production",job=~"api-.+"}
|
||||||
http_requests{group="production", instance="0", job="api-server"} 100
|
http_requests{group="production", instance="0", job="api-server"} 100
|
||||||
http_requests{group="production", instance="1", job="api-server"} 200
|
http_requests{group="production", instance="1", job="api-server"} 200
|
||||||
|
@ -244,10 +233,6 @@ eval instant at 50m sum_over_time(http_requests{group="production",job="api-serv
|
||||||
eval instant at 50m time()
|
eval instant at 50m time()
|
||||||
3000
|
3000
|
||||||
|
|
||||||
eval instant at 50m drop_common_labels(http_requests{group="production",job="api-server"})
|
|
||||||
http_requests{instance="0"} 100
|
|
||||||
http_requests{instance="1"} 200
|
|
||||||
|
|
||||||
eval instant at 50m {__name__=~".+"}
|
eval instant at 50m {__name__=~".+"}
|
||||||
http_requests{group="canary", instance="0", job="api-server"} 300
|
http_requests{group="canary", instance="0", job="api-server"} 300
|
||||||
http_requests{group="canary", instance="0", job="app-server"} 700
|
http_requests{group="canary", instance="0", job="app-server"} 700
|
||||||
|
@ -283,11 +268,9 @@ eval instant at 50m absent(nonexistent)
|
||||||
eval instant at 50m absent(nonexistent{job="testjob", instance="testinstance", method=~".x"})
|
eval instant at 50m absent(nonexistent{job="testjob", instance="testinstance", method=~".x"})
|
||||||
{instance="testinstance", job="testjob"} 1
|
{instance="testinstance", job="testjob"} 1
|
||||||
|
|
||||||
eval instant at 50m count_scalar(absent(http_requests))
|
eval instant at 50m absent(http_requests)
|
||||||
0
|
|
||||||
|
|
||||||
eval instant at 50m count_scalar(absent(sum(http_requests)))
|
eval instant at 50m absent(sum(http_requests))
|
||||||
0
|
|
||||||
|
|
||||||
eval instant at 50m absent(sum(nonexistent{job="testjob", instance="testinstance"}))
|
eval instant at 50m absent(sum(nonexistent{job="testjob", instance="testinstance"}))
|
||||||
{} 1
|
{} 1
|
||||||
|
@ -370,19 +353,6 @@ eval instant at 50m log10(vector_matching_a - 20)
|
||||||
|
|
||||||
|
|
||||||
# Matrix tests.
|
# Matrix tests.
|
||||||
|
|
||||||
clear
|
|
||||||
load 1h
|
|
||||||
testmetric{testlabel="1"} 1 1
|
|
||||||
testmetric{testlabel="2"} _ 2
|
|
||||||
|
|
||||||
eval instant at 0h drop_common_labels(testmetric)
|
|
||||||
testmetric 1
|
|
||||||
|
|
||||||
eval instant at 1h drop_common_labels(testmetric)
|
|
||||||
testmetric{testlabel="1"} 1
|
|
||||||
testmetric{testlabel="2"} 2
|
|
||||||
|
|
||||||
clear
|
clear
|
||||||
load 1h
|
load 1h
|
||||||
testmetric{testlabel="1"} 1 1
|
testmetric{testlabel="1"} 1 1
|
||||||
|
|
Loading…
Reference in a new issue