Skip to content

Commit

Permalink
expose ParsePrometheusResults function for external usage
Browse files Browse the repository at this point in the history
original work here #259,
re-implemented it to be idiomatic simpler API.
  • Loading branch information
harshavardhana committed Jan 19, 2024
1 parent f8019d2 commit c0303b5
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 19 deletions.
32 changes: 14 additions & 18 deletions prometheus_metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,11 @@ package madmin

import (
"context"
"fmt"
"io"
"net/http"

dto "github.com/prometheus/client_model/go"
"github.com/prometheus/common/expfmt"
"github.com/prometheus/prom2json"
)

Expand Down Expand Up @@ -71,26 +72,21 @@ func (client *MetricsClient) fetchMetrics(ctx context.Context, subSystem string)
return nil, httpRespToErrorResponse(resp)
}

return parsePrometheusResults(io.LimitReader(resp.Body, metricsRespBodyLimit))
return ParsePrometheusResults(io.LimitReader(resp.Body, metricsRespBodyLimit))
}

func parsePrometheusResults(reader io.Reader) (results []*prom2json.Family, err error) {
mfChan := make(chan *dto.MetricFamily)
errChan := make(chan error)

go func() {
defer close(errChan)
err = prom2json.ParseReader(reader, mfChan)
if err != nil {
errChan <- err
}
}()

for mf := range mfChan {
results = append(results, prom2json.NewFamily(mf))
func ParsePrometheusResults(reader io.Reader) (results []*prom2json.Family, err error) {
// We could do further content-type checks here, but the
// fallback for now will anyway be the text format
// version 0.0.4, so just go for it and see if it works.
var parser expfmt.TextParser
metricFamilies, err := parser.TextToMetricFamilies(reader)
if err != nil {
return nil, fmt.Errorf("reading text format failed: %v", err)
}
if err := <-errChan; err != nil {
return nil, err
results = make([]*prom2json.Family, 0, len(metricFamilies))
for _, mf := range metricFamilies {
results = append(results, prom2json.NewFamily(mf))
}
return results, nil
}
2 changes: 1 addition & 1 deletion prometheus_metrics_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ func TestParsePrometheusResultsReturnsPrometheusObjectsFromStringReader(t *testi
go_gc_duration_seconds_count 397
`
myReader := strings.NewReader(prometheusResults)
results, err := parsePrometheusResults(myReader)
results, err := ParsePrometheusResults(myReader)
if err != nil {
t.Errorf("error not expected, got: %v", err)
}
Expand Down

0 comments on commit c0303b5

Please sign in to comment.