Fix edge cases in data extraction for point and interval ops.

pull/84/head
Julius Volz 12 years ago committed by Matt T. Proud
parent a4361e4116
commit e0dbc8c561

@ -104,13 +104,23 @@ func extractValuesAroundTime(t time.Time, in []model.SamplePair) (out []model.Sa
i := sort.Search(len(in), func(i int) bool { i := sort.Search(len(in), func(i int) bool {
return !in[i].Timestamp.Before(t) return !in[i].Timestamp.Before(t)
}) })
switch i { if i == len(in) {
case len(in): // Target time is past the end, return only the last sample.
out = in[len(in)-1:] out = in[len(in)-1:]
case 0: } else {
out = append(out, in[0:1]...) if in[i].Timestamp.Equal(t) && len(in) > i+1 {
default: // We hit exactly the current sample time. Very unlikely in practice.
out = append(out, in[i-1:i+1]...) // Return only the current sample.
out = append(out, in[i])
} else {
if i == 0 {
// We hit before the first sample time. Return only the first sample.
out = append(out, in[0:1]...)
} else {
// We hit between two samples. Return both surrounding samples.
out = append(out, in[i-1:i+1]...)
}
}
} }
return return
} }

Loading…
Cancel
Save