From 8846e3e03fd7252c5c9b01ff9463f2b591174f68 Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20=E2=80=98Bombe=E2=80=99=20Roden?= Date: Mon, 2 Oct 2017 11:42:40 +0200 Subject: [PATCH] Add unit test for move profile field ajax page --- .../sone/web/ajax/MoveProfileFieldAjaxPageTest.kt | 69 ++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 src/test/kotlin/net/pterodactylus/sone/web/ajax/MoveProfileFieldAjaxPageTest.kt diff --git a/src/test/kotlin/net/pterodactylus/sone/web/ajax/MoveProfileFieldAjaxPageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/ajax/MoveProfileFieldAjaxPageTest.kt new file mode 100644 index 0000000..7524eaa --- /dev/null +++ b/src/test/kotlin/net/pterodactylus/sone/web/ajax/MoveProfileFieldAjaxPageTest.kt @@ -0,0 +1,69 @@ +package net.pterodactylus.sone.web.ajax + +import org.hamcrest.MatcherAssert.assertThat +import org.hamcrest.Matchers.equalTo +import org.junit.Test +import org.mockito.Mockito.verify + +/** + * Unit test for [MoveProfileFieldAjaxPage]. + */ +class MoveProfileFieldAjaxPageTest : JsonPageTest("moveProfileField.ajax", true, true, ::MoveProfileFieldAjaxPage) { + + @Test + fun `request without field id results in invalid-field-id`() { + assertThat(json.isSuccess, equalTo(false)) + assertThat(json.error, equalTo("invalid-field-id")) + } + + @Test + fun `request with invalid direction results in invalid-direction`() { + val fieldId = profile.addField("someField").id + addRequestParameter("field", fieldId) + assertThat(json.isSuccess, equalTo(false)) + assertThat(json.error, equalTo("invalid-direction")) + } + + @Test + fun `moving first field up results in not-possible`() { + val fieldId = profile.addField("someField").id + addRequestParameter("field", fieldId) + addRequestParameter("direction", "up") + assertThat(json.isSuccess, equalTo(false)) + assertThat(json.error, equalTo("not-possible")) + } + + @Test + fun `moving only field down results in not-possible`() { + val fieldId = profile.addField("someField").id + addRequestParameter("field", fieldId) + addRequestParameter("direction", "down") + assertThat(json.isSuccess, equalTo(false)) + assertThat(json.error, equalTo("not-possible")) + } + + @Test + fun `moving second field up results in field being moved up`() { + profile.addField("firstField") + val fieldId = profile.addField("someField").id + addRequestParameter("field", fieldId) + addRequestParameter("direction", "up") + assertThat(json.isSuccess, equalTo(true)) + assertThat(profile.fields[0].id, equalTo(fieldId)) + verify(core).touchConfiguration() + verify(currentSone).profile = profile + } + + @Test + fun `moving first field down results in field being moved down`() { + val fieldId = profile.addField("someField").id + profile.addField("firstField") + addRequestParameter("field", fieldId) + addRequestParameter("direction", "down") + assertThat(json.isSuccess, equalTo(true)) + assertThat(profile.fields.last().id, equalTo(fieldId)) + verify(core).touchConfiguration() + verify(currentSone).profile = profile + } + +} -- 2.7.4