🎨 Rename method to create replies for tests
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / notification / NotificationHandlerModuleTest.kt
index 27f396f..0a79cfe 100644 (file)
@@ -1,5 +1,5 @@
 /**
- * Sone - NotificationHandlerModuleTest.kt - Copyright Â© 2019 David â€˜Bombe’ Roden
+ * Sone - NotificationHandlerModuleTest.kt - Copyright Â© 2019–2020 David â€˜Bombe’ Roden
  *
  * This program is free software: you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -205,7 +205,7 @@ class NotificationHandlerModuleTest {
        fun `new-remote-post-reply notification has correct key and template`() {
                loaders.templates += "/templates/notify/newReplyNotification.html" to "<% replies>".asTemplate()
                val notification = injector.getInstance<ListNotification<PostReply>>(named("newRemotePostReply"))
-               val postReplies = listOf(emptyPostReply(), emptyPostReply())
+               val postReplies = listOf(createPostReply(), createPostReply())
                postReplies.forEach(notification::add)
                assertThat(notification.render(), equalTo(postReplies.toString()))
        }
@@ -282,7 +282,7 @@ class NotificationHandlerModuleTest {
        fun `local-reply notification has correct key and template`() {
                loaders.templates += "/templates/notify/newReplyNotification.html" to "<% replies>".asTemplate()
                val notification = injector.getInstance<ListNotification<PostReply>>(named("localReply"))
-               val replies = listOf(emptyPostReply("reply1"), emptyPostReply("reply2"))
+               val replies = listOf(createPostReply("reply1"), createPostReply("reply2"))
                replies.forEach(notification::add)
                assertThat(notification.render(), equalTo(replies.toString()))
        }
@@ -562,4 +562,50 @@ class NotificationHandlerModuleTest {
                injector.verifySingletonInstance<SoneMentionedHandler>()
        }
 
+       @Test
+       fun `sone insert notification supplier is created as singleton`() {
+               injector.verifySingletonInstance<SoneInsertNotificationSupplier>()
+       }
+
+       @Test
+       fun `sone insert notification template is loaded correctly`() {
+               loaders.templates += "/templates/notify/soneInsertNotification.html" to "foo".asTemplate()
+               injector.getInstance<SoneInsertNotificationSupplier>()
+                               .invoke(createRemoteSone())
+                               .render()
+                               .let { assertThat(it, equalTo("foo")) }
+       }
+
+       @Test
+       fun `sone notification supplier returns different notifications for different sones`() {
+               val supplier = injector.getInstance<SoneInsertNotificationSupplier>()
+               listOf(createRemoteSone(), createRemoteSone(), createRemoteSone())
+                               .map(supplier)
+                               .distinct()
+                               .let { assertThat(it, hasSize(3)) }
+       }
+
+       @Test
+       fun `sone notification supplier caches notifications for a sone`() {
+               val supplier = injector.getInstance<SoneInsertNotificationSupplier>()
+               val sone = createRemoteSone()
+               listOf(sone, sone, sone)
+                               .map(supplier)
+                               .distinct()
+                               .let { assertThat(it, hasSize(1)) }
+       }
+
+       @Test
+       fun `sone notification supplier sets sone in notification template`() {
+               val supplier = injector.getInstance<SoneInsertNotificationSupplier>()
+               val sone = createRemoteSone()
+               val templateNotification = supplier(sone)
+               assertThat(templateNotification["insertSone"], sameInstance<Any>(sone))
+       }
+
+       @Test
+       fun `sone insert handler is created as singleton`() {
+               injector.verifySingletonInstance<SoneInsertHandler>()
+       }
+
 }