LabelNames() for Querier (#455)

* LabelNames() for Querier

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>

* nits

Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>
This commit is contained in:
Ganesh Vernekar 2018-11-16 23:32:24 +05:30 committed by Goutham Veeramachaneni
parent 41b54585d9
commit 7f30395115
3 changed files with 35 additions and 45 deletions

43
db.go
View file

@ -882,49 +882,6 @@ func (db *DB) CleanTombstones() (err error) {
return errors.Wrap(db.reload(), "reload blocks") return errors.Wrap(db.reload(), "reload blocks")
} }
// labelNames returns all the unique label names from the Block Readers.
func labelNames(brs ...BlockReader) (map[string]struct{}, error) {
labelNamesMap := make(map[string]struct{})
for _, br := range brs {
ir, err := br.Index()
if err != nil {
return nil, errors.Wrap(err, "get IndexReader")
}
names, err := ir.LabelNames()
if err != nil {
return nil, errors.Wrap(err, "LabelNames() from IndexReader")
}
for _, name := range names {
labelNamesMap[name] = struct{}{}
}
if err = ir.Close(); err != nil {
return nil, errors.Wrap(err, "close IndexReader")
}
}
return labelNamesMap, nil
}
// LabelNames returns all the unique label names present in the DB in sorted order.
func (db *DB) LabelNames() ([]string, error) {
brs := []BlockReader{db.head}
for _, b := range db.Blocks() {
brs = append(brs, b)
}
labelNamesMap, err := labelNames(brs...)
if err != nil {
return nil, err
}
labelNames := make([]string, 0, len(labelNamesMap))
for name := range labelNamesMap {
labelNames = append(labelNames, name)
}
sort.Strings(labelNames)
return labelNames, nil
}
func isBlockDir(fi os.FileInfo) bool { func isBlockDir(fi os.FileInfo) bool {
if !fi.IsDir() { if !fi.IsDir() {
return false return false

View file

@ -1388,12 +1388,15 @@ func TestDB_LabelNames(t *testing.T) {
} }
// Addings more samples to head with new label names // Addings more samples to head with new label names
// so that we can test db.LabelNames() (the union). // so that we can test (head+disk).LabelNames() (the union).
appendSamples(db, 5, 9, tst.sampleLabels2) appendSamples(db, 5, 9, tst.sampleLabels2)
// Testing DB (union). // Testing DB (union).
labelNames, err = db.LabelNames() q, err := db.Querier(math.MinInt64, math.MaxInt64)
testutil.Ok(t, err) testutil.Ok(t, err)
labelNames, err = q.LabelNames()
testutil.Ok(t, err)
testutil.Ok(t, q.Close())
testutil.Equals(t, tst.exp2, labelNames) testutil.Equals(t, tst.exp2, labelNames)
} }
} }

View file

@ -33,10 +33,14 @@ type Querier interface {
// LabelValues returns all potential values for a label name. // LabelValues returns all potential values for a label name.
LabelValues(string) ([]string, error) LabelValues(string) ([]string, error)
// LabelValuesFor returns all potential values for a label name. // LabelValuesFor returns all potential values for a label name.
// under the constraint of another label. // under the constraint of another label.
LabelValuesFor(string, labels.Label) ([]string, error) LabelValuesFor(string, labels.Label) ([]string, error)
// LabelNames returns all the unique label names present in the block in sorted order.
LabelNames() ([]string, error)
// Close releases the resources of the Querier. // Close releases the resources of the Querier.
Close() error Close() error
} }
@ -60,6 +64,28 @@ func (q *querier) LabelValues(n string) ([]string, error) {
return q.lvals(q.blocks, n) return q.lvals(q.blocks, n)
} }
// LabelNames returns all the unique label names present querier blocks.
func (q *querier) LabelNames() ([]string, error) {
labelNamesMap := make(map[string]struct{})
for _, b := range q.blocks {
names, err := b.LabelNames()
if err != nil {
return nil, errors.Wrap(err, "LabelNames() from Querier")
}
for _, name := range names {
labelNamesMap[name] = struct{}{}
}
}
labelNames := make([]string, 0, len(labelNamesMap))
for name := range labelNamesMap {
labelNames = append(labelNames, name)
}
sort.Strings(labelNames)
return labelNames, nil
}
func (q *querier) lvals(qs []Querier, n string) ([]string, error) { func (q *querier) lvals(qs []Querier, n string) ([]string, error) {
if len(qs) == 0 { if len(qs) == 0 {
return nil, nil return nil, nil
@ -187,6 +213,10 @@ func (q *blockQuerier) LabelValues(name string) ([]string, error) {
return res, nil return res, nil
} }
func (q *blockQuerier) LabelNames() ([]string, error) {
return q.index.LabelNames()
}
func (q *blockQuerier) LabelValuesFor(string, labels.Label) ([]string, error) { func (q *blockQuerier) LabelValuesFor(string, labels.Label) ([]string, error) {
return nil, fmt.Errorf("not implemented") return nil, fmt.Errorf("not implemented")
} }