Remove obsolete loading animation
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / DeleteReplyPageTest.kt
1 package net.pterodactylus.sone.web
2
3 import net.pterodactylus.sone.data.PostReply
4 import net.pterodactylus.sone.data.Sone
5 import net.pterodactylus.sone.test.mock
6 import net.pterodactylus.sone.test.whenever
7 import net.pterodactylus.util.web.Method.GET
8 import net.pterodactylus.util.web.Method.POST
9 import org.hamcrest.MatcherAssert.assertThat
10 import org.hamcrest.Matchers.equalTo
11 import org.junit.Before
12 import org.junit.Test
13 import org.mockito.Mockito.never
14 import org.mockito.Mockito.verify
15
16 /**
17  * Unit test for [DeleteReplyPage].
18  */
19 class DeleteReplyPageTest : WebPageTest() {
20
21         private val page = DeleteReplyPage(template, webInterface)
22
23         private val sone = mock<Sone>()
24         private val reply = mock<PostReply>()
25
26         override fun getPage() = page
27
28         @Before
29         fun setupReply() {
30                 whenever(sone.isLocal).thenReturn(true)
31                 whenever(reply.sone).thenReturn(sone)
32         }
33
34         @Test
35         fun `page returns correct path`() {
36             assertThat(page.path, equalTo("deleteReply.html"))
37         }
38
39         @Test
40         fun `page requires login`() {
41             assertThat(page.requiresLogin(), equalTo(true))
42         }
43
44         @Test
45         fun `get request sets reply ID and return page in template context`() {
46                 request("", GET)
47                 addHttpRequestParameter("reply", "reply-id")
48                 addHttpRequestParameter("returnPage", "return.html")
49                 page.processTemplate(freenetRequest, templateContext)
50                 assertThat(templateContext["reply"], equalTo<Any>("reply-id"))
51                 assertThat(templateContext["returnPage"], equalTo<Any>("return.html"))
52         }
53
54         @Test
55         fun `post request without any action sets reply ID and return page in template context`() {
56                 request("", POST)
57                 addPostReply("reply-id", reply)
58                 addHttpRequestParameter("reply", "reply-id")
59                 addHttpRequestParameter("returnPage", "return.html")
60                 page.processTemplate(freenetRequest, templateContext)
61                 assertThat(templateContext["reply"], equalTo<Any>("reply-id"))
62                 assertThat(templateContext["returnPage"], equalTo<Any>("return.html"))
63         }
64
65         @Test
66         fun `trying to delete a reply with an invalid ID results in no permission page`() {
67                 request("", POST)
68                 verifyRedirect("noPermission.html")
69         }
70
71         @Test
72         fun `trying to delete a reply from a non-local sone results in no permission page`() {
73                 request("", POST)
74                 addHttpRequestParameter("reply", "reply-id")
75                 whenever(sone.isLocal).thenReturn(false)
76                 addPostReply("reply-id", reply)
77                 verifyRedirect("noPermission.html")
78         }
79
80         @Test
81         fun `confirming deletion of reply deletes the reply and redirects to return page`() {
82                 request("", POST)
83                 addPostReply("reply-id", reply)
84                 addHttpRequestParameter("reply", "reply-id")
85                 addHttpRequestParameter("returnPage", "return.html")
86                 addHttpRequestParameter("confirmDelete", "true")
87                 verifyRedirect("return.html") {
88                         verify(core).deleteReply(reply)
89                 }
90         }
91
92         @Test
93         fun `aborting deletion of reply redirects to return page`() {
94                 request("", POST)
95                 addPostReply("reply-id", reply)
96                 addHttpRequestParameter("reply", "reply-id")
97                 addHttpRequestParameter("returnPage", "return.html")
98                 addHttpRequestParameter("abortDelete", "true")
99                 verifyRedirect("return.html") {
100                         verify(core, never()).deleteReply(reply)
101                 }
102         }
103
104 }