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 [TrustPage].
17 class TrustPageTest : WebPageTest() {
19 private val page = TrustPage(template, webInterface)
21 override fun getPage() = page
24 fun `page returns correct path`() {
25 assertThat(page.path, equalTo("trust.html"))
29 fun `page requires login`() {
30 assertThat(page.requiresLogin(), equalTo(true))
34 fun `page returns correct title`() {
35 addTranslation("Page.Trust.Title", "title trust page")
36 assertThat(page.getPageTitle(freenetRequest), equalTo("title trust page"))
40 fun `get method does not redirect`() {
45 fun `post request without sone redirects to return page`() {
47 addHttpRequestPart("returnPage", "return.html")
48 verifyRedirect("return.html") {
49 verify(core, never()).trustSone(eq(currentSone), any())
54 fun `post request with missing sone redirects to return page`() {
56 addHttpRequestPart("returnPage", "return.html")
57 addHttpRequestPart("sone", "sone-id")
58 verifyRedirect("return.html") {
59 verify(core, never()).trustSone(eq(currentSone), any())
64 fun `post request with existing sone trusts the identity and redirects to return page`() {
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))