X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FDeletePostPageTest.kt;h=e6f386a7b488711cea1e84870f520a46a1a54649;hp=152e70dec595633eb267e54cea64f6f98b5a8f49;hb=110a933c2724aba6a604fc5eed6372ff1e1e6144;hpb=de7568a82eb4150bf6d2b0553841b7b69f84c968 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/DeletePostPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/DeletePostPageTest.kt index 152e70d..e6f386a 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/pages/DeletePostPageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/DeletePostPageTest.kt @@ -2,14 +2,15 @@ package net.pterodactylus.sone.web.pages import net.pterodactylus.sone.data.Post import net.pterodactylus.sone.data.Sone +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.DeletePostPage -import net.pterodactylus.util.web.Method.GET +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.equalTo +import org.hamcrest.Matchers.notNullValue import org.junit.Before import org.junit.Test import org.mockito.Mockito.never @@ -18,15 +19,11 @@ import org.mockito.Mockito.verify /** * Unit test for [DeletePostPage]. */ -class DeletePostPageTest : WebPageTest() { - - private val page = DeletePostPage(template, webInterface) +class DeletePostPageTest: WebPageTest(::DeletePostPage) { private val post = mock() private val sone = mock() - override fun getPage() = page - @Before fun setupPost() { whenever(post.sone).thenReturn(sone) @@ -45,13 +42,11 @@ class DeletePostPageTest : WebPageTest() { @Test fun `get request with invalid post redirects to no permission page`() { - request("", GET) verifyRedirect("noPermission.html") } @Test fun `get request with valid post sets post and return page in template context`() { - request("", GET) addPost("post-id", post) addHttpRequestParameter("post", "post-id") addHttpRequestParameter("returnPage", "return.html") @@ -62,27 +57,27 @@ class DeletePostPageTest : WebPageTest() { @Test fun `post request with invalid post redirects to no permission page`() { - request("", POST) + setMethod(POST) verifyRedirect("noPermission.html") } @Test fun `post request with post from non-local sone redirects to no permission page`() { - request("", POST) + setMethod(POST) whenever(sone.isLocal).thenReturn(false) addPost("post-id", post) - addHttpRequestParameter("post", "post-id") - addHttpRequestParameter("returnPage", "return.html") + addHttpRequestPart("post", "post-id") + addHttpRequestPart("returnPage", "return.html") verifyRedirect("noPermission.html") } @Test fun `post request with confirmation deletes post and redirects to return page`() { - request("", POST) + setMethod(POST) addPost("post-id", post) - addHttpRequestParameter("post", "post-id") - addHttpRequestParameter("returnPage", "return.html") - addHttpRequestParameter("confirmDelete", "true") + addHttpRequestPart("post", "post-id") + addHttpRequestPart("returnPage", "return.html") + addHttpRequestPart("confirmDelete", "true") verifyRedirect("return.html") { verify(core).deletePost(post) } @@ -90,11 +85,11 @@ class DeletePostPageTest : WebPageTest() { @Test fun `post request with abort delete does not delete post and redirects to return page`() { - request("", POST) + setMethod(POST) addPost("post-id", post) - addHttpRequestParameter("post", "post-id") - addHttpRequestParameter("returnPage", "return.html") - addHttpRequestParameter("abortDelete", "true") + addHttpRequestPart("post", "post-id") + addHttpRequestPart("returnPage", "return.html") + addHttpRequestPart("abortDelete", "true") verifyRedirect("return.html") { verify(core, never()).deletePost(post) } @@ -102,13 +97,23 @@ class DeletePostPageTest : WebPageTest() { @Test fun `post request without delete or abort sets post in template context`() { - request("", POST) + setMethod(POST) addPost("post-id", post) - addHttpRequestParameter("post", "post-id") - addHttpRequestParameter("returnPage", "return.html") + addHttpRequestPart("post", "post-id") + addHttpRequestPart("returnPage", "return.html") page.processTemplate(freenetRequest, templateContext) assertThat(templateContext["post"], equalTo(post)) assertThat(templateContext["returnPage"], equalTo("return.html")) } + @Test + fun `page can be created by dependency injection`() { + assertThat(baseInjector.getInstance(), notNullValue()) + } + + @Test + fun `page is annotated with correct template path`() { + assertThat(page.templatePath, equalTo("/templates/deletePost.html")) + } + }