X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FDeleteSonePageTest.kt;fp=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FDeleteSonePageTest.kt;h=b94c3faa5858a9d728a0968565242d16d087a7c8;hb=de7568a82eb4150bf6d2b0553841b7b69f84c968;hp=0000000000000000000000000000000000000000;hpb=9acbc5bdec4ccb752e0856a501568b0bb6161579;p=Sone.git diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/DeleteSonePageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/DeleteSonePageTest.kt new file mode 100644 index 0000000..b94c3fa --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/DeleteSonePageTest.kt @@ -0,0 +1,65 @@ +package net.pterodactylus.sone.web.pages + +import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.web.pages.WebPageTest +import net.pterodactylus.sone.web.pages.DeleteSonePage +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.Test +import org.mockito.ArgumentMatchers +import org.mockito.ArgumentMatchers.any +import org.mockito.Mockito.any +import org.mockito.Mockito.never +import org.mockito.Mockito.verify + +/** + * Unit test for [DeleteSonePage]. + */ +class DeleteSonePageTest : WebPageTest() { + + private val page = DeleteSonePage(template, webInterface) + + override fun getPage() = page + + @Test + fun `page returns correct path`() { + assertThat(page.path, equalTo("deleteSone.html")) + } + + @Test + fun `page requires login`() { + assertThat(page.requiresLogin(), equalTo(true)) + } + + @Test + fun `page returns correct title`() { + whenever(l10n.getString("Page.DeleteSone.Title")).thenReturn("delete sone page") + assertThat(page.getPageTitle(freenetRequest), equalTo("delete sone page")) + } + + @Test + fun `get request does not redirect`() { + request("", GET) + page.processTemplate(freenetRequest, templateContext) + } + + @Test + fun `post request without delete confirmation redirects to index`() { + request("", POST) + verifyRedirect("index.html") { + verify(core, never()).deleteSone(any()) + } + } + + @Test + fun `post request with delete confirmation deletes sone and redirects to index`() { + request("", POST) + addHttpRequestParameter("deleteSone", "true") + verifyRedirect("index.html") { + verify(core).deleteSone(currentSone) + } + } + +}