Remove obsolete loading animation
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / EditProfileFieldPageTest.kt
1 package net.pterodactylus.sone.web
2
3 import net.pterodactylus.sone.data.Profile
4 import net.pterodactylus.sone.test.whenever
5 import net.pterodactylus.util.web.Method.GET
6 import net.pterodactylus.util.web.Method.POST
7 import org.hamcrest.MatcherAssert.assertThat
8 import org.hamcrest.Matchers.equalTo
9 import org.junit.Before
10 import org.junit.Test
11 import org.mockito.Mockito.never
12 import org.mockito.Mockito.verify
13
14 /**
15  * Unit test for [EditProfileFieldPage].
16  */
17 class EditProfileFieldPageTest : WebPageTest() {
18
19         private val page = EditProfileFieldPage(template, webInterface)
20
21         private val profile = Profile(currentSone)
22         private val field = profile.addField("Name")
23
24         override fun getPage() = page
25
26         @Before
27         fun setupProfile() {
28                 whenever(currentSone.profile).thenReturn(profile)
29         }
30
31         @Test
32         fun `get request with invalid field redirects to invalid page`() {
33                 request("", GET)
34                 verifyRedirect("invalid.html")
35         }
36
37         @Test
38         fun `get request with valid field stores field in template context`() {
39                 request("", GET)
40                 addHttpRequestParameter("field", field.id)
41                 page.handleRequest(freenetRequest, templateContext)
42                 assertThat(templateContext["field"], equalTo<Any>(field))
43         }
44
45         @Test
46         fun `post request with cancel set redirects to profile edit page`() {
47                 request("", POST)
48                 addHttpRequestParameter("field", field.id)
49                 addHttpRequestParameter("cancel", "true")
50                 verifyRedirect("editProfile.html#profile-fields")
51         }
52
53         @Test
54         fun `post request with new name renames field and redirects to profile edit page`() {
55                 request("", POST)
56                 addHttpRequestParameter("field", field.id)
57                 addHttpRequestParameter("name", "New Name")
58                 verifyRedirect("editProfile.html#profile-fields") {
59                         assertThat(field.name, equalTo("New Name"))
60                         verify(currentSone).profile = profile
61                 }
62         }
63
64         @Test
65         fun `post request with same name does not modify field and redirects to profile edit page`() {
66                 request("", POST)
67                 addHttpRequestParameter("field", field.id)
68                 addHttpRequestParameter("name", "Name")
69                 verifyRedirect("editProfile.html#profile-fields") {
70                         assertThat(field.name, equalTo("Name"))
71                         verify(currentSone, never()).profile = profile
72                 }
73         }
74
75         @Test
76         fun `post request with same name as different field sets error condition in template`() {
77                 request("", POST)
78                 profile.addField("New Name")
79                 addHttpRequestParameter("field", field.id)
80                 addHttpRequestParameter("name", "New Name")
81                 page.handleRequest(freenetRequest, templateContext)
82                 assertThat(field.name, equalTo("Name"))
83                 verify(currentSone, never()).profile = profile
84                 assertThat(templateContext["duplicateFieldName"], equalTo<Any>(true))
85         }
86
87 }