1 package net.pterodactylus.sone.web.pages
3 import net.pterodactylus.sone.data.Sone
4 import net.pterodactylus.sone.test.mock
5 import net.pterodactylus.util.web.Method.POST
6 import org.hamcrest.MatcherAssert.assertThat
7 import org.hamcrest.Matchers.equalTo
9 import org.mockito.ArgumentMatchers.any
10 import org.mockito.ArgumentMatchers.eq
11 import org.mockito.Mockito.never
12 import org.mockito.Mockito.verify
15 * Unit test for [UntrustPage].
17 class UntrustPageTest : WebPageTest() {
19 private val page = UntrustPage(template, webInterface)
21 override fun getPage() = page
24 fun `page returns correct path`() {
25 assertThat(page.path, equalTo("untrust.html"))
29 fun `page requires login`() {
30 assertThat(page.requiresLogin(), equalTo(true))
34 fun `page returns correct title`() {
35 addTranslation("Page.Untrust.Title", "untrust page title")
36 assertThat(page.getPageTitle(freenetRequest), equalTo("untrust page title"))
40 fun `get request does not redirect`() {
42 verify(core, never()).untrustSone(eq(currentSone), any())
47 fun `post request without sone parameter does not untrust but redirects`() {
49 addHttpRequestPart("returnPage", "return.html")
50 verifyRedirect("return.html") {
51 verify(core, never()).untrustSone(eq(currentSone), any())
56 fun `post request with invalid sone parameter does not untrust but redirects`() {
58 addHttpRequestPart("returnPage", "return.html")
59 addHttpRequestPart("sone", "no-sone")
60 verifyRedirect("return.html") {
61 verify(core, never()).untrustSone(eq(currentSone), any())
66 fun `post request with valid sone parameter untrusts and redirects`() {
68 addHttpRequestPart("returnPage", "return.html")
69 addHttpRequestPart("sone", "sone-id")
70 val sone = mock<Sone>()
71 addSone("sone-id", sone)
72 verifyRedirect("return.html") {
73 verify(core).untrustSone(currentSone, sone)