add checks for metrics and display duplicate fields (#6026)

Signed-off-by: Harkishen-Singh <harkishensingh@hotmail.com>
pull/6037/head
Harkishen Singh 2019-09-20 15:59:47 +05:30 committed by Brian Brazil
parent 5f6a56a0bb
commit e097c70e6d
1 changed files with 41 additions and 0 deletions

View File

@ -23,6 +23,7 @@ import (
"net/url"
"os"
"path/filepath"
"reflect"
"strconv"
"strings"
"time"
@ -303,9 +304,49 @@ func checkRules(filename string) (int, []error) {
numRules += len(rg.Rules)
}
dRules := checkDuplicates(rgs.Groups)
if len(dRules) != 0 {
fmt.Printf("%d duplicate rules(s) found.\n", len(dRules))
for _, n := range dRules {
fmt.Printf("Metric: %s\nLabel(s):\n", n.metric)
for i, l := range n.label {
fmt.Printf("\t%s: %s\n", i, l)
}
}
fmt.Println("Might cause inconsistency while recording expressions.")
}
return numRules, nil
}
type compareRuleType struct {
metric string
label map[string]string
}
func checkDuplicates(r []rulefmt.RuleGroup) []compareRuleType {
var duplicates []compareRuleType
for rindex := range r {
for index, props := range r[rindex].Rules {
inst := compareRuleType{
metric: props.Record,
label: props.Labels,
}
for i := 0; i < index; i++ {
t := compareRuleType{
metric: r[rindex].Rules[i].Record,
label: r[rindex].Rules[i].Labels,
}
if reflect.DeepEqual(t, inst) {
duplicates = append(duplicates, t)
}
}
}
}
return duplicates
}
var checkMetricsUsage = strings.TrimSpace(`
Pass Prometheus metrics over stdin to lint them for consistency and correctness.