}
@Test
+ fun `page returns correct path`() {
+ assertThat(page.path, equalTo("editProfile.html"))
+ }
+
+ @Test
+ fun `page requires login`() {
+ assertThat(page.requiresLogin(), equalTo(true))
+ }
+
+ @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"))
+ }
+
+ @Test
fun `get request stores fields of current sone’s profile in template context`() {
request("", GET)
- page.handleRequest(freenetRequest, templateContext)
+ page.processTemplate(freenetRequest, templateContext)
assertThat(templateContext["firstName"], equalTo<Any>("First"))
assertThat(templateContext["middleName"], equalTo<Any>("Middle"))
assertThat(templateContext["lastName"], equalTo<Any>("Last"))
@Test
fun `post request without any command stores fields of current sone’s profile in template context`() {
request("", POST)
- page.handleRequest(freenetRequest, templateContext)
+ page.processTemplate(freenetRequest, templateContext)
assertThat(templateContext["firstName"], equalTo<Any>("First"))
assertThat(templateContext["middleName"], equalTo<Any>("Middle"))
assertThat(templateContext["lastName"], equalTo<Any>("Last"))
private fun <T> verifySingleFieldCanBeChanged(fieldName: String, newValue: T, expectedValue: T = newValue, fieldAccessor: () -> T) {
request("", POST)
- addHttpRequestParameter("save-profile", "true")
- addHttpRequestParameter(fieldName, newValue.toString())
+ addHttpRequestPart("save-profile", "true")
+ addHttpRequestPart(fieldName, newValue.toString())
verifyRedirect("editProfile.html") {
verify(core).touchConfiguration()
assertThat(fieldAccessor(), equalTo(expectedValue))
fun `adding a field with a duplicate name sets error in template context`() {
request("", POST)
profile.addField("new-field")
- addHttpRequestParameter("add-field", "true")
- addHttpRequestParameter("field-name", "new-field")
- page.handleRequest(freenetRequest, templateContext)
+ addHttpRequestPart("add-field", "true")
+ addHttpRequestPart("field-name", "new-field")
+ page.processTemplate(freenetRequest, templateContext)
assertThat(templateContext["fieldName"], equalTo<Any>("new-field"))
assertThat(templateContext["duplicateFieldName"], equalTo<Any>(true))
verify(core, never()).touchConfiguration()
@Test
fun `adding a field with a new name sets adds field to profile and redirects to profile edit page`() {
request("", POST)
- addHttpRequestParameter("add-field", "true")
- addHttpRequestParameter("field-name", "new-field")
+ addHttpRequestPart("add-field", "true")
+ addHttpRequestPart("field-name", "new-field")
verifyRedirect("editProfile.html#profile-fields") {
assertThat(profile.getFieldByName("new-field"), notNullValue())
verify(currentSone).profile = profile
@Test
fun `deleting a field redirects to delete field page`() {
request("", POST)
- addHttpRequestParameter("delete-field-${firstField.id}", "true")
+ addHttpRequestPart("delete-field-${firstField.id}", "true")
verifyRedirect("deleteProfileField.html?field=${firstField.id}")
}
@Test
fun `moving a field up moves the field up and redirects to the edit profile page`() {
request("", POST)
- addHttpRequestParameter("move-up-field-${secondField.id}", "true")
+ addHttpRequestPart("move-up-field-${secondField.id}", "true")
verifyRedirect("editProfile.html#profile-fields") {
assertThat(profile.fields, contains(secondField, firstField))
verify(currentSone).profile = profile
}
@Test
- fun `moving an invalid field up redirects to the invalid page`() {
+ fun `moving an invalid field up does not redirect`() {
request("", POST)
- addHttpRequestParameter("move-up-field-foo", "true")
- verifyRedirect("invalid.html")
+ addHttpRequestPart("move-up-field-foo", "true")
+ page.processTemplate(freenetRequest, templateContext)
}
@Test
fun `moving a field down moves the field down and redirects to the edit profile page`() {
request("", POST)
- addHttpRequestParameter("move-down-field-${firstField.id}", "true")
+ addHttpRequestPart("move-down-field-${firstField.id}", "true")
verifyRedirect("editProfile.html#profile-fields") {
assertThat(profile.fields, contains(secondField, firstField))
verify(currentSone).profile = profile
}
@Test
- fun `moving an invalid field down redirects to the invalid page`() {
+ fun `moving an invalid field down does not redirect`() {
request("", POST)
- addHttpRequestParameter("move-down-field-foo", "true")
- verifyRedirect("invalid.html")
+ addHttpRequestPart("move-down-field-foo", "true")
+ page.processTemplate(freenetRequest, templateContext)
}
@Test
fun `editing a field redirects to the edit profile page`() {
request("", POST)
- addHttpRequestParameter("edit-field-${firstField.id}", "true")
+ addHttpRequestPart("edit-field-${firstField.id}", "true")
verifyRedirect("editProfileField.html?field=${firstField.id}")
}