Skip to content

Commit c018a49

Browse files
committed
fix(blooms): Check length of tasks before accessing first element in slice (#14634)
This PR adds a length check for the partitioned series before accessing the first element of the resulting slice. Signed-off-by: Christian Haudum <[email protected]>
1 parent 8e67b52 commit c018a49

File tree

1 file changed

+10
-6
lines changed

1 file changed

+10
-6
lines changed

pkg/bloomgateway/bloomgateway.go

+10-6
Original file line numberDiff line numberDiff line change
@@ -200,9 +200,7 @@ func (g *Gateway) FilterChunkRefs(ctx context.Context, req *logproto.FilterChunk
200200
// Shortcut if request does not contain filters
201201
if len(matchers) == 0 {
202202
stats.Status = labelSuccess
203-
return &logproto.FilterChunkRefResponse{
204-
ChunkRefs: req.Refs,
205-
}, nil
203+
return &logproto.FilterChunkRefResponse{ChunkRefs: req.Refs}, nil
206204
}
207205

208206
blocks := make([]bloomshipper.BlockRef, 0, len(req.Blocks))
@@ -218,9 +216,7 @@ func (g *Gateway) FilterChunkRefs(ctx context.Context, req *logproto.FilterChunk
218216
// Shortcut if request does not contain blocks
219217
if len(blocks) == 0 {
220218
stats.Status = labelSuccess
221-
return &logproto.FilterChunkRefResponse{
222-
ChunkRefs: req.Refs,
223-
}, nil
219+
return &logproto.FilterChunkRefResponse{ChunkRefs: req.Refs}, nil
224220
}
225221

226222
seriesByDay := partitionRequest(req)
@@ -233,6 +229,14 @@ func (g *Gateway) FilterChunkRefs(ctx context.Context, req *logproto.FilterChunk
233229
"series_requested", len(req.Refs),
234230
)
235231

232+
// len(seriesByDay) should never be 0
233+
// Not sure how this can happen, but there was a bug report
234+
// https://github.com/grafana/loki/issues/14623
235+
if len(seriesByDay) == 0 {
236+
stats.Status = labelSuccess
237+
return &logproto.FilterChunkRefResponse{ChunkRefs: req.Refs}, nil
238+
}
239+
236240
if len(seriesByDay) > 1 {
237241
stats.Status = labelFailure
238242
return nil, errors.New("request time range must span exactly one day")

0 commit comments

Comments
 (0)