package net.pterodactylus.sone.web.pages
import net.pterodactylus.sone.data.Sone
+import net.pterodactylus.sone.test.getInstance
import net.pterodactylus.sone.test.mock
+import net.pterodactylus.sone.web.baseInjector
+import net.pterodactylus.util.web.Method.POST
import org.hamcrest.MatcherAssert.assertThat
import org.hamcrest.Matchers.equalTo
+import org.hamcrest.Matchers.notNullValue
import org.junit.Test
import org.mockito.ArgumentMatchers.any
import org.mockito.Mockito.never
/**
* Unit test for [LockSonePage].
*/
-class LockSonePageTest : WebPageTest() {
-
- private val page = LockSonePage(template, webInterface)
-
- override fun getPage() = page
+class LockSonePageTest: WebPageTest(::LockSonePage) {
@Test
fun `page returns correct path`() {
}
@Test
- fun `page requires login`() {
+ fun `page does not require login`() {
assertThat(page.requiresLogin(), equalTo(false))
}
@Test
fun `locking an invalid local sone redirects to return page`() {
+ setMethod(POST)
addHttpRequestPart("returnPage", "return.html")
verifyRedirect("return.html") {
verify(core, never()).lockSone(any<Sone>())
@Test
fun `locking an valid local sone locks the sone and redirects to return page`() {
+ setMethod(POST)
addHttpRequestPart("sone", "sone-id")
val sone = mock<Sone>()
addLocalSone("sone-id", sone)
}
}
+ @Test
+ fun `page can be created by dependency injection`() {
+ assertThat(baseInjector.getInstance<LockSonePage>(), notNullValue())
+ }
+
}