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)
@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<Any>(field))
@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")
@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") {
@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") {
@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")
assertThat(templateContext["duplicateFieldName"], equalTo<Any>(true))
}
+ @Test
+ fun `page can be created by dependency injection`() {
+ assertThat(baseInjector.getInstance<EditProfileFieldPage>(), notNullValue())
+ }
+
+ @Test
+ fun `page is annotated with correct template path`() {
+ assertThat(page.templatePath, equalTo("/templates/editProfileField.html"))
+ }
+
}