X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FEditProfileFieldPageTest.kt;h=4a84644934f0012b57a713b1aa8b5e2baea8cec5;hp=78b27b70e2f40773720b4f88ee4a0875577875ff;hb=HEAD;hpb=05fb821e72072bde52f383bdc5a988da67f66d0c diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt index 78b27b7..4a84644 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfileFieldPageTest.kt @@ -1,30 +1,23 @@ 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 +import net.pterodactylus.sone.data.* +import net.pterodactylus.sone.test.* +import net.pterodactylus.sone.web.* +import net.pterodactylus.sone.web.page.* +import net.pterodactylus.util.web.Method.* +import org.hamcrest.MatcherAssert.* +import org.hamcrest.Matchers.* +import org.junit.* +import org.mockito.Mockito.* /** * Unit test for [EditProfileFieldPage]. */ -class EditProfileFieldPageTest : WebPageTest() { - - private val page = EditProfileFieldPage(template, webInterface) +class EditProfileFieldPageTest : WebPageTest(::EditProfileFieldPage) { private val profile = Profile(currentSone) private val field = profile.addField("Name") - override fun getPage() = page - @Before fun setupProfile() { whenever(currentSone.profile).thenReturn(profile) @@ -32,29 +25,27 @@ class EditProfileFieldPageTest : WebPageTest() { @Test fun `page returns correct path`() { - assertThat(page.path, equalTo("editProfileField.html")) + assertThat(page.path, equalTo("editProfileField.html")) } @Test fun `page requires login`() { - assertThat(page.requiresLogin(), equalTo(true)) + 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(freenetRequest), equalTo("edit profile field title")) + addTranslation("Page.EditProfileField.Title", "edit profile field title") + assertThat(page.getPageTitle(soneRequest), equalTo("edit profile field title")) } @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.processTemplate(freenetRequest, templateContext) assertThat(templateContext["field"], equalTo(field)) @@ -62,7 +53,7 @@ class EditProfileFieldPageTest : WebPageTest() { @Test fun `post request with cancel set redirects to profile edit page`() { - request("", POST) + setMethod(POST) addHttpRequestPart("field", field.id) addHttpRequestPart("cancel", "true") verifyRedirect("editProfile.html#profile-fields") @@ -70,7 +61,7 @@ class EditProfileFieldPageTest : WebPageTest() { @Test fun `post request with new name renames field and redirects to profile edit page`() { - request("", POST) + setMethod(POST) addHttpRequestPart("field", field.id) addHttpRequestPart("name", "New Name") verifyRedirect("editProfile.html#profile-fields") { @@ -81,7 +72,7 @@ class EditProfileFieldPageTest : WebPageTest() { @Test fun `post request with same name does not modify field and redirects to profile edit page`() { - request("", POST) + setMethod(POST) addHttpRequestPart("field", field.id) addHttpRequestPart("name", "Name") verifyRedirect("editProfile.html#profile-fields") { @@ -92,7 +83,7 @@ class EditProfileFieldPageTest : WebPageTest() { @Test fun `post request with same name as different field sets error condition in template`() { - request("", POST) + setMethod(POST) profile.addField("New Name") addHttpRequestPart("field", field.id) addHttpRequestPart("name", "New Name") @@ -102,4 +93,14 @@ class EditProfileFieldPageTest : WebPageTest() { assertThat(templateContext["duplicateFieldName"], equalTo(true)) } + @Test + fun `page can be created by dependency injection`() { + assertThat(baseInjector.getInstance(), notNullValue()) + } + + @Test + fun `page is annotated with correct template path`() { + assertThat(page.templatePath, equalTo("/templates/editProfileField.html")) + } + }