Add test for get post ajax page
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / ajax / GetPostAjaxPageTest.kt
diff --git a/src/test/kotlin/net/pterodactylus/sone/web/ajax/GetPostAjaxPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/ajax/GetPostAjaxPageTest.kt
new file mode 100644 (file)
index 0000000..768a186
--- /dev/null
@@ -0,0 +1,55 @@
+package net.pterodactylus.sone.web.ajax
+
+import net.pterodactylus.sone.data.Post
+import net.pterodactylus.sone.data.Sone
+import net.pterodactylus.sone.test.mock
+import net.pterodactylus.sone.test.whenever
+import net.pterodactylus.sone.utils.asOptional
+import net.pterodactylus.sone.utils.asTemplate
+import net.pterodactylus.util.template.ReflectionAccessor
+import org.hamcrest.MatcherAssert.assertThat
+import org.hamcrest.Matchers.equalTo
+import org.junit.Test
+
+/**
+ * Unit test for [GetPostAjaxPage].
+ */
+class GetPostAjaxPageTest : JsonPageTest("getPost.ajax", needsFormPassword = false,
+               pageSupplier = { webInterface ->
+                       GetPostAjaxPage(webInterface, "<%core>\n<%request>\n<%post.text>\n<%currentSone>\n<%localSones>".asTemplate())
+               }) {
+
+       @Test
+       fun `request with missing post results in invalid-post-id`() {
+               assertThat(json.isSuccess, equalTo(false))
+               assertThat(json.error, equalTo("invalid-post-id"))
+       }
+
+       @Test
+       fun `request with valid post results in post json`() {
+               val sone = mock<Sone>().apply { whenever(id).thenReturn("sone-id") }
+               val post = mock<Post>().apply {
+                       whenever(id).thenReturn("post-id")
+                       whenever(time).thenReturn(1000)
+                       whenever(this.sone).thenReturn(sone)
+                       whenever(recipientId).thenReturn("recipient-id".asOptional())
+                       whenever(text).thenReturn("post text")
+               }
+               webInterface.templateContextFactory.addAccessor(Any::class.java, ReflectionAccessor())
+               addPost(post)
+               addRequestParameter("post", "post-id")
+               assertThat(json.isSuccess, equalTo(true))
+               assertThat(json["post"]["id"].asText(), equalTo("post-id"))
+               assertThat(json["post"]["time"].asLong(), equalTo(1000L))
+               assertThat(json["post"]["sone"].asText(), equalTo("sone-id"))
+               assertThat(json["post"]["recipient"].asText(), equalTo("recipient-id"))
+               assertThat(json["post"]["html"].asText(), equalTo(listOf(
+                               core.toString(),
+                               freenetRequest.toString(),
+                               "post text",
+                               currentSone.toString(),
+                               core.localSones.toString()
+               ).joinToString("\n")))
+       }
+
+}