X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FEditProfileFieldPageTest.kt;fp=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FEditProfileFieldPageTest.kt;h=cbe12897515c26f623cf6c6bd661ce7f3bab6a01;hb=de7568a82eb4150bf6d2b0553841b7b69f84c968;hp=0000000000000000000000000000000000000000;hpb=9acbc5bdec4ccb752e0856a501568b0bb6161579;p=Sone.git diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt new file mode 100644 index 0000000..cbe1289 --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt @@ -0,0 +1,89 @@ +package net.pterodactylus.sone.web.pages + +import net.pterodactylus.sone.data.Profile +import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.web.pages.EditProfileFieldPage +import net.pterodactylus.sone.web.pages.WebPageTest +import net.pterodactylus.util.web.Method.GET +import net.pterodactylus.util.web.Method.POST +import org.hamcrest.MatcherAssert.assertThat +import org.hamcrest.Matchers.equalTo +import org.junit.Before +import org.junit.Test +import org.mockito.Mockito.never +import org.mockito.Mockito.verify + +/** + * Unit test for [EditProfileFieldPage]. + */ +class EditProfileFieldPageTest : WebPageTest() { + + private val page = EditProfileFieldPage(template, webInterface) + + private val profile = Profile(currentSone) + private val field = profile.addField("Name") + + override fun getPage() = page + + @Before + fun setupProfile() { + whenever(currentSone.profile).thenReturn(profile) + } + + @Test + fun `get request with invalid field redirects to invalid page`() { + request("", GET) + verifyRedirect("invalid.html") + } + + @Test + fun `get request with valid field stores field in template context`() { + request("", GET) + addHttpRequestParameter("field", field.id) + page.handleRequest(freenetRequest, templateContext) + assertThat(templateContext["field"], equalTo(field)) + } + + @Test + fun `post request with cancel set redirects to profile edit page`() { + request("", POST) + addHttpRequestParameter("field", field.id) + addHttpRequestParameter("cancel", "true") + verifyRedirect("editProfile.html#profile-fields") + } + + @Test + fun `post request with new name renames field and redirects to profile edit page`() { + request("", POST) + addHttpRequestParameter("field", field.id) + addHttpRequestParameter("name", "New Name") + verifyRedirect("editProfile.html#profile-fields") { + assertThat(field.name, equalTo("New Name")) + verify(currentSone).profile = profile + } + } + + @Test + fun `post request with same name does not modify field and redirects to profile edit page`() { + request("", POST) + addHttpRequestParameter("field", field.id) + addHttpRequestParameter("name", "Name") + verifyRedirect("editProfile.html#profile-fields") { + assertThat(field.name, equalTo("Name")) + verify(currentSone, never()).profile = profile + } + } + + @Test + fun `post request with same name as different field sets error condition in template`() { + request("", POST) + profile.addField("New Name") + addHttpRequestParameter("field", field.id) + addHttpRequestParameter("name", "New Name") + page.handleRequest(freenetRequest, templateContext) + assertThat(field.name, equalTo("Name")) + verify(currentSone, never()).profile = profile + assertThat(templateContext["duplicateFieldName"], equalTo(true)) + } + +}