Add more tests for trust page
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / TrustPageTest.kt
1 package net.pterodactylus.sone.web.pages
2
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
8 import org.junit.Test
9 import org.mockito.ArgumentMatchers.any
10 import org.mockito.ArgumentMatchers.eq
11 import org.mockito.Mockito.never
12 import org.mockito.Mockito.verify
13
14 /**
15  * Unit test for [TrustPage].
16  */
17 class TrustPageTest : WebPageTest() {
18
19         private val page = TrustPage(template, webInterface)
20
21         override fun getPage() = page
22
23         @Test
24         fun `page returns correct path`() {
25             assertThat(page.path, equalTo("trust.html"))
26         }
27
28         @Test
29         fun `page requires login`() {
30             assertThat(page.requiresLogin(), equalTo(true))
31         }
32
33         @Test
34         fun `page returns correct title`() {
35             addTranslation("Page.Trust.Title", "title trust page")
36                 assertThat(page.getPageTitle(freenetRequest), equalTo("title trust page"))
37         }
38
39         @Test
40         fun `get method does not redirect`() {
41                 verifyNoRedirect { }
42         }
43
44         @Test
45         fun `post request without sone redirects to return page`() {
46                 setMethod(POST)
47                 addHttpRequestPart("returnPage", "return.html")
48                 verifyRedirect("return.html") {
49                         verify(core, never()).trustSone(eq(currentSone), any())
50                 }
51         }
52
53         @Test
54         fun `post request with missing sone redirects to return page`() {
55                 setMethod(POST)
56                 addHttpRequestPart("returnPage", "return.html")
57                 addHttpRequestPart("sone", "sone-id")
58                 verifyRedirect("return.html") {
59                         verify(core, never()).trustSone(eq(currentSone), any())
60                 }
61         }
62
63         @Test
64         fun `post request with existing sone trusts the identity and redirects to return page`() {
65                 setMethod(POST)
66                 addHttpRequestPart("returnPage", "return.html")
67                 addHttpRequestPart("sone", "sone-id")
68                 val sone = mock<Sone>()
69                 addSone("sone-id", sone)
70                 verifyRedirect("return.html") {
71                         verify(core).trustSone(eq(currentSone), eq(sone))
72                 }
73         }
74
75 }