X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2FDistrustPageTest.kt;h=8346a7fc14a593d36eeeb2b8cda15afb4402b4b3;hp=a0766ba79f7674a27e0a70ddfbadadcf3a41b24c;hb=9acbc5bdec4ccb752e0856a501568b0bb6161579;hpb=47c6bfa7ff59256ce9d4813d7f7a4d965de5bd32 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt index a0766ba..8346a7f 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt @@ -2,46 +2,60 @@ package net.pterodactylus.sone.web import net.pterodactylus.sone.data.Sone import net.pterodactylus.sone.test.mock -import net.pterodactylus.sone.web.WebTestUtils.redirectsTo -import net.pterodactylus.util.web.Method +import net.pterodactylus.sone.test.whenever import net.pterodactylus.util.web.Method.GET import net.pterodactylus.util.web.Method.POST +import org.hamcrest.MatcherAssert.assertThat +import org.hamcrest.Matchers.equalTo import org.junit.Test -import org.mockito.Mockito import org.mockito.Mockito.verify /** * Unit test for [DistrustPage]. */ -class DistrustPageTest : WebPageTest() { +class DistrustPageTest: WebPageTest() { private val page = DistrustPage(template, webInterface) + override fun getPage() = page + + @Test + fun `page returns correct path`() { + assertThat(page.path, equalTo("distrust.html")) + } + + @Test + fun `page requires login`() { + assertThat(page.requiresLogin(), equalTo(true)) + } + + @Test + fun `page returns correct title`() { + whenever(l10n.getString("Page.Distrust.Title")).thenReturn("distrust page title") + assertThat(page.getPageTitle(freenetRequest), equalTo("distrust page title")) + } + @Test fun `get request does not redirect`() { - request("", GET) - page.handleRequest(freenetRequest, templateContext) + request("", GET) + page.processTemplate(freenetRequest, templateContext) } @Test fun `post request with invalid sone redirects to return page`() { - request("", POST) + request("", POST) addHttpRequestParameter("returnPage", "return.html") - expectedException.expect(redirectsTo("return.html")) - page.handleRequest(freenetRequest, templateContext) + verifyRedirect("return.html") } @Test fun `post request with valid sone distrusts sone and redirects to return page`() { - request("", POST) + request("", POST) val remoteSone = mock() addSone("remote-sone-id", remoteSone) addHttpRequestParameter("returnPage", "return.html") addHttpRequestParameter("sone", "remote-sone-id") - expectedException.expect(redirectsTo("return.html")) - try { - page.handleRequest(freenetRequest, templateContext) - } finally { + verifyRedirect("return.html") { verify(core).distrustSone(currentSone, remoteSone) } }