Merge pull request #10267 from roidelapluie/contenttype

Improve content-type error handling
This commit is contained in:
Matthias Loibl 2022-02-14 11:57:09 +01:00 committed by GitHub
commit afdd1357e0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 13 additions and 21 deletions

View file

@ -64,7 +64,7 @@ type Parser interface {
//
// This function always returns a valid parser, but might additionally
// return an error if the content type cannot be parsed.
func New(b []byte, contentType string) (p Parser, warning error) {
func New(b []byte, contentType string) (Parser, error) {
if contentType == "" {
return NewPromParser(b), nil
}

View file

@ -37,62 +37,54 @@ func TestNewParser(t *testing.T) {
for name, tt := range map[string]*struct {
contentType string
validateParser func(*testing.T, Parser)
warning string
err string
}{
"empty-string": {
contentType: "",
validateParser: requirePromParser,
warning: "",
},
"invalid-content-type-1": {
contentType: "invalid/",
validateParser: requirePromParser,
warning: "expected token after slash",
err: "expected token after slash",
},
"invalid-content-type-2": {
contentType: "invalid/invalid/invalid",
validateParser: requirePromParser,
warning: "unexpected content after media subtype",
err: "unexpected content after media subtype",
},
"invalid-content-type-3": {
contentType: "/",
validateParser: requirePromParser,
warning: "no media type",
err: "no media type",
},
"invalid-content-type-4": {
contentType: "application/openmetrics-text; charset=UTF-8; charset=utf-8",
validateParser: requirePromParser,
warning: "duplicate parameter name",
err: "duplicate parameter name",
},
"openmetrics": {
contentType: "application/openmetrics-text",
validateParser: requireOpenMetricsParser,
warning: "",
},
"openmetrics-with-charset": {
contentType: "application/openmetrics-text; charset=utf-8",
validateParser: requireOpenMetricsParser,
warning: "",
},
"openmetrics-with-charset-and-version": {
contentType: "application/openmetrics-text; version=1.0.0; charset=utf-8",
validateParser: requireOpenMetricsParser,
warning: "",
},
"plain-text": {
contentType: "text/plain",
validateParser: requirePromParser,
warning: "",
},
"plain-text-with-version": {
contentType: "text/plain; version=0.0.4",
validateParser: requirePromParser,
warning: "",
},
"some-other-valid-content-type": {
contentType: "text/html",
validateParser: requirePromParser,
warning: "",
},
} {
t.Run(name, func(t *testing.T) {
@ -101,11 +93,11 @@ func TestNewParser(t *testing.T) {
p, err := New([]byte{}, tt.contentType)
tt.validateParser(t, p)
if tt.warning == "" {
if tt.err == "" {
require.NoError(t, err)
} else {
require.Error(t, err)
require.Contains(t, err.Error(), tt.warning)
require.Contains(t, err.Error(), tt.err)
}
})
}

View file

@ -1418,12 +1418,12 @@ type appendErrors struct {
}
func (sl *scrapeLoop) append(app storage.Appender, b []byte, contentType string, ts time.Time) (total, added, seriesAdded int, err error) {
p, warning := textparse.New(b, contentType)
if warning != nil {
p, err := textparse.New(b, contentType)
if err != nil {
level.Debug(sl.l).Log(
"msg", "Invalid content type on scrape, using prometheus parser as fallback",
"content-type", contentType,
"err", warning,
"msg", "Invalid content type on scrape, using prometheus parser as fallback.",
"content_type", contentType,
"err", err,
)
}