From 5bd75f4b4b1de78ab1a4b0d43313a3ddcd7109a1 Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20=E2=80=98Bombe=E2=80=99=20Roden?= Date: Sat, 21 Jan 2017 16:28:20 +0100 Subject: [PATCH] Add unit test for unlike page --- .../net/pterodactylus/sone/web/UnlikePageTest.kt | 60 ++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 src/test/kotlin/net/pterodactylus/sone/web/UnlikePageTest.kt diff --git a/src/test/kotlin/net/pterodactylus/sone/web/UnlikePageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/UnlikePageTest.kt new file mode 100644 index 0000000..3bbd1e4 --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/UnlikePageTest.kt @@ -0,0 +1,60 @@ +package net.pterodactylus.sone.web + +import net.pterodactylus.util.web.Method +import net.pterodactylus.util.web.Method.POST +import org.junit.Test +import org.mockito.ArgumentMatchers +import org.mockito.ArgumentMatchers.any +import org.mockito.Mockito +import org.mockito.Mockito.never +import org.mockito.Mockito.verify + +/** + * Unit test for [UnlikePage]. + */ +class UnlikePageTest : WebPageTest() { + + private val page = UnlikePage(template, webInterface) + + override fun getPage() = page + + @Test + fun `get request does not redirect`() { + page.handleRequest(freenetRequest, templateContext) + } + + @Test + fun `post request does not remove any likes but redirects`() { + request("", POST) + addHttpRequestParameter("returnPage", "return.html") + verifyRedirect("return.html") { + verify(currentSone, never()).removeLikedPostId(any()) + verify(currentSone, never()).removeLikedReplyId(any()) + } + } + + @Test + fun `post request removes post like and redirects`() { + request("", POST) + addHttpRequestParameter("returnPage", "return.html") + addHttpRequestParameter("type", "post") + addHttpRequestParameter("id", "post-id") + verifyRedirect("return.html") { + verify(currentSone, never()).removeLikedPostId("post-id") + verify(currentSone, never()).removeLikedReplyId(any()) + } + } + + @Test + fun `post request removes reply like and redirects`() { + request("", POST) + addHttpRequestParameter("returnPage", "return.html") + addHttpRequestParameter("type", "reply") + addHttpRequestParameter("id", "reply-id") + verifyRedirect("return.html") { + verify(currentSone, never()).removeLikedPostId(any()) + verify(currentSone, never()).removeLikedReplyId("reply-id") + } + } + +} -- 2.7.4