parent
d33f1d4bd8
commit
0f4ca09e54
|
@ -153,14 +153,13 @@ public abstract class TimeZoneRounding extends Rounding {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public long roundKey(long utcMillis) {
|
public long roundKey(long utcMillis) {
|
||||||
long time = utcMillis + preTz.getOffset(utcMillis);
|
long offset = preTz.getOffset(utcMillis);
|
||||||
return field.roundFloor(time);
|
long time = utcMillis + offset;
|
||||||
|
return field.roundFloor(time) - offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public long valueForKey(long time) {
|
public long valueForKey(long time) {
|
||||||
// now, time is still in local, move it to UTC (or the adjustLargeInterval flag is set)
|
|
||||||
time = time - preTz.getOffset(time);
|
|
||||||
// now apply post Tz
|
// now apply post Tz
|
||||||
time = time + postTz.getOffset(time);
|
time = time + postTz.getOffset(time);
|
||||||
return time;
|
return time;
|
||||||
|
|
|
@ -84,6 +84,45 @@ public class TimeZoneRoundingTests extends ElasticsearchTestCase {
|
||||||
assertThat(tzRounding.nextRoundingValue(time("2009-02-03T01:00:00", DateTimeZone.forOffsetHours(+2))), equalTo(time("2009-02-03T02:00:00", DateTimeZone.forOffsetHours(+2))));
|
assertThat(tzRounding.nextRoundingValue(time("2009-02-03T01:00:00", DateTimeZone.forOffsetHours(+2))), equalTo(time("2009-02-03T02:00:00", DateTimeZone.forOffsetHours(+2))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTimeTimeZoneRoundingDST() {
|
||||||
|
Rounding tzRounding;
|
||||||
|
// testing savings to non savings switch
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("UTC")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-10-26T01:01:01", DateTimeZone.forID("CET"))), equalTo(time("2014-10-26T01:00:00", DateTimeZone.forID("CET"))));
|
||||||
|
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("CET")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-10-26T01:01:01", DateTimeZone.forID("CET"))), equalTo(time("2014-10-26T01:00:00", DateTimeZone.forID("CET"))));
|
||||||
|
|
||||||
|
// testing non savings to savings switch
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("UTC")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-03-30T01:01:01", DateTimeZone.forID("CET"))), equalTo(time("2014-03-30T01:00:00", DateTimeZone.forID("CET"))));
|
||||||
|
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("CET")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-03-30T01:01:01", DateTimeZone.forID("CET"))), equalTo(time("2014-03-30T01:00:00", DateTimeZone.forID("CET"))));
|
||||||
|
|
||||||
|
// testing non savings to savings switch (America/Chicago)
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("UTC")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-03-09T03:01:01", DateTimeZone.forID("America/Chicago"))), equalTo(time("2014-03-09T03:00:00", DateTimeZone.forID("America/Chicago"))));
|
||||||
|
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("America/Chicago")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-03-09T03:01:01", DateTimeZone.forID("America/Chicago"))), equalTo(time("2014-03-09T03:00:00", DateTimeZone.forID("America/Chicago"))));
|
||||||
|
|
||||||
|
// testing savings to non savings switch 2013 (America/Chicago)
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("UTC")).build();
|
||||||
|
assertThat(tzRounding.round(time("2013-11-03T06:01:01", DateTimeZone.forID("America/Chicago"))), equalTo(time("2013-11-03T06:00:00", DateTimeZone.forID("America/Chicago"))));
|
||||||
|
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("America/Chicago")).build();
|
||||||
|
assertThat(tzRounding.round(time("2013-11-03T06:01:01", DateTimeZone.forID("America/Chicago"))), equalTo(time("2013-11-03T06:00:00", DateTimeZone.forID("America/Chicago"))));
|
||||||
|
|
||||||
|
// testing savings to non savings switch 2014 (America/Chicago)
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("UTC")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-11-02T06:01:01", DateTimeZone.forID("America/Chicago"))), equalTo(time("2014-11-02T06:00:00", DateTimeZone.forID("America/Chicago"))));
|
||||||
|
|
||||||
|
tzRounding = TimeZoneRounding.builder(DateTimeUnit.HOUR_OF_DAY).preZone(DateTimeZone.forID("America/Chicago")).build();
|
||||||
|
assertThat(tzRounding.round(time("2014-11-02T06:01:01", DateTimeZone.forID("America/Chicago"))), equalTo(time("2014-11-02T06:00:00", DateTimeZone.forID("America/Chicago"))));
|
||||||
|
}
|
||||||
|
|
||||||
private long utc(String time) {
|
private long utc(String time) {
|
||||||
return time(time, DateTimeZone.UTC);
|
return time(time, DateTimeZone.UTC);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue