From ecb2a5d8b89cdfa6c2095d9d40f0ba89daaacf29 Mon Sep 17 00:00:00 2001 From: Wouter Born Date: Sat, 20 Jun 2020 13:34:24 +0200 Subject: [PATCH] Fix DateTimeType deprecations (#7948) Related to: * https://github.com/openhab/openhab-core/pull/1500 * https://github.com/openhab/openhab-addons/pull/7918 Signed-off-by: Wouter Born Signed-off-by: CSchlipp --- .../internal/handler/ClockAppHandler.java | 5 +-- .../internal/grxprg/PrgBridgeHandler.java | 7 ++-- .../internal/handler/RobonectHandlerTest.java | 42 +++++++++---------- 3 files changed, 26 insertions(+), 28 deletions(-) diff --git a/bundles/org.openhab.binding.lametrictime/src/main/java/org/openhab/binding/lametrictime/internal/handler/ClockAppHandler.java b/bundles/org.openhab.binding.lametrictime/src/main/java/org/openhab/binding/lametrictime/internal/handler/ClockAppHandler.java index 9039c9aa5af7b..481f3612f7813 100644 --- a/bundles/org.openhab.binding.lametrictime/src/main/java/org/openhab/binding/lametrictime/internal/handler/ClockAppHandler.java +++ b/bundles/org.openhab.binding.lametrictime/src/main/java/org/openhab/binding/lametrictime/internal/handler/ClockAppHandler.java @@ -14,9 +14,7 @@ import static org.openhab.binding.lametrictime.internal.LaMetricTimeBindingConstants.*; -import java.time.Instant; import java.time.LocalTime; -import java.time.ZoneId; import org.eclipse.smarthome.core.library.types.DateTimeType; import org.eclipse.smarthome.core.library.types.StringType; @@ -52,8 +50,7 @@ public void handleAppCommand(ChannelUID channelUID, Command command) { try { switch (channelUID.getId()) { case CHANNEL_APP_SET_ALARM: { - LocalTime time = Instant.ofEpochMilli(((DateTimeType) command).getCalendar().getTimeInMillis()) - .atZone(ZoneId.systemDefault()).toLocalTime(); + LocalTime time = ((DateTimeType) command).getZonedDateTime().toLocalTime(); getDevice().doAction(getWidget(), CoreApps.clock().setAlarm(true, time, null)); updateActiveAppOnDevice(); break; diff --git a/bundles/org.openhab.binding.lutron/src/main/java/org/openhab/binding/lutron/internal/grxprg/PrgBridgeHandler.java b/bundles/org.openhab.binding.lutron/src/main/java/org/openhab/binding/lutron/internal/grxprg/PrgBridgeHandler.java index c8bec6438b295..5b59e67a4947c 100644 --- a/bundles/org.openhab.binding.lutron/src/main/java/org/openhab/binding/lutron/internal/grxprg/PrgBridgeHandler.java +++ b/bundles/org.openhab.binding.lutron/src/main/java/org/openhab/binding/lutron/internal/grxprg/PrgBridgeHandler.java @@ -13,7 +13,8 @@ package org.openhab.binding.lutron.internal.grxprg; import java.io.IOException; -import java.util.Calendar; +import java.time.ZonedDateTime; +import java.util.GregorianCalendar; import java.util.concurrent.ScheduledFuture; import java.util.concurrent.TimeUnit; @@ -167,8 +168,8 @@ public void handleCommand(ChannelUID channelUID, Command command) { } else if (id.equals(PrgConstants.CHANNEL_TIMECLOCK)) { if (command instanceof DateTimeType) { - final Calendar c = ((DateTimeType) command).getCalendar(); - _protocolHandler.setTime(c); + final ZonedDateTime zdt = ((DateTimeType) command).getZonedDateTime(); + _protocolHandler.setTime(GregorianCalendar.from(zdt)); } else { logger.error("Received a TIMECLOCK channel command with a non DateTimeType: {}", command); } diff --git a/bundles/org.openhab.binding.robonect/src/test/java/org/openhab/binding/robonect/internal/handler/RobonectHandlerTest.java b/bundles/org.openhab.binding.robonect/src/test/java/org/openhab/binding/robonect/internal/handler/RobonectHandlerTest.java index 4790904caadd7..fdc84608011f9 100644 --- a/bundles/org.openhab.binding.robonect/src/test/java/org/openhab/binding/robonect/internal/handler/RobonectHandlerTest.java +++ b/bundles/org.openhab.binding.robonect/src/test/java/org/openhab/binding/robonect/internal/handler/RobonectHandlerTest.java @@ -16,8 +16,9 @@ import static org.mockito.ArgumentMatchers.eq; import static org.mockito.Mockito.*; +import java.time.Month; import java.time.ZoneId; -import java.util.Calendar; +import java.time.ZonedDateTime; import org.eclipse.jetty.client.HttpClient; import org.eclipse.smarthome.core.i18n.TimeZoneProvider; @@ -113,15 +114,14 @@ public void shouldUpdateNextTimerChannelWithDateTimeState() throws InterruptedEx State value = stateCaptor.getValue(); assertTrue(value instanceof DateTimeType); - DateTimeType dateTimeType = (DateTimeType) value; - assertEquals(1, dateTimeType.getCalendar().get(Calendar.DAY_OF_MONTH)); - - assertEquals(2017, dateTimeType.getCalendar().get(Calendar.YEAR)); - // calendar january is 0 - assertEquals(4, dateTimeType.getCalendar().get(Calendar.MONTH)); - assertEquals(19, dateTimeType.getCalendar().get(Calendar.HOUR_OF_DAY)); - assertEquals(0, dateTimeType.getCalendar().get(Calendar.MINUTE)); - assertEquals(0, dateTimeType.getCalendar().get(Calendar.SECOND)); + + ZonedDateTime zdt = ((DateTimeType) value).getZonedDateTime(); + assertEquals(1, zdt.getDayOfMonth()); + assertEquals(2017, zdt.getYear()); + assertEquals(Month.MAY, zdt.getMonth()); + assertEquals(19, zdt.getHour()); + assertEquals(0, zdt.getMinute()); + assertEquals(0, zdt.getSecond()); } @Test @@ -136,7 +136,7 @@ public void shouldUpdateErrorChannelsIfErrorStatusReturned() throws InterruptedE error.setDate("01.05.2017"); error.setTime("19:00:00"); error.setUnix("1493665200"); - error.setErrorCode(new Integer(22)); + error.setErrorCode(Integer.valueOf(22)); error.setErrorMessage("Dummy Message"); mowerInfo.getStatus().setStatus(MowerStatus.ERROR_STATUS); mowerInfo.setError(error); @@ -164,14 +164,14 @@ public void shouldUpdateErrorChannelsIfErrorStatusReturned() throws InterruptedE State errorDate = errorDateCaptor.getValue(); assertTrue(errorDate instanceof DateTimeType); - DateTimeType dateTimeType = (DateTimeType) errorDate; - assertEquals(1, dateTimeType.getCalendar().get(Calendar.DAY_OF_MONTH)); - assertEquals(2017, dateTimeType.getCalendar().get(Calendar.YEAR)); - // calendar january is 0 - assertEquals(4, dateTimeType.getCalendar().get(Calendar.MONTH)); - assertEquals(19, dateTimeType.getCalendar().get(Calendar.HOUR_OF_DAY)); - assertEquals(0, dateTimeType.getCalendar().get(Calendar.MINUTE)); - assertEquals(0, dateTimeType.getCalendar().get(Calendar.SECOND)); + + ZonedDateTime zdt = ((DateTimeType) errorDate).getZonedDateTime(); + assertEquals(1, zdt.getDayOfMonth()); + assertEquals(2017, zdt.getYear()); + assertEquals(Month.MAY, zdt.getMonth()); + assertEquals(19, zdt.getHour()); + assertEquals(0, zdt.getMinute()); + assertEquals(0, zdt.getSecond()); State errorMessage = errorMessageCaptor.getValue(); assertTrue(errorMessage instanceof StringType); @@ -298,8 +298,8 @@ public void shouldUpdateAllChannels() { assertEquals("Mowy", stateCaptorName.getValue().toFullString()); assertEquals(99, ((DecimalType) stateCaptorBattery.getValue()).intValue()); assertEquals(4, ((DecimalType) stateCaptorStatus.getValue()).intValue()); - assertEquals(55, ((QuantityType) stateCaptorDuration.getValue()).intValue()); - assertEquals(22, ((QuantityType) stateCaptorHours.getValue()).intValue()); + assertEquals(55, ((QuantityType) stateCaptorDuration.getValue()).intValue()); + assertEquals(22, ((QuantityType) stateCaptorHours.getValue()).intValue()); assertEquals(MowerMode.AUTO.name(), stateCaptorMode.getValue().toFullString()); assertEquals(OnOffType.ON, stateCaptorStarted.getValue()); assertEquals(-88, ((DecimalType) stateCaptorWlan.getValue()).intValue());