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