X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FRescuePageTest.kt;h=e653bbee064f80d9a00be8111cd86e7410d05204;hb=6de1ddee725ce440b1a91880a45edae195c2d593;hp=303a23cbe3c54d7edc0e8f3dc9ba6c6e69907fb7;hpb=4f2dd6da42af253e7545d7cba5d9e5cb2895eb34;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 303a23c..e653bbe 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/RescuePageTest.kt @@ -1,13 +1,13 @@ 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.util.web.Method.POST -import org.hamcrest.MatcherAssert.assertThat -import org.hamcrest.Matchers.equalTo -import org.junit.Before -import org.junit.Test +import net.pterodactylus.sone.core.* +import net.pterodactylus.sone.test.* +import net.pterodactylus.sone.web.* +import net.pterodactylus.sone.web.page.* +import net.pterodactylus.util.web.Method.* +import org.hamcrest.MatcherAssert.* +import org.hamcrest.Matchers.* +import org.junit.* import org.mockito.ArgumentMatchers.anyLong import org.mockito.Mockito.never import org.mockito.Mockito.verify @@ -15,20 +15,32 @@ 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`() { verifyNoRedirect { assertThat(templateContext["soneRescuer"], equalTo(soneRescuer)) @@ -42,24 +54,36 @@ class RescuePageTest : WebPageTest() { } @Test - fun `post request with fetch and invalid edition starts next fetch`() { + fun `post request with fetch starts next fetch`() { setMethod(POST) addHttpRequestPart("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`() { + fun `post request with skipping fetch starts next skipping fetch`() { setMethod(POST) - addHttpRequestPart("fetch", "true") - addHttpRequestPart("edition", "123") + addHttpRequestPart("fetchSkip", "true") verifyRedirect("rescue.html") { - verify(soneRescuer).setEdition(123L) - verify(soneRescuer).startNextFetch() + verify(soneRescuer).startNextFetchWithSkip() } } + @Test + fun `page can be created by dependency injection`() { + assertThat(baseInjector.getInstance(), notNullValue()) + } + + @Test + fun `page is annotated with correct menuname`() { + assertThat(page.menuName, equalTo("Rescue")) + } + + @Test + fun `page is annotated with correct template path`() { + assertThat(page.templatePath, equalTo("/templates/rescue.html")) + } + }