🎨 Fix formatting
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / LockSonePageTest.kt
index 25678ca..de42141 100644 (file)
@@ -1,10 +1,12 @@
 package net.pterodactylus.sone.web.pages
 
-import net.pterodactylus.sone.data.Sone
-import net.pterodactylus.sone.test.mock
-import org.hamcrest.MatcherAssert.assertThat
-import org.hamcrest.Matchers.equalTo
-import org.junit.Test
+import net.pterodactylus.sone.data.*
+import net.pterodactylus.sone.test.*
+import net.pterodactylus.sone.web.*
+import net.pterodactylus.util.web.Method.*
+import org.hamcrest.MatcherAssert.*
+import org.hamcrest.Matchers.*
+import org.junit.*
 import org.mockito.ArgumentMatchers.any
 import org.mockito.Mockito.never
 import org.mockito.Mockito.verify
@@ -12,11 +14,7 @@ import org.mockito.Mockito.verify
 /**
  * Unit test for [LockSonePage].
  */
-class LockSonePageTest : WebPageTest() {
-
-       private val page = LockSonePage(template, webInterface)
-
-       override fun getPage() = page
+class LockSonePageTest : WebPageTest(::LockSonePage) {
 
        @Test
        fun `page returns correct path`() {
@@ -24,18 +22,19 @@ class LockSonePageTest : WebPageTest() {
        }
 
        @Test
-       fun `page requires login`() {
-           assertThat(page.requiresLogin(), equalTo(false))
+       fun `page does not require login`() {
+               assertThat(page.requiresLogin(), equalTo(false))
        }
 
        @Test
        fun `page returns correct title`() {
-           addTranslation("Page.LockSone.Title", "lock Sone page title")
-               assertThat(page.getPageTitle(freenetRequest), equalTo("lock Sone page title"))
+               addTranslation("Page.LockSone.Title", "lock Sone page title")
+               assertThat(page.getPageTitle(soneRequest), equalTo("lock Sone page title"))
        }
 
        @Test
        fun `locking an invalid local sone redirects to return page`() {
+               setMethod(POST)
                addHttpRequestPart("returnPage", "return.html")
                verifyRedirect("return.html") {
                        verify(core, never()).lockSone(any<Sone>())
@@ -44,6 +43,7 @@ class LockSonePageTest : WebPageTest() {
 
        @Test
        fun `locking an valid local sone locks the sone and redirects to return page`() {
+               setMethod(POST)
                addHttpRequestPart("sone", "sone-id")
                val sone = mock<Sone>()
                addLocalSone("sone-id", sone)
@@ -53,4 +53,9 @@ class LockSonePageTest : WebPageTest() {
                }
        }
 
+       @Test
+       fun `page can be created by dependency injection`() {
+               assertThat(baseInjector.getInstance<LockSonePage>(), notNullValue())
+       }
+
 }