Remove obsolete loading animation
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / DistrustPageTest.kt
1 package net.pterodactylus.sone.web
2
3 import net.pterodactylus.sone.data.Sone
4 import net.pterodactylus.sone.test.mock
5 import net.pterodactylus.sone.test.whenever
6 import net.pterodactylus.util.web.Method.GET
7 import net.pterodactylus.util.web.Method.POST
8 import org.hamcrest.MatcherAssert.assertThat
9 import org.hamcrest.Matchers.equalTo
10 import org.junit.Test
11 import org.mockito.Mockito.verify
12
13 /**
14  * Unit test for [DistrustPage].
15  */
16 class DistrustPageTest: WebPageTest() {
17
18         private val page = DistrustPage(template, webInterface)
19
20         override fun getPage() = page
21
22         @Test
23         fun `page returns correct path`() {
24                 assertThat(page.path, equalTo("distrust.html"))
25         }
26
27         @Test
28         fun `page requires login`() {
29                 assertThat(page.requiresLogin(), equalTo(true))
30         }
31
32         @Test
33         fun `page returns correct title`() {
34                 whenever(l10n.getString("Page.Distrust.Title")).thenReturn("distrust page title")
35                 assertThat(page.getPageTitle(freenetRequest), equalTo("distrust page title"))
36         }
37
38         @Test
39         fun `get request does not redirect`() {
40                 request("", GET)
41                 page.processTemplate(freenetRequest, templateContext)
42         }
43
44         @Test
45         fun `post request with invalid sone redirects to return page`() {
46                 request("", POST)
47                 addHttpRequestParameter("returnPage", "return.html")
48                 verifyRedirect("return.html")
49         }
50
51         @Test
52         fun `post request with valid sone distrusts sone and redirects to return page`() {
53                 request("", POST)
54                 val remoteSone = mock<Sone>()
55                 addSone("remote-sone-id", remoteSone)
56                 addHttpRequestParameter("returnPage", "return.html")
57                 addHttpRequestParameter("sone", "remote-sone-id")
58                 verifyRedirect("return.html") {
59                         verify(core).distrustSone(currentSone, remoteSone)
60                 }
61         }
62
63 }