🔥 Remove templates from FreenetTemplatePages
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / CreateSonePageTest.kt
index 04ed0aa..e865f65 100644 (file)
@@ -3,14 +3,16 @@ package net.pterodactylus.sone.web.pages
 import net.pterodactylus.sone.data.Profile
 import net.pterodactylus.sone.data.Sone
 import net.pterodactylus.sone.freenet.wot.OwnIdentity
+import net.pterodactylus.sone.test.getInstance
 import net.pterodactylus.sone.test.mock
 import net.pterodactylus.sone.test.whenever
-import net.pterodactylus.sone.web.pages.WebPageTest
-import net.pterodactylus.sone.web.pages.CreateSonePage
+import net.pterodactylus.sone.web.baseInjector
+import net.pterodactylus.sone.web.page.*
 import net.pterodactylus.util.web.Method.POST
 import org.hamcrest.MatcherAssert.assertThat
 import org.hamcrest.Matchers.contains
 import org.hamcrest.Matchers.equalTo
+import org.hamcrest.Matchers.notNullValue
 import org.junit.Test
 import org.mockito.ArgumentMatchers.anyString
 import org.mockito.Mockito.verify
@@ -18,10 +20,7 @@ import org.mockito.Mockito.verify
 /**
  * Unit test for [CreateSonePage].
  */
-class CreateSonePageTest: WebPageTest() {
-
-       private val page = CreateSonePage(template, webInterface)
-       override fun getPage() = page
+class CreateSonePageTest : WebPageTest(::CreateSonePage) {
 
        private val localSones_ = listOf(
                        createSone("local-sone1"),
@@ -85,7 +84,7 @@ class CreateSonePageTest: WebPageTest() {
        @Test
        fun `sone is created and logged in`() {
                addExistingOwnIdentities()
-               request("", POST)
+               setMethod(POST)
                addHttpRequestPart("identity", "own-id-3")
                val newSone = mock<Sone>()
                whenever(core.createSone(ownIdentities_[2])).thenReturn(newSone)
@@ -96,7 +95,7 @@ class CreateSonePageTest: WebPageTest() {
 
        @Test
        fun `on invalid identity id a flag is set in the template context`() {
-               request("", POST)
+               setMethod(POST)
                addHttpRequestParameter("identity", "own-id-3")
                page.processTemplate(freenetRequest, templateContext)
                assertThat(templateContext["errorNoIdentity"], equalTo<Any>(true))
@@ -105,7 +104,7 @@ class CreateSonePageTest: WebPageTest() {
        @Test
        fun `if sone is not created user is still redirected to index`() {
                addExistingOwnIdentities()
-               request("", POST)
+               setMethod(POST)
                addHttpRequestPart("identity", "own-id-3")
                whenever(core.createSone(ownIdentities_[2])).thenReturn(null)
                verifyRedirect("index.html") {
@@ -116,7 +115,7 @@ class CreateSonePageTest: WebPageTest() {
 
        @Test
        fun `create sone is not shown in menu if full access is required but client doesn’t have full access`() {
-               core.preferences.isRequireFullAccess = true
+               core.preferences.newRequireFullAccess = true
                assertThat(page.isEnabled(toadletContext), equalTo(false))
        }
 
@@ -141,10 +140,25 @@ class CreateSonePageTest: WebPageTest() {
 
        @Test
        fun `create sone is shown in menu if no sone is logged in and client has full access`() {
-               core.preferences.isRequireFullAccess = true
+               core.preferences.newRequireFullAccess = true
                whenever(toadletContext.isAllowedFullAccess).thenReturn(true)
                unsetCurrentSone()
                assertThat(page.isEnabled(toadletContext), equalTo(true))
        }
 
+       @Test
+       fun `page can be created by dependency injection`() {
+               assertThat(baseInjector.getInstance<CreateSonePage>(), notNullValue())
+       }
+
+       @Test
+       fun `page is annotated with the correct menuname`() {
+           assertThat(page.menuName, equalTo("CreateSone"))
+       }
+
+       @Test
+       fun `page is annotated with the correct template path`() {
+           assertThat(page.templatePath, equalTo("/templates/createSone.html"))
+       }
+
 }