X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FDeleteReplyPageTest.kt;fp=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FDeleteReplyPageTest.kt;h=ff65e9d8f18a9b7cd4afda18e6e00fcf4e64b38d;hp=0000000000000000000000000000000000000000;hb=de7568a82eb4150bf6d2b0553841b7b69f84c968;hpb=9acbc5bdec4ccb752e0856a501568b0bb6161579 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPageTest.kt new file mode 100644 index 0000000..ff65e9d --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPageTest.kt @@ -0,0 +1,106 @@ +package net.pterodactylus.sone.web.pages + +import net.pterodactylus.sone.data.PostReply +import net.pterodactylus.sone.data.Sone +import net.pterodactylus.sone.test.mock +import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.web.pages.WebPageTest +import net.pterodactylus.sone.web.pages.DeleteReplyPage +import net.pterodactylus.util.web.Method.GET +import net.pterodactylus.util.web.Method.POST +import org.hamcrest.MatcherAssert.assertThat +import org.hamcrest.Matchers.equalTo +import org.junit.Before +import org.junit.Test +import org.mockito.Mockito.never +import org.mockito.Mockito.verify + +/** + * Unit test for [DeleteReplyPage]. + */ +class DeleteReplyPageTest : WebPageTest() { + + private val page = DeleteReplyPage(template, webInterface) + + private val sone = mock() + private val reply = mock() + + override fun getPage() = page + + @Before + fun setupReply() { + whenever(sone.isLocal).thenReturn(true) + whenever(reply.sone).thenReturn(sone) + } + + @Test + fun `page returns correct path`() { + assertThat(page.path, equalTo("deleteReply.html")) + } + + @Test + fun `page requires login`() { + assertThat(page.requiresLogin(), equalTo(true)) + } + + @Test + fun `get request sets reply ID and return page in template context`() { + request("", GET) + addHttpRequestParameter("reply", "reply-id") + addHttpRequestParameter("returnPage", "return.html") + page.processTemplate(freenetRequest, templateContext) + assertThat(templateContext["reply"], equalTo("reply-id")) + assertThat(templateContext["returnPage"], equalTo("return.html")) + } + + @Test + fun `post request without any action sets reply ID and return page in template context`() { + request("", POST) + addPostReply("reply-id", reply) + addHttpRequestParameter("reply", "reply-id") + addHttpRequestParameter("returnPage", "return.html") + page.processTemplate(freenetRequest, templateContext) + assertThat(templateContext["reply"], equalTo("reply-id")) + assertThat(templateContext["returnPage"], equalTo("return.html")) + } + + @Test + fun `trying to delete a reply with an invalid ID results in no permission page`() { + request("", POST) + verifyRedirect("noPermission.html") + } + + @Test + fun `trying to delete a reply from a non-local sone results in no permission page`() { + request("", POST) + addHttpRequestParameter("reply", "reply-id") + whenever(sone.isLocal).thenReturn(false) + addPostReply("reply-id", reply) + verifyRedirect("noPermission.html") + } + + @Test + fun `confirming deletion of reply deletes the reply and redirects to return page`() { + request("", POST) + addPostReply("reply-id", reply) + addHttpRequestParameter("reply", "reply-id") + addHttpRequestParameter("returnPage", "return.html") + addHttpRequestParameter("confirmDelete", "true") + verifyRedirect("return.html") { + verify(core).deleteReply(reply) + } + } + + @Test + fun `aborting deletion of reply redirects to return page`() { + request("", POST) + addPostReply("reply-id", reply) + addHttpRequestParameter("reply", "reply-id") + addHttpRequestParameter("returnPage", "return.html") + addHttpRequestParameter("abortDelete", "true") + verifyRedirect("return.html") { + verify(core, never()).deleteReply(reply) + } + } + +}