Label name check for 'count_values' (#4585)
Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>
This commit is contained in:
parent
9ee4b05d16
commit
576ee4d309
|
@ -29,6 +29,7 @@ import (
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
opentracing "github.com/opentracing/opentracing-go"
|
opentracing "github.com/opentracing/opentracing-go"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/timestamp"
|
"github.com/prometheus/prometheus/pkg/timestamp"
|
||||||
"github.com/prometheus/prometheus/pkg/value"
|
"github.com/prometheus/prometheus/pkg/value"
|
||||||
|
@ -1494,6 +1495,9 @@ func (ev *evaluator) aggregation(op ItemType, grouping []string, without bool, p
|
||||||
var valueLabel string
|
var valueLabel string
|
||||||
if op == itemCountValues {
|
if op == itemCountValues {
|
||||||
valueLabel = param.(string)
|
valueLabel = param.(string)
|
||||||
|
if !model.LabelName(valueLabel).IsValid() {
|
||||||
|
ev.errorf("invalid label name %q", valueLabel)
|
||||||
|
}
|
||||||
if !without {
|
if !without {
|
||||||
grouping = append(grouping, valueLabel)
|
grouping = append(grouping, valueLabel)
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
|
"github.com/prometheus/prometheus/util/testutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestQueryConcurrency(t *testing.T) {
|
func TestQueryConcurrency(t *testing.T) {
|
||||||
|
@ -267,11 +268,12 @@ load 10s
|
||||||
}
|
}
|
||||||
|
|
||||||
cases := []struct {
|
cases := []struct {
|
||||||
Query string
|
Query string
|
||||||
Result Value
|
Result Value
|
||||||
Start time.Time
|
Start time.Time
|
||||||
End time.Time
|
End time.Time
|
||||||
Interval time.Duration
|
Interval time.Duration
|
||||||
|
ShouldError bool
|
||||||
}{
|
}{
|
||||||
// Instant queries.
|
// Instant queries.
|
||||||
{
|
{
|
||||||
|
@ -326,6 +328,10 @@ load 10s
|
||||||
End: time.Unix(10, 0),
|
End: time.Unix(10, 0),
|
||||||
Interval: 5 * time.Second,
|
Interval: 5 * time.Second,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Query: `count_values("wrong label!", metric)`,
|
||||||
|
ShouldError: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
|
@ -340,6 +346,10 @@ load 10s
|
||||||
t.Fatalf("unexpected error creating query: %q", err)
|
t.Fatalf("unexpected error creating query: %q", err)
|
||||||
}
|
}
|
||||||
res := qry.Exec(test.Context())
|
res := qry.Exec(test.Context())
|
||||||
|
if c.ShouldError {
|
||||||
|
testutil.NotOk(t, res.Err, "expected error for the query %q", c.Query)
|
||||||
|
continue
|
||||||
|
}
|
||||||
if res.Err != nil {
|
if res.Err != nil {
|
||||||
t.Fatalf("unexpected error running query: %q", res.Err)
|
t.Fatalf("unexpected error running query: %q", res.Err)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue