cleanup and fix tests

Signed-off-by: Owen Williams <owen.williams@grafana.com>
This commit is contained in:
Owen Williams 2023-12-08 11:03:17 -05:00
parent a64e10ef3a
commit d8f92a1c95
4 changed files with 47 additions and 49 deletions

View file

@ -227,12 +227,11 @@ func (p *OpenMetricsParser) nextToken() token {
} }
func (p *OpenMetricsParser) parseError(exp string, got token) error { func (p *OpenMetricsParser) parseError(exp string, got token) error {
e := p.l.i + 80 e := p.l.i + 1
if len(p.l.b) < e { if len(p.l.b) < e {
e = len(p.l.b) e = len(p.l.b)
} }
start := int(math.Max(0, float64(p.start-80))) return fmt.Errorf("%s, got %q (%q) while parsing: %q", exp, p.l.b[p.l.start:e], got, p.l.b[p.start:e])
return fmt.Errorf("%s, got %q (%q) while parsing: %q", exp, p.l.b[p.l.start:e], got, p.l.b[start:e])
} }
// Next advances the parser to the next sample. It returns false if no // Next advances the parser to the next sample. It returns false if no
@ -256,7 +255,6 @@ func (p *OpenMetricsParser) Next() (Entry, error) {
case tEOF: case tEOF:
return EntryInvalid, errors.New("data does not end with # EOF") return EntryInvalid, errors.New("data does not end with # EOF")
case tHelp, tType, tUnit: case tHelp, tType, tUnit:
tStart := p.l.start
switch t2 := p.nextToken(); t2 { switch t2 := p.nextToken(); t2 {
case tMName: case tMName:
mStart := p.l.start mStart := p.l.start
@ -267,7 +265,7 @@ func (p *OpenMetricsParser) Next() (Entry, error) {
} }
p.offsets = append(p.offsets, mStart, mEnd) p.offsets = append(p.offsets, mStart, mEnd)
default: default:
return EntryInvalid, p.parseError("expected metric name after "+t.String()+" "+string(p.l.b), t2) return EntryInvalid, p.parseError("expected metric name after "+t.String(), t2)
} }
switch t2 := p.nextToken(); t2 { switch t2 := p.nextToken(); t2 {
case tText: case tText:
@ -277,11 +275,7 @@ func (p *OpenMetricsParser) Next() (Entry, error) {
p.text = []byte{} p.text = []byte{}
} }
default: default:
end := tStart + 40 return EntryInvalid, fmt.Errorf("expected text in %s", t.String())
if end >= len(p.l.b) {
end = len(p.l.b) - 1
}
return EntryInvalid, fmt.Errorf("expected text in %s: got %v (%v)", t.String(), t2.String(), string(p.l.b[tStart:end]))
} }
switch t { switch t {
case tType: case tType:
@ -469,6 +463,10 @@ func (p *OpenMetricsParser) parseLVals(offsets []int) ([]int, error) {
// parseMetricSuffix parses the end of the line after the metric name and // parseMetricSuffix parses the end of the line after the metric name and
// labels. It starts parsing with the provided token. // labels. It starts parsing with the provided token.
func (p *OpenMetricsParser) parseMetricSuffix(t token) (Entry, error) { func (p *OpenMetricsParser) parseMetricSuffix(t token) (Entry, error) {
if p.offsets[0] == -1 {
return EntryInvalid, fmt.Errorf("metric name not set while parsing: %q", p.l.b[p.start:p.l.i])
}
var err error var err error
p.val, err = p.getFloatValue(t, "metric") p.val, err = p.getFloatValue(t, "metric")
if err != nil { if err != nil {

View file

@ -467,19 +467,19 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "a\n#EOF\n", input: "a\n#EOF\n",
err: "expected value after metric, got \"\\n#EOF\\n\" (\"INVALID\") while parsing: \"a\\n#EOF\\n\"", err: "expected value after metric, got \"\\n\" (\"INVALID\") while parsing: \"a\\n\"",
}, },
{ {
input: "\n\n#EOF\n", input: "\n\n#EOF\n",
err: "expected a valid start token, got \"\\n\\n#EOF\\n\" (\"INVALID\") while parsing: \"\\n\\n#EOF\\n\"", err: "expected a valid start token, got \"\\n\" (\"INVALID\") while parsing: \"\\n\"",
}, },
{ {
input: " a 1\n#EOF\n", input: " a 1\n#EOF\n",
err: "expected a valid start token, got \" a 1\\n#EOF\\n\" (\"INVALID\") while parsing: \" a 1\\n#EOF\\n\"", err: "expected a valid start token, got \" \" (\"INVALID\") while parsing: \" \"",
}, },
{ {
input: "9\n#EOF\n", input: "9\n#EOF\n",
err: "expected a valid start token, got \"9\\n#EOF\\n\" (\"INVALID\") while parsing: \"9\\n#EOF\\n\"", err: "expected a valid start token, got \"9\" (\"INVALID\") while parsing: \"9\"",
}, },
{ {
input: "# TYPE u untyped\n#EOF\n", input: "# TYPE u untyped\n#EOF\n",
@ -491,15 +491,15 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "# TYPE c counter\n#EOF\n", input: "# TYPE c counter\n#EOF\n",
err: "expected a valid start token, got \"# TYPE c counter\\n#EOF\\n\" (\"INVALID\") while parsing: \"# TYPE c counter\\n#EOF\\n\"", err: "expected a valid start token, got \"# \" (\"INVALID\") while parsing: \"# \"",
}, },
{ {
input: "# TYPE \n#EOF\n", input: "# TYPE \n#EOF\n",
err: "expected metric name after TYPE # TYPE \n#EOF\n, got \"\\n#EOF\\n\" (\"INVALID\") while parsing: \"# TYPE \\n#EOF\\n\"", err: "expected metric name after TYPE, got \"\\n\" (\"INVALID\") while parsing: \"# TYPE \\n\"",
}, },
{ {
input: "# TYPE m\n#EOF\n", input: "# TYPE m\n#EOF\n",
err: "expected text in TYPE: got INVALID (# TYPE m\n#EOF)", err: "expected text in TYPE",
}, },
{ {
input: "# UNIT metric suffix\n#EOF\n", input: "# UNIT metric suffix\n#EOF\n",
@ -515,23 +515,23 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "# UNIT \n#EOF\n", input: "# UNIT \n#EOF\n",
err: "expected metric name after UNIT # UNIT \n#EOF\n, got \"\\n#EOF\\n\" (\"INVALID\") while parsing: \"# UNIT \\n#EOF\\n\"", err: "expected metric name after UNIT, got \"\\n\" (\"INVALID\") while parsing: \"# UNIT \\n\"",
}, },
{ {
input: "# UNIT m\n#EOF\n", input: "# UNIT m\n#EOF\n",
err: "expected text in UNIT: got INVALID (# UNIT m\n#EOF)", err: "expected text in UNIT",
}, },
{ {
input: "# HELP \n#EOF\n", input: "# HELP \n#EOF\n",
err: "expected metric name after HELP # HELP \n#EOF\n, got \"\\n#EOF\\n\" (\"INVALID\") while parsing: \"# HELP \\n#EOF\\n\"", err: "expected metric name after HELP, got \"\\n\" (\"INVALID\") while parsing: \"# HELP \\n\"",
}, },
{ {
input: "# HELP m\n#EOF\n", input: "# HELP m\n#EOF\n",
err: "expected text in HELP: got INVALID (# HELP m\n#EOF)", err: "expected text in HELP",
}, },
{ {
input: "a\t1\n#EOF\n", input: "a\t1\n#EOF\n",
err: "expected value after metric, got \"\\t1\\n#EOF\\n\" (\"INVALID\") while parsing: \"a\\t1\\n#EOF\\n\"", err: "expected value after metric, got \"\\t\" (\"INVALID\") while parsing: \"a\\t\"",
}, },
{ {
input: "a 1\t2\n#EOF\n", input: "a 1\t2\n#EOF\n",
@ -539,11 +539,11 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "a 1 2 \n#EOF\n", input: "a 1 2 \n#EOF\n",
err: "expected next entry after timestamp, got \" \\n#EOF\\n\" (\"INVALID\") while parsing: \"a 1 2 \\n#EOF\\n\"", err: "expected next entry after timestamp, got \" \\n\" (\"INVALID\") while parsing: \"a 1 2 \\n\"",
}, },
{ {
input: "a 1 2 #\n#EOF\n", input: "a 1 2 #\n#EOF\n",
err: "expected next entry after timestamp, got \" #\\n#EOF\\n\" (\"TIMESTAMP\") while parsing: \"a 1 2 #\\n#EOF\\n\"", err: "expected next entry after timestamp, got \" #\\n\" (\"TIMESTAMP\") while parsing: \"a 1 2 #\\n\"",
}, },
{ {
input: "a 1 1z\n#EOF\n", input: "a 1 1z\n#EOF\n",
@ -551,7 +551,7 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: " # EOF\n", input: " # EOF\n",
err: "expected a valid start token, got \" # EOF\\n\" (\"INVALID\") while parsing: \" # EOF\\n\"", err: "expected a valid start token, got \" \" (\"INVALID\") while parsing: \" \"",
}, },
{ {
input: "# EOF\na 1", input: "# EOF\na 1",
@ -567,7 +567,7 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "#\tTYPE c counter\n", input: "#\tTYPE c counter\n",
err: "expected a valid start token, got \"#\\tTYPE c counter\\n\" (\"INVALID\") while parsing: \"#\\tTYPE c counter\\n\"", err: "expected a valid start token, got \"#\\t\" (\"INVALID\") while parsing: \"#\\t\"",
}, },
{ {
input: "# TYPE c counter\n", input: "# TYPE c counter\n",
@ -575,31 +575,31 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "a 1 1 1\n# EOF\n", input: "a 1 1 1\n# EOF\n",
err: "expected next entry after timestamp, got \" 1\\n# EOF\\n\" (\"TIMESTAMP\") while parsing: \"a 1 1 1\\n# EOF\\n\"", err: "expected next entry after timestamp, got \" 1\\n\" (\"TIMESTAMP\") while parsing: \"a 1 1 1\\n\"",
}, },
{ {
input: "a{b='c'} 1\n# EOF\n", input: "a{b='c'} 1\n# EOF\n",
err: "expected label value, got \"'c'} 1\\n# EOF\\n\" (\"INVALID\") while parsing: \"a{b='c'} 1\\n# EOF\\n\"", err: "expected label value, got \"'\" (\"INVALID\") while parsing: \"a{b='\"",
}, },
{ {
input: "a{,b=\"c\"} 1\n# EOF\n", input: "a{,b=\"c\"} 1\n# EOF\n",
err: "expected label name, got \",b=\\\"c\\\"} 1\\n# EOF\\n\" (\"COMMA\") while parsing: \"a{,b=\\\"c\\\"} 1\\n# EOF\\n\"", err: "expected label name, got \",b\" (\"COMMA\") while parsing: \"a{,b\"",
}, },
{ {
input: "a{b=\"c\"d=\"e\"} 1\n# EOF\n", input: "a{b=\"c\"d=\"e\"} 1\n# EOF\n",
err: "expected comma or brace close, got \"d=\\\"e\\\"} 1\\n# EOF\\n\" (\"LNAME\") while parsing: \"a{b=\\\"c\\\"d=\\\"e\\\"} 1\\n# EOF\\n\"", err: "expected comma or brace close, got \"d=\" (\"LNAME\") while parsing: \"a{b=\\\"c\\\"d=\"",
}, },
{ {
input: "a{b=\"c\",,d=\"e\"} 1\n# EOF\n", input: "a{b=\"c\",,d=\"e\"} 1\n# EOF\n",
err: "expected label name, got \",d=\\\"e\\\"} 1\\n# EOF\\n\" (\"COMMA\") while parsing: \"a{b=\\\"c\\\",,d=\\\"e\\\"} 1\\n# EOF\\n\"", err: "expected label name, got \",d\" (\"COMMA\") while parsing: \"a{b=\\\"c\\\",,d\"",
}, },
{ {
input: "a{b=\n# EOF\n", input: "a{b=\n# EOF\n",
err: "expected label value, got \"\\n# EOF\\n\" (\"INVALID\") while parsing: \"a{b=\\n# EOF\\n\"", err: "expected label value, got \"\\n\" (\"INVALID\") while parsing: \"a{b=\\n\"",
}, },
{ {
input: "a{\xff=\"foo\"} 1\n# EOF\n", input: "a{\xff=\"foo\"} 1\n# EOF\n",
err: "expected label name, got \"\\xff=\\\"foo\\\"} 1\\n# EOF\\n\" (\"INVALID\") while parsing: \"a{\\xff=\\\"foo\\\"} 1\\n# EOF\\n\"", err: "expected label name, got \"\\xff\" (\"INVALID\") while parsing: \"a{\\xff\"",
}, },
{ {
input: "a{b=\"\xff\"} 1\n# EOF\n", input: "a{b=\"\xff\"} 1\n# EOF\n",
@ -611,11 +611,11 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "something_weird{problem=\"\n# EOF\n", input: "something_weird{problem=\"\n# EOF\n",
err: "expected label value, got \"\\\"\\n# EOF\\n\" (\"INVALID\") while parsing: \"something_weird{problem=\\\"\\n# EOF\\n\"", err: "expected label value, got \"\\\"\\n\" (\"INVALID\") while parsing: \"something_weird{problem=\\\"\\n\"",
}, },
{ {
input: "empty_label_name{=\"\"} 0\n# EOF\n", input: "empty_label_name{=\"\"} 0\n# EOF\n",
err: "expected label name, got \"=\\\"\\\"} 0\\n# EOF\\n\" (\"EQUAL\") while parsing: \"empty_label_name{=\\\"\\\"} 0\\n# EOF\\n\"", err: "expected label name, got \"=\\\"\" (\"EQUAL\") while parsing: \"empty_label_name{=\\\"\"",
}, },
{ {
input: "foo 1_2\n\n# EOF\n", input: "foo 1_2\n\n# EOF\n",
@ -635,11 +635,11 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: "custom_metric_total 1 # {aa=bb}\n# EOF\n", input: "custom_metric_total 1 # {aa=bb}\n# EOF\n",
err: "expected label value, got \"bb}\\n# EOF\\n\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {aa=bb}\\n# EOF\\n\"", err: "expected label value, got \"b\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {aa=b\"",
}, },
{ {
input: "custom_metric_total 1 # {aa=\"bb\"}\n# EOF\n", input: "custom_metric_total 1 # {aa=\"bb\"}\n# EOF\n",
err: "expected value after exemplar labels, got \"\\n# EOF\\n\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {aa=\\\"bb\\\"}\\n# EOF\\n\"", err: "expected value after exemplar labels, got \"\\n\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {aa=\\\"bb\\\"}\\n\"",
}, },
{ {
input: `custom_metric_total 1 # {aa="bb"}`, input: `custom_metric_total 1 # {aa="bb"}`,
@ -647,7 +647,7 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: `custom_metric_total 1 # {aa="bb",,cc="dd"} 1`, input: `custom_metric_total 1 # {aa="bb",,cc="dd"} 1`,
err: "expected label name, got \",cc=\\\"dd\\\"} 1\" (\"COMMA\") while parsing: \"custom_metric_total 1 # {aa=\\\"bb\\\",,cc=\\\"dd\\\"} 1\"", err: "expected label name, got \",c\" (\"COMMA\") while parsing: \"custom_metric_total 1 # {aa=\\\"bb\\\",,c\"",
}, },
{ {
input: `custom_metric_total 1 # {aa="bb"} 1_2`, input: `custom_metric_total 1 # {aa="bb"} 1_2`,
@ -667,11 +667,11 @@ func TestOpenMetricsParseErrors(t *testing.T) {
}, },
{ {
input: `custom_metric_total 1 # {aa=\"\xff\"} 9.0`, input: `custom_metric_total 1 # {aa=\"\xff\"} 9.0`,
err: "expected label value, got \"\\\\\\\"\\\\xff\\\\\\\"} 9.0\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {aa=\\\\\\\"\\\\xff\\\\\\\"} 9.0\"", err: "expected label value, got \"\\\\\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {aa=\\\\\"",
}, },
{ {
input: `{b="c",} 1`, input: `{b="c",} 1`,
err: "data does not end with # EOF", err: "metric name not set while parsing: \"{b=\\\"c\\\",} 1\"",
}, },
{ {
input: `a 1 NaN`, input: `a 1 NaN`,
@ -732,7 +732,7 @@ func TestOMNullByteHandling(t *testing.T) {
}, },
{ {
input: "a{b=\x00\"ssss\"} 1\n# EOF\n", input: "a{b=\x00\"ssss\"} 1\n# EOF\n",
err: "expected label value, got \"\\x00\\\"ssss\\\"} 1\\n# EOF\\n\" (\"INVALID\") while parsing: \"a{b=\\x00\\\"ssss\\\"} 1\\n# EOF\\n\"", err: "expected label value, got \"\\x00\" (\"INVALID\") while parsing: \"a{b=\\x00\"",
}, },
{ {
input: "a{b=\"\x00", input: "a{b=\"\x00",
@ -740,11 +740,11 @@ func TestOMNullByteHandling(t *testing.T) {
}, },
{ {
input: "a{b\x00=\"hiih\"} 1", input: "a{b\x00=\"hiih\"} 1",
err: "expected equal, got \"\\x00=\\\"hiih\\\"}\\t1\" (\"INVALID\") while parsing: \"a{b\\x00=\\\"hiih\\\"}\\t1\"", err: "expected equal, got \"\\x00\" (\"INVALID\") while parsing: \"a{b\\x00\"",
}, },
{ {
input: "a\x00{b=\"ddd\"} 1", input: "a\x00{b=\"ddd\"} 1",
err: "expected value after metric, got \"\\x00{b=\\\"ddd\\\"} 1\" (\"INVALID\") while parsing: \"a\\x00{b=\\\"ddd\\\"} 1\"", err: "expected value after metric, got \"\\x00\" (\"INVALID\") while parsing: \"a\\x00\"",
}, },
{ {
input: "#", input: "#",
@ -756,11 +756,11 @@ func TestOMNullByteHandling(t *testing.T) {
}, },
{ {
input: "custom_metric_total 1 # {b=\x00\"ssss\"} 1\n", input: "custom_metric_total 1 # {b=\x00\"ssss\"} 1\n",
err: "expected label value, got \"\\x00\\\"ssss\\\"} 1\\n\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {b=\\x00\\\"ssss\\\"} 1\\n\"", err: "expected label value, got \"\\x00\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {b=\\x00\"",
}, },
{ {
input: "custom_metric_total 1 # {b=\"\x00ss\"} 1\n", input: "custom_metric_total 1 # {b=\"\x00ss\"} 1\n",
err: "expected label value, got \"\\\"\\x00ss\\\"} 1\\n\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {b=\\\"\\x00ss\\\"} 1\\n\"", err: "expected label value, got \"\\\"\\x00\" (\"INVALID\") while parsing: \"custom_metric_total 1 # {b=\\\"\\x00\"",
}, },
} }

View file

@ -455,6 +455,9 @@ func (p *PromParser) parseLVals() error {
// parseMetricSuffix parses the end of the line after the metric name and // parseMetricSuffix parses the end of the line after the metric name and
// labels. It starts parsing with the provided token. // labels. It starts parsing with the provided token.
func (p *PromParser) parseMetricSuffix(t token) (Entry, error) { func (p *PromParser) parseMetricSuffix(t token) (Entry, error) {
if p.offsets[0] == -1 {
return EntryInvalid, fmt.Errorf("metric name not set while parsing: %q", p.l.b[p.start:p.l.i])
}
if t != tValue { if t != tValue {
return EntryInvalid, p.parseError("expected value after metric", t) return EntryInvalid, p.parseError("expected value after metric", t)
} }
@ -482,9 +485,6 @@ func (p *PromParser) parseMetricSuffix(t token) (Entry, error) {
return EntryInvalid, p.parseError("expected timestamp or new record", t) return EntryInvalid, p.parseError("expected timestamp or new record", t)
} }
if p.offsets[0] == -1 {
return EntryInvalid, fmt.Errorf("metric name not set while parsing: %q", p.l.b[p.start:p.l.i])
}
return EntrySeries, nil return EntrySeries, nil
} }

View file

@ -392,7 +392,7 @@ func TestPromParseErrors(t *testing.T) {
}, },
{ {
input: `{a="ok"} 1`, input: `{a="ok"} 1`,
err: "metric name not set while parsing: \"{a=\\\"ok\\\"} 1\\n\"", err: "metric name not set while parsing: \"{a=\\\"ok\\\"} 1\"",
}, },
{ {
input: "# TYPE #\n#EOF\n", input: "# TYPE #\n#EOF\n",