package net.pterodactylus.sone.web import net.pterodactylus.sone.data.Profile import net.pterodactylus.sone.test.whenever 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)) } }