From 47c6bfa7ff59256ce9d4813d7f7a4d965de5bd32 Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20=E2=80=98Bombe=E2=80=99=20Roden?= Date: Fri, 25 Nov 2016 20:09:54 +0100 Subject: [PATCH] Add unit test for distrust page --- .../net/pterodactylus/sone/web/DistrustPageTest.kt | 49 ++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt diff --git a/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt new file mode 100644 index 0000000..a0766ba --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/DistrustPageTest.kt @@ -0,0 +1,49 @@ +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.util.web.Method.GET +import net.pterodactylus.util.web.Method.POST +import org.junit.Test +import org.mockito.Mockito +import org.mockito.Mockito.verify + +/** + * Unit test for [DistrustPage]. + */ +class DistrustPageTest : WebPageTest() { + + private val page = DistrustPage(template, webInterface) + + @Test + fun `get request does not redirect`() { + request("", GET) + page.handleRequest(freenetRequest, templateContext) + } + + @Test + fun `post request with invalid sone redirects to return page`() { + request("", POST) + addHttpRequestParameter("returnPage", "return.html") + expectedException.expect(redirectsTo("return.html")) + page.handleRequest(freenetRequest, templateContext) + } + + @Test + fun `post request with valid sone distrusts sone and redirects to return page`() { + 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 { + verify(core).distrustSone(currentSone, remoteSone) + } + } + +} -- 2.7.4