🔥 Remove possibility to fetch a custom edition
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / RescuePageTest.kt
index 1f62a92..85e1f6b 100644 (file)
@@ -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,14 +15,10 @@ 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<SoneRescuer>()
 
-       override fun getPage() = page
-
        @Before
        fun setupSoneRescuer() {
                whenever(core.getSoneRescuer(currentSone)).thenReturn(soneRescuer)
@@ -41,7 +37,7 @@ class RescuePageTest: WebPageTest() {
        @Test
        fun `page returns correct title`() {
                addTranslation("Page.Rescue.Title", "rescue page title")
-               assertThat(page.getPageTitle(freenetRequest), equalTo("rescue page title"))
+               assertThat(page.getPageTitle(soneRequest), equalTo("rescue page title"))
        }
 
        @Test
@@ -58,36 +54,27 @@ 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`() {
-               setMethod(POST)
-               addHttpRequestPart("fetch", "true")
-               addHttpRequestPart("edition", "123")
-               verifyRedirect("rescue.html") {
-                       verify(soneRescuer).setEdition(123L)
-                       verify(soneRescuer).startNextFetch()
-               }
+       fun `page can be created by dependency injection`() {
+               assertThat(baseInjector.getInstance<RescuePage>(), notNullValue())
        }
 
        @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()
-               }
+       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"))
+       }
 
 }