X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FEditProfilePageTest.kt;h=be34861518ec6262de59739ab3542a738e2a3d25;hp=fd03d0a44d2cde71a4081987ac44e1c8551fbbfc;hb=bce70170ce5ddaa142e67fcc67985215e1eadac2;hpb=6b29b49714912ff5e3e410d2484699cdf8041b90 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfilePageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfilePageTest.kt index fd03d0a..be34861 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfilePageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/EditProfilePageTest.kt @@ -2,10 +2,11 @@ package net.pterodactylus.sone.web.pages import net.pterodactylus.sone.data.Image import net.pterodactylus.sone.data.Profile +import net.pterodactylus.sone.test.getInstance import net.pterodactylus.sone.test.mock import net.pterodactylus.sone.test.whenever -import net.pterodactylus.sone.web.pages.EditProfilePage -import net.pterodactylus.sone.web.pages.WebPageTest +import net.pterodactylus.sone.web.baseInjector +import net.pterodactylus.sone.web.page.* import net.pterodactylus.util.web.Method.POST import org.hamcrest.MatcherAssert.assertThat import org.hamcrest.Matchers.contains @@ -19,16 +20,12 @@ import org.mockito.Mockito.verify /** * Unit test for [EditProfilePage]. */ -class EditProfilePageTest : WebPageTest() { - - private val page = EditProfilePage(template, webInterface) +class EditProfilePageTest: WebPageTest(::EditProfilePage) { private val profile = Profile(currentSone) private val firstField = profile.addField("First Field") private val secondField = profile.addField("Second Field") - override fun getPage() = page - @Before fun setupProfile() { val avatar = mock() @@ -57,7 +54,7 @@ class EditProfilePageTest : WebPageTest() { @Test fun `page returns correct title`() { whenever(l10n.getString("Page.EditProfile.Title")).thenReturn("edit profile page title") - assertThat(page.getPageTitle(freenetRequest), equalTo("edit profile page title")) + assertThat(page.getPageTitle(soneRequest), equalTo("edit profile page title")) } @Test @@ -92,6 +89,7 @@ class EditProfilePageTest : WebPageTest() { addHttpRequestPart("save-profile", "true") addHttpRequestPart(fieldName, newValue.toString()) verifyRedirect("editProfile.html") { + verify(currentSone).profile = profile verify(core).touchConfiguration() assertThat(fieldAccessor(), equalTo(expectedValue)) } @@ -223,4 +221,19 @@ class EditProfilePageTest : WebPageTest() { verifyRedirect("editProfileField.html?field=${firstField.id}") } + @Test + fun `page can be created by dependency injection`() { + assertThat(baseInjector.getInstance(), notNullValue()) + } + + @Test + fun `page is annotated with correct menuname`() { + assertThat(page.menuName, equalTo("EditProfile")) + } + + @Test + fun `page is annotated with correct template path`() { + assertThat(page.templatePath, equalTo("/templates/editProfile.html")) + } + }