X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FRescuePageTest.kt;fp=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FRescuePageTest.kt;h=db6903eb427b1c133a2c6aa26d068d5c56b41bd4;hp=0000000000000000000000000000000000000000;hb=de7568a82eb4150bf6d2b0553841b7b69f84c968;hpb=9acbc5bdec4ccb752e0856a501568b0bb6161579 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt new file mode 100644 index 0000000..db6903e --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt @@ -0,0 +1,67 @@ +package net.pterodactylus.sone.web.pages + +import net.pterodactylus.sone.core.SoneRescuer +import net.pterodactylus.sone.test.mock +import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.web.pages.RescuePage +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.ArgumentMatchers.anyLong +import org.mockito.Mockito.never +import org.mockito.Mockito.verify + +/** + * Unit test for [RescuePage]. + */ +class RescuePageTest : WebPageTest() { + + private val page = RescuePage(template, webInterface) + + private val soneRescuer = mock() + + override fun getPage() = page + + @Before + fun setupSoneRescuer() { + whenever(core.getSoneRescuer(currentSone)).thenReturn(soneRescuer) + } + + @Test + fun `get request sets rescuer in template context`() { + request("", GET) + page.handleRequest(freenetRequest, templateContext) + assertThat(templateContext["soneRescuer"], equalTo(soneRescuer)) + } + + @Test + fun `post request redirects to rescue page`() { + request("", POST) + verifyRedirect("rescue.html") + } + + @Test + fun `post request with fetch and invalid edition starts next fetch`() { + request("", POST) + addHttpRequestParameter("fetch", "true") + verifyRedirect("rescue.html") { + verify(soneRescuer, never()).setEdition(anyLong()) + verify(soneRescuer).startNextFetch() + } + } + + @Test + fun `post request with fetch and valid edition sets edition and starts next fetch`() { + request("", POST) + addHttpRequestParameter("fetch", "true") + addHttpRequestParameter("edition", "123") + verifyRedirect("rescue.html") { + verify(soneRescuer).setEdition(123L) + verify(soneRescuer).startNextFetch() + } + } + +}