Use a single hour state for all weather services
[rhynodge.git] / src / test / kotlin / net / pterodactylus / rhynodge / webpages / weather / wettercom / WetterComStateTest.kt
index 2b52a77..d32e563 100644 (file)
@@ -1,11 +1,14 @@
 package net.pterodactylus.rhynodge.webpages.weather.wettercom
 
+import com.fasterxml.jackson.databind.ObjectMapper
+import net.pterodactylus.rhynodge.webpages.weather.HourState
+import net.pterodactylus.rhynodge.webpages.weather.WindDirection
 import org.hamcrest.MatcherAssert.assertThat
 import org.hamcrest.Matchers.`is`
 import org.junit.Test
 import java.time.Instant
-import java.time.LocalDateTime
 import java.time.ZoneId
+import java.time.ZonedDateTime
 
 /**
  * Unit test for [WetterComState].
@@ -16,24 +19,44 @@ class WetterComStateTest {
 
     @Test
     fun statesWithoutHoursEqualOneAnother() {
-        val now = Instant.now().atZone(ZoneId.of("UTC"))
-        println("%s %s".format(now, now.javaClass))
-        val firstState = WetterComState(LocalDateTime.from(now))
-        val secondState = WetterComState(LocalDateTime.from(now))
+        val now = Instant.now().atZone(ZoneId.of("Europe/Berlin"))
+        val firstState = WetterComState(ZonedDateTime.from(now))
+        val secondState = WetterComState(ZonedDateTime.from(now))
         assertThat(firstState, `is`(secondState))
     }
 
     @Test
     fun statesWithTheSameHoursAreEqual() {
-        val now = Instant.now().atZone(ZoneId.of("UTC"))
-        println("%s %s".format(now, now.javaClass))
-        val firstState = WetterComState(LocalDateTime.from(now))
-        firstState.addHour(HourState(0, 10.0, 0.05, 0.0, WindDirection.NORTH, 5.0, "Fine", "http://1"))
-        firstState.addHour(HourState(1, 12.0, 0.1, 2.0, WindDirection.WEST, 8.0, "Superb", "http://2"))
-        val secondState = WetterComState(LocalDateTime.from(now))
-        secondState.addHour(HourState(0, 10.0, 0.05, 0.0, WindDirection.NORTH, 5.0, "Fine", "http://1"))
-        secondState.addHour(HourState(1, 12.0, 0.1, 2.0, WindDirection.WEST, 8.0, "Superb", "http://2"))
+        val now = Instant.now().atZone(ZoneId.of("Europe/Berlin"))
+        val firstState = WetterComState(ZonedDateTime.from(now))
+        firstState += HourState(0, 10, null, 0.05, 0.0, WindDirection.NORTH, 5, null, null, "Fine", "http://1")
+        firstState += HourState(1, 12, null, 0.1, 2.0, WindDirection.WEST, 8, null, null, "Superb", "http://2")
+        val secondState = WetterComState(ZonedDateTime.from(now))
+        secondState += HourState(0, 10, null, 0.05, 0.0, WindDirection.NORTH, 5, null, null, "Fine", "http://1")
+        secondState += HourState(1, 12, null, 0.1, 2.0, WindDirection.WEST, 8, null, null, "Superb", "http://2")
         assertThat(firstState, `is`(secondState))
     }
 
+    @Test
+    fun iteratingDeliversHourStates() {
+        val now = Instant.now().atZone(ZoneId.of("Europe/Berlin"))
+        val firstState = WetterComState(ZonedDateTime.from(now))
+        firstState += HourState(0, 10, null, 0.05, 0.0, WindDirection.NORTH, 5, null, null, "Fine", "http://1")
+        firstState += HourState(1, 12, null, 0.1, 2.0, WindDirection.WEST, 8, null, null, "Superb", "http://2")
+        assertThat(firstState.iterator().asSequence().toList(), `is`(firstState.hours as Iterable<HourState>))
+    }
+
+    @Test
+    fun stateIsSerializableAsJson() {
+        val objectMapper = ObjectMapper()
+        val now = Instant.now().atZone(ZoneId.of("Europe/Berlin"))
+        val originalState = WetterComState(ZonedDateTime.from(now))
+        originalState += HourState(0, 10, null, 0.05, 0.0, WindDirection.NORTH, 5, null, null, "Fine", "http://1")
+        originalState += HourState(1, 12, null, 0.1, 2.0, WindDirection.WEST, 8, null, null, "Superb", "http://2")
+        val json = objectMapper.writeValueAsString(originalState)
+        println(json)
+        val parsedState = objectMapper.readValue(json, WetterComState::class.java)
+        assertThat(parsedState, `is`(originalState))
+    }
+
 }