Fixing aggregate queries with no GROUP BY to include the end time
Queries with a time constraint but no group by would not include the final point from the underlying iterator. Fixes #6229.pull/6244/head
parent
e2eb93f6d4
commit
fa5a38dcd4
|
@ -10,6 +10,7 @@
|
||||||
- [#6248](https://github.com/influxdata/influxdb/issues/6248): Panic using incorrectly quoted "queries" field key.
|
- [#6248](https://github.com/influxdata/influxdb/issues/6248): Panic using incorrectly quoted "queries" field key.
|
||||||
- [#6257](https://github.com/influxdata/influxdb/issues/6257): CreateShardGroup was incrementing meta data index even when it was idempotent.
|
- [#6257](https://github.com/influxdata/influxdb/issues/6257): CreateShardGroup was incrementing meta data index even when it was idempotent.
|
||||||
- [#6223](https://github.com/influxdata/influxdb/issues/6223): Failure to start/run on Windows. Thanks @mvadu
|
- [#6223](https://github.com/influxdata/influxdb/issues/6223): Failure to start/run on Windows. Thanks @mvadu
|
||||||
|
- [#6229](https://github.com/influxdata/influxdb/issues/6229): Fixed aggregate queries with no GROUP BY to include the end time.
|
||||||
|
|
||||||
## v0.12.0 [2016-04-05]
|
## v0.12.0 [2016-04-05]
|
||||||
### Release Notes
|
### Release Notes
|
||||||
|
|
|
@ -1711,7 +1711,7 @@ func (itr *floatTransformIterator) Next() *FloatPoint {
|
||||||
// new point if possible.
|
// new point if possible.
|
||||||
type floatTransformFunc func(p *FloatPoint) *FloatPoint
|
type floatTransformFunc func(p *FloatPoint) *FloatPoint
|
||||||
|
|
||||||
// floatReduceIterator executes a function to modify an existing point for every
|
// floatBoolTransformIterator executes a function to modify an existing point for every
|
||||||
// output of the input iterator.
|
// output of the input iterator.
|
||||||
type floatBoolTransformIterator struct {
|
type floatBoolTransformIterator struct {
|
||||||
input FloatIterator
|
input FloatIterator
|
||||||
|
@ -3512,7 +3512,7 @@ func (itr *integerTransformIterator) Next() *IntegerPoint {
|
||||||
// new point if possible.
|
// new point if possible.
|
||||||
type integerTransformFunc func(p *IntegerPoint) *IntegerPoint
|
type integerTransformFunc func(p *IntegerPoint) *IntegerPoint
|
||||||
|
|
||||||
// integerReduceIterator executes a function to modify an existing point for every
|
// integerBoolTransformIterator executes a function to modify an existing point for every
|
||||||
// output of the input iterator.
|
// output of the input iterator.
|
||||||
type integerBoolTransformIterator struct {
|
type integerBoolTransformIterator struct {
|
||||||
input IntegerIterator
|
input IntegerIterator
|
||||||
|
@ -5313,7 +5313,7 @@ func (itr *stringTransformIterator) Next() *StringPoint {
|
||||||
// new point if possible.
|
// new point if possible.
|
||||||
type stringTransformFunc func(p *StringPoint) *StringPoint
|
type stringTransformFunc func(p *StringPoint) *StringPoint
|
||||||
|
|
||||||
// stringReduceIterator executes a function to modify an existing point for every
|
// stringBoolTransformIterator executes a function to modify an existing point for every
|
||||||
// output of the input iterator.
|
// output of the input iterator.
|
||||||
type stringBoolTransformIterator struct {
|
type stringBoolTransformIterator struct {
|
||||||
input StringIterator
|
input StringIterator
|
||||||
|
@ -7114,7 +7114,7 @@ func (itr *booleanTransformIterator) Next() *BooleanPoint {
|
||||||
// new point if possible.
|
// new point if possible.
|
||||||
type booleanTransformFunc func(p *BooleanPoint) *BooleanPoint
|
type booleanTransformFunc func(p *BooleanPoint) *BooleanPoint
|
||||||
|
|
||||||
// booleanReduceIterator executes a function to modify an existing point for every
|
// booleanBoolTransformIterator executes a function to modify an existing point for every
|
||||||
// output of the input iterator.
|
// output of the input iterator.
|
||||||
type booleanBoolTransformIterator struct {
|
type booleanBoolTransformIterator struct {
|
||||||
input BooleanIterator
|
input BooleanIterator
|
||||||
|
|
|
@ -1047,7 +1047,7 @@ func (itr *{{$k.name}}TransformIterator) Next() *{{$k.Name}}Point {
|
||||||
// new point if possible.
|
// new point if possible.
|
||||||
type {{$k.name}}TransformFunc func(p *{{$k.Name}}Point) *{{$k.Name}}Point
|
type {{$k.name}}TransformFunc func(p *{{$k.Name}}Point) *{{$k.Name}}Point
|
||||||
|
|
||||||
// {{$k.name}}ReduceIterator executes a function to modify an existing point for every
|
// {{$k.name}}BoolTransformIterator executes a function to modify an existing point for every
|
||||||
// output of the input iterator.
|
// output of the input iterator.
|
||||||
type {{$k.name}}BoolTransformIterator struct {
|
type {{$k.name}}BoolTransformIterator struct {
|
||||||
input {{$k.Name}}Iterator
|
input {{$k.Name}}Iterator
|
||||||
|
|
|
@ -726,7 +726,7 @@ func (opt IteratorOptions) SeekTime() int64 {
|
||||||
// Window returns the time window [start,end) that t falls within.
|
// Window returns the time window [start,end) that t falls within.
|
||||||
func (opt IteratorOptions) Window(t int64) (start, end int64) {
|
func (opt IteratorOptions) Window(t int64) (start, end int64) {
|
||||||
if opt.Interval.IsZero() {
|
if opt.Interval.IsZero() {
|
||||||
return opt.StartTime, opt.EndTime
|
return opt.StartTime, opt.EndTime + 1
|
||||||
}
|
}
|
||||||
|
|
||||||
// Subtract the offset to the time so we calculate the correct base interval.
|
// Subtract the offset to the time so we calculate the correct base interval.
|
||||||
|
|
|
@ -772,8 +772,8 @@ func TestIteratorOptions_Window_Default(t *testing.T) {
|
||||||
if start != 0 {
|
if start != 0 {
|
||||||
t.Errorf("expected start to be 0, got %d", start)
|
t.Errorf("expected start to be 0, got %d", start)
|
||||||
}
|
}
|
||||||
if end != 60 {
|
if end != 61 {
|
||||||
t.Errorf("expected end to be 60, got %d", end)
|
t.Errorf("expected end to be 61, got %d", end)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue