diff --git a/bundles/org.openhab.persistence.mongodb/src/main/java/org/openhab/persistence/mongodb/internal/MongoDBTypeConversions.java b/bundles/org.openhab.persistence.mongodb/src/main/java/org/openhab/persistence/mongodb/internal/MongoDBTypeConversions.java index cc3bc3771e9..e5326ac833e 100644 --- a/bundles/org.openhab.persistence.mongodb/src/main/java/org/openhab/persistence/mongodb/internal/MongoDBTypeConversions.java +++ b/bundles/org.openhab.persistence.mongodb/src/main/java/org/openhab/persistence/mongodb/internal/MongoDBTypeConversions.java @@ -125,7 +125,7 @@ public class MongoDBTypeConversions { HSBType.class, State::toString, // QuantityType.class, state -> ((QuantityType) state).toBigDecimal().doubleValue(), // PercentType.class, state -> ((PercentType) state).intValue(), // - DateTimeType.class, state -> ((DateTimeType) state).getZonedDateTime().toString(), // + DateTimeType.class, state -> ((DateTimeType) state).getZonedDateTime(ZoneId.systemDefault()).toString(), // StringListType.class, State::toString, // DecimalType.class, state -> ((DecimalType) state).toBigDecimal().doubleValue(), // RawType.class, MongoDBTypeConversions::handleRawType// @@ -237,7 +237,7 @@ public class MongoDBTypeConversions { if (value instanceof String) { return new DateTimeType(ZonedDateTime.parse(doc.getString(MongoDBFields.FIELD_VALUE))); } else { - return new DateTimeType(ZonedDateTime.ofInstant(((Date) value).toInstant(), ZoneId.systemDefault())); + return new DateTimeType(((Date) value).toInstant()); } } diff --git a/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/DataCreationHelper.java b/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/DataCreationHelper.java index ac4deaf7732..0fee51e23f0 100644 --- a/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/DataCreationHelper.java +++ b/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/DataCreationHelper.java @@ -18,6 +18,7 @@ import static org.mockito.Mockito.when; import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; +import java.time.Instant; import java.time.LocalDate; import java.time.ZonedDateTime; import java.util.ArrayList; @@ -212,7 +213,7 @@ public class DataCreationHelper { Arguments.of(DataCreationHelper.createItem(RollershutterItem.class, "RollershutterItem", new PercentType(30))), Arguments.of(DataCreationHelper.createItem(DateTimeItem.class, "DateTimeItem", - new DateTimeType(ZonedDateTime.now()))), + new DateTimeType(Instant.now()))), Arguments.of(DataCreationHelper.createItem(ColorItem.class, "ColorItem", new HSBType("180,100,100"))), Arguments.of( DataCreationHelper.createItem(LocationItem.class, "LocationItem", new PointType("51.0,0.0"))), @@ -397,7 +398,7 @@ public class DataCreationHelper { value = type.toBigDecimal().doubleValue(); } else if (state instanceof DateTimeType) { DateTimeType type = (DateTimeType) state; - value = Date.from(type.getZonedDateTime().toInstant()); + value = Date.from(type.getInstant()); } else if (state instanceof DecimalType) { DecimalType type = (DecimalType) state; value = type.toBigDecimal().doubleValue(); diff --git a/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/MongoDBPersistenceServiceTest.java b/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/MongoDBPersistenceServiceTest.java index 1c80bc9544e..8747493bac7 100644 --- a/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/MongoDBPersistenceServiceTest.java +++ b/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/MongoDBPersistenceServiceTest.java @@ -59,7 +59,7 @@ import ch.qos.logback.core.read.ListAppender; import de.bwaldvogel.mongo.backend.memory.MemoryBackend; /** - * This is the implementation of the test for MongoDB {@link PersistenceService}. + * This is the implementation of the test for MongoDB {@link org.openhab.core.persistence.PersistenceService}. * * @author René Ulbricht - Initial contribution */ @@ -699,8 +699,9 @@ public class MongoDBPersistenceServiceTest { if (item instanceof DateTimeItem) { // verify just the date part - assertEquals(((DateTimeType) item.getState()).getZonedDateTime().toLocalDate(), - ((DateTimeType) result.iterator().next().getState()).getZonedDateTime().toLocalDate()); + assertEquals(((DateTimeType) item.getState()).getZonedDateTime(ZoneId.systemDefault()).toLocalDate(), + ((DateTimeType) result.iterator().next().getState()).getZonedDateTime(ZoneId.systemDefault()) + .toLocalDate()); } else { VerificationHelper.verifyQueryResult(result, item.getState()); } diff --git a/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/VerificationHelper.java b/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/VerificationHelper.java index 1e6093f4fe6..0adb3ebd471 100644 --- a/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/VerificationHelper.java +++ b/bundles/org.openhab.persistence.mongodb/src/test/java/org/openhab/persistence/mongodb/internal/VerificationHelper.java @@ -15,6 +15,7 @@ package org.openhab.persistence.mongodb.internal; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertNotNull; +import java.time.ZoneId; import java.util.ArrayList; import java.util.List; import java.util.Map; @@ -176,7 +177,8 @@ public class VerificationHelper { private static Pair handleDateTimeType(Object ev, Document doc) { String value = doc.getString(MongoDBFields.FIELD_VALUE); - return Pair.of(((DateTimeType) ev).getZonedDateTime().toString(), value != null ? value : new Object()); + return Pair.of(((DateTimeType) ev).getZonedDateTime(ZoneId.systemDefault()).toString(), + value != null ? value : new Object()); } private static Pair handlePercentType(Object ev, Document doc) {