2018-08-22 13:08:52 +03:00
|
|
|
// Copyright 2018 The Prometheus Authors
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2017-08-19 23:57:48 +03:00
|
|
|
package prometheus
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2023-09-21 12:46:54 +03:00
|
|
|
"time"
|
|
|
|
|
|
|
|
dto "github.com/prometheus/client_model/go"
|
|
|
|
"google.golang.org/protobuf/types/known/timestamppb"
|
2017-08-19 23:57:48 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewConstMetricInvalidLabelValues(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
desc string
|
|
|
|
labels Labels
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "non utf8 label value",
|
|
|
|
labels: Labels{"a": "\xFF"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "not enough label values",
|
|
|
|
labels: Labels{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "too many label values",
|
|
|
|
labels: Labels{"a": "1", "b": "2"},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range testCases {
|
2017-08-20 01:53:55 +03:00
|
|
|
metricDesc := NewDesc(
|
|
|
|
"sample_value",
|
|
|
|
"sample value",
|
|
|
|
[]string{"a"},
|
|
|
|
Labels{},
|
|
|
|
)
|
2017-08-19 23:57:48 +03:00
|
|
|
|
2017-08-20 01:53:55 +03:00
|
|
|
expectPanic(t, func() {
|
|
|
|
MustNewConstMetric(metricDesc, CounterValue, 0.3, "\xFF")
|
2024-11-08 11:54:31 +03:00
|
|
|
}, "WithLabelValues: expected panic because: "+test.desc)
|
2017-08-19 23:57:48 +03:00
|
|
|
|
2017-08-20 01:53:55 +03:00
|
|
|
if _, err := NewConstMetric(metricDesc, CounterValue, 0.3, "\xFF"); err == nil {
|
|
|
|
t.Errorf("NewConstMetric: expected error because: %s", test.desc)
|
|
|
|
}
|
2017-08-19 23:57:48 +03:00
|
|
|
}
|
|
|
|
}
|
2023-09-21 12:46:54 +03:00
|
|
|
|
|
|
|
func TestNewConstMetricWithCreatedTimestamp(t *testing.T) {
|
|
|
|
now := time.Now()
|
|
|
|
|
|
|
|
for _, tcase := range []struct {
|
|
|
|
desc string
|
|
|
|
metricType ValueType
|
|
|
|
createdTimestamp time.Time
|
|
|
|
expecErr bool
|
|
|
|
expectedCt *timestamppb.Timestamp
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
desc: "gauge with CT",
|
|
|
|
metricType: GaugeValue,
|
|
|
|
createdTimestamp: now,
|
|
|
|
expecErr: true,
|
|
|
|
expectedCt: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "counter with CT",
|
|
|
|
metricType: CounterValue,
|
|
|
|
createdTimestamp: now,
|
|
|
|
expecErr: false,
|
|
|
|
expectedCt: timestamppb.New(now),
|
|
|
|
},
|
|
|
|
} {
|
|
|
|
t.Run(tcase.desc, func(t *testing.T) {
|
|
|
|
metricDesc := NewDesc(
|
|
|
|
"sample_value",
|
|
|
|
"sample value",
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
)
|
|
|
|
m, err := NewConstMetricWithCreatedTimestamp(metricDesc, tcase.metricType, float64(1), tcase.createdTimestamp)
|
|
|
|
if tcase.expecErr && err == nil {
|
|
|
|
t.Errorf("Expected error is test %s, got no err", tcase.desc)
|
|
|
|
}
|
|
|
|
if !tcase.expecErr && err != nil {
|
|
|
|
t.Errorf("Didn't expect error in test %s, got %s", tcase.desc, err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
if tcase.expectedCt != nil {
|
|
|
|
var metric dto.Metric
|
|
|
|
m.Write(&metric)
|
|
|
|
if metric.Counter.CreatedTimestamp.AsTime() != tcase.expectedCt.AsTime() {
|
|
|
|
t.Errorf("Expected timestamp %v, got %v", tcase.expectedCt, &metric.Counter.CreatedTimestamp)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|