promql: fix potential panic in the query logger (#6094)

Signed-off-by: Simon Pasquier <spasquie@redhat.com>
This commit is contained in:
Simon Pasquier 2019-10-10 16:09:08 +02:00 committed by Krasi Georgiev
parent 6970f725c9
commit cf3d74ed69
2 changed files with 46 additions and 4 deletions

View file

@ -41,12 +41,14 @@ const (
entrySize int = 1000 entrySize int = 1000
) )
func parseBrokenJson(brokenJson []byte, logger log.Logger) (bool, string) { func parseBrokenJson(brokenJson []byte) (bool, string) {
queries := strings.ReplaceAll(string(brokenJson), "\x00", "") queries := strings.ReplaceAll(string(brokenJson), "\x00", "")
queries = queries[:len(queries)-1] + "]" if len(queries) > 0 {
queries = queries[:len(queries)-1] + "]"
}
// Conditional because of implementation detail: len() = 1 implies file consisted of a single char: '['. // Conditional because of implementation detail: len() = 1 implies file consisted of a single char: '['.
if len(queries) == 1 { if len(queries) <= 1 {
return false, "[]" return false, "[]"
} }
@ -68,7 +70,7 @@ func logUnfinishedQueries(filename string, filesize int, logger log.Logger) {
return return
} }
queriesExist, queries := parseBrokenJson(brokenJson, logger) queriesExist, queries := parseBrokenJson(brokenJson)
if !queriesExist { if !queriesExist {
return return
} }

View file

@ -136,3 +136,43 @@ func TestMMapFile(t *testing.T) {
t.Fatalf("Mmap failed") t.Fatalf("Mmap failed")
} }
} }
func TestParseBrokenJson(t *testing.T) {
for _, tc := range []struct {
b []byte
ok bool
out string
}{
{
b: []byte(""),
},
{
b: []byte("\x00\x00"),
},
{
b: []byte("\x00[\x00"),
},
{
b: []byte("\x00[]\x00"),
ok: true,
out: "[]",
},
{
b: []byte("[\"up == 0\",\"rate(http_requests[2w]\"]\x00\x00\x00"),
ok: true,
out: "[\"up == 0\",\"rate(http_requests[2w]\"]",
},
} {
t.Run("", func(t *testing.T) {
ok, out := parseBrokenJson(tc.b)
if tc.ok != ok {
t.Fatalf("expected %t, got %t", tc.ok, ok)
return
}
if ok && tc.out != out {
t.Fatalf("expected %s, got %s", tc.out, out)
}
})
}
}