package net.pterodactylus.sone.web.pages import net.pterodactylus.sone.data.Profile import net.pterodactylus.sone.test.getInstance import net.pterodactylus.sone.test.whenever import net.pterodactylus.sone.web.baseInjector import net.pterodactylus.util.web.Method.POST import org.hamcrest.MatcherAssert.assertThat import org.hamcrest.Matchers.equalTo import org.hamcrest.Matchers.notNullValue 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(::EditProfileFieldPage) { private val profile = Profile(currentSone) private val field = profile.addField("Name") @Before fun setupProfile() { whenever(currentSone.profile).thenReturn(profile) } @Test fun `page returns correct path`() { assertThat(page.path, equalTo("editProfileField.html")) } @Test fun `page requires login`() { assertThat(page.requiresLogin(), equalTo(true)) } @Test fun `page returns correct title`() { whenever(l10n.getString("Page.EditProfileField.Title")).thenReturn("edit profile field title") assertThat(page.getPageTitle(soneRequest), equalTo("edit profile field title")) } @Test fun `get request with invalid field redirects to invalid page`() { verifyRedirect("invalid.html") } @Test fun `get request with valid field stores field in template context`() { addHttpRequestParameter("field", field.id) page.processTemplate(freenetRequest, templateContext) assertThat(templateContext["field"], equalTo(field)) } @Test fun `post request with cancel set redirects to profile edit page`() { setMethod(POST) addHttpRequestPart("field", field.id) addHttpRequestPart("cancel", "true") verifyRedirect("editProfile.html#profile-fields") } @Test fun `post request with new name renames field and redirects to profile edit page`() { setMethod(POST) addHttpRequestPart("field", field.id) addHttpRequestPart("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`() { setMethod(POST) addHttpRequestPart("field", field.id) addHttpRequestPart("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`() { setMethod(POST) profile.addField("New Name") addHttpRequestPart("field", field.id) addHttpRequestPart("name", "New Name") page.processTemplate(freenetRequest, templateContext) assertThat(field.name, equalTo("Name")) verify(currentSone, never()).profile = profile assertThat(templateContext["duplicateFieldName"], equalTo(true)) } @Test fun `page can be created by dependency injection`() { assertThat(baseInjector.getInstance(), notNullValue()) } }