import net.pterodactylus.sone.core.SoneRescuer
import net.pterodactylus.sone.test.mock
import net.pterodactylus.sone.test.whenever
-import net.pterodactylus.sone.web.pages.RescuePage
-import net.pterodactylus.util.web.Method.GET
import net.pterodactylus.util.web.Method.POST
import org.hamcrest.MatcherAssert.assertThat
import org.hamcrest.Matchers.equalTo
/**
* Unit test for [RescuePage].
*/
-class RescuePageTest : WebPageTest() {
-
- private val page = RescuePage(template, webInterface)
+class RescuePageTest: WebPageTest2(::RescuePage) {
private val soneRescuer = mock<SoneRescuer>()
- override fun getPage() = page
-
@Before
fun setupSoneRescuer() {
whenever(core.getSoneRescuer(currentSone)).thenReturn(soneRescuer)
}
@Test
+ fun `page returns correct path`() {
+ assertThat(page.path, equalTo("rescue.html"))
+ }
+
+ @Test
+ fun `page requires login`() {
+ assertThat(page.requiresLogin(), equalTo(true))
+ }
+
+ @Test
+ fun `page returns correct title`() {
+ addTranslation("Page.Rescue.Title", "rescue page title")
+ assertThat(page.getPageTitle(freenetRequest), equalTo("rescue page title"))
+ }
+
+ @Test
fun `get request sets rescuer in template context`() {
- request("", GET)
- page.handleRequest(freenetRequest, templateContext)
- assertThat(templateContext["soneRescuer"], equalTo<Any>(soneRescuer))
+ verifyNoRedirect {
+ assertThat(templateContext["soneRescuer"], equalTo<Any>(soneRescuer))
+ }
}
@Test
fun `post request redirects to rescue page`() {
- request("", POST)
+ setMethod(POST)
verifyRedirect("rescue.html")
}
@Test
fun `post request with fetch and invalid edition starts next fetch`() {
- request("", POST)
- addHttpRequestParameter("fetch", "true")
+ setMethod(POST)
+ addHttpRequestPart("fetch", "true")
verifyRedirect("rescue.html") {
verify(soneRescuer, never()).setEdition(anyLong())
verify(soneRescuer).startNextFetch()
@Test
fun `post request with fetch and valid edition sets edition and starts next fetch`() {
- request("", POST)
- addHttpRequestParameter("fetch", "true")
- addHttpRequestParameter("edition", "123")
+ setMethod(POST)
+ addHttpRequestPart("fetch", "true")
+ addHttpRequestPart("edition", "123")
verifyRedirect("rescue.html") {
verify(soneRescuer).setEdition(123L)
verify(soneRescuer).startNextFetch()
}
}
+ @Test
+ fun `post request with negative edition will not set edition`() {
+ setMethod(POST)
+ addHttpRequestPart("fetch", "true")
+ addHttpRequestPart("edition", "-123")
+ verifyRedirect("rescue.html") {
+ verify(soneRescuer, never()).setEdition(anyLong())
+ verify(soneRescuer).startNextFetch()
+ }
+ }
+
}