X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FRescuePageTest.kt;h=8bda29acc13d47bb4a541b90dc6eeec71d76b777;hb=5479681d7a9aa211a775ca448d568f81ec12df7a;hp=547c580947744b4ff05330e18013b591b5880103;hpb=5ba707d40f9d2a20094aaabc21647aeec1feed46;p=Sone.git diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt index 547c580..8bda29a 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt @@ -1,11 +1,14 @@ package net.pterodactylus.sone.web.pages import net.pterodactylus.sone.core.SoneRescuer +import net.pterodactylus.sone.test.getInstance import net.pterodactylus.sone.test.mock import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.web.baseInjector import net.pterodactylus.util.web.Method.POST import org.hamcrest.MatcherAssert.assertThat import org.hamcrest.Matchers.equalTo +import org.hamcrest.Matchers.notNullValue import org.junit.Before import org.junit.Test import org.mockito.ArgumentMatchers.anyLong @@ -15,23 +18,36 @@ import org.mockito.Mockito.verify /** * Unit test for [RescuePage]. */ -class RescuePageTest : WebPageTest() { - - private val page = RescuePage(template, webInterface) +class RescuePageTest: WebPageTest(::RescuePage) { private val soneRescuer = mock() - override fun getPage() = page - @Before fun setupSoneRescuer() { whenever(core.getSoneRescuer(currentSone)).thenReturn(soneRescuer) } @Test + fun `page returns correct path`() { + assertThat(page.path, equalTo("rescue.html")) + } + + @Test + fun `page requires login`() { + assertThat(page.requiresLogin(), equalTo(true)) + } + + @Test + fun `page returns correct title`() { + addTranslation("Page.Rescue.Title", "rescue page title") + assertThat(page.getPageTitle(soneRequest), equalTo("rescue page title")) + } + + @Test fun `get request sets rescuer in template context`() { - page.handleRequest(freenetRequest, templateContext) - assertThat(templateContext["soneRescuer"], equalTo(soneRescuer)) + verifyNoRedirect { + assertThat(templateContext["soneRescuer"], equalTo(soneRescuer)) + } } @Test @@ -61,4 +77,20 @@ class RescuePageTest : WebPageTest() { } } + @Test + fun `post request with negative edition will not set edition`() { + setMethod(POST) + addHttpRequestPart("fetch", "true") + addHttpRequestPart("edition", "-123") + verifyRedirect("rescue.html") { + verify(soneRescuer, never()).setEdition(anyLong()) + verify(soneRescuer).startNextFetch() + } + } + + @Test + fun `page can be created by dependency injection`() { + assertThat(baseInjector.getInstance(), notNullValue()) + } + }