package net.pterodactylus.sone.web.pages
-import net.pterodactylus.sone.data.Album
-import net.pterodactylus.sone.data.Sone
-import net.pterodactylus.sone.test.mock
-import net.pterodactylus.sone.test.whenever
-import net.pterodactylus.sone.web.pages.WebPageTest
-import net.pterodactylus.sone.web.pages.DeleteAlbumPage
-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 net.pterodactylus.sone.data.impl.*
+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.ArgumentMatchers.anyString
import org.mockito.Mockito.verify
/**
* Unit test for [DeleteAlbumPage].
*/
-class DeleteAlbumPageTest: WebPageTest() {
+class DeleteAlbumPageTest : WebPageTest(::DeleteAlbumPage) {
- private val page = DeleteAlbumPage(template, webInterface)
-
- private val sone = mock<Sone>()
- private val album = mock<Album>()
- private val parentAlbum = mock<Album>()
-
- override fun getPage() = page
+ private val album = AlbumImpl(currentSone, "album-id")
+ private val parentAlbum = AlbumImpl(currentSone, "parent-id").also { it.addAlbum(album) }
@Before
fun setupAlbums() {
- whenever(sone.id).thenReturn("sone-id")
- whenever(sone.isLocal).thenReturn(true)
- whenever(parentAlbum.id).thenReturn("parent-id")
- whenever(parentAlbum.isRoot).thenReturn(true)
- whenever(album.id).thenReturn("album-id")
- whenever(album.sone).thenReturn(sone)
- whenever(album.parent).thenReturn(parentAlbum)
- whenever(sone.rootAlbum).thenReturn(parentAlbum)
+ whenever(currentSone.id).thenReturn("sone-id")
+ whenever(currentSone.isLocal).thenReturn(true)
+ whenever(currentSone.rootAlbum).thenReturn(parentAlbum)
}
@Test
@Test
fun `get request with invalid album ID results in redirect to invalid page`() {
- request("", GET)
whenever(core.getAlbum(anyString())).thenReturn(null)
verifyRedirect("invalid.html")
}
@Test
fun `get request with valid album ID sets album in template context`() {
- request("", GET)
- val album = mock<Album>()
addAlbum("album-id", album)
addHttpRequestParameter("album", "album-id")
page.processTemplate(freenetRequest, templateContext)
@Test
fun `post request redirects to invalid page if album is invalid`() {
- request("", POST)
+ setMethod(POST)
verifyRedirect("invalid.html")
}
@Test
fun `post request redirects to no permissions page if album is not local`() {
- request("", POST)
- whenever(sone.isLocal).thenReturn(false)
+ setMethod(POST)
+ whenever(currentSone.isLocal).thenReturn(false)
addAlbum("album-id", album)
- addHttpRequestParameter("album", "album-id")
+ addHttpRequestPart("album", "album-id")
verifyRedirect("noPermission.html")
}
@Test
fun `post request with abort delete parameter set redirects to album browser`() {
- request("", POST)
+ setMethod(POST)
addAlbum("album-id", album)
- addHttpRequestParameter("album", "album-id")
- addHttpRequestParameter("abortDelete", "true")
+ addHttpRequestPart("album", "album-id")
+ addHttpRequestPart("abortDelete", "true")
verifyRedirect("imageBrowser.html?album=album-id")
}
@Test
fun `album is deleted and page redirects to sone if parent album is root album`() {
- request("", POST)
+ setMethod(POST)
addAlbum("album-id", album)
- addHttpRequestParameter("album", "album-id")
+ addHttpRequestPart("album", "album-id")
verifyRedirect("imageBrowser.html?sone=sone-id") {
verify(core).deleteAlbum(album)
}
@Test
fun `album is deleted and page redirects to album if parent album is not root album`() {
- request("", POST)
- whenever(parentAlbum.isRoot).thenReturn(false)
- whenever(sone.rootAlbum).thenReturn(mock<Album>())
- addAlbum("album-id", album)
- addHttpRequestParameter("album", "album-id")
- verifyRedirect("imageBrowser.html?album=parent-id") {
- verify(core).deleteAlbum(album)
+ setMethod(POST)
+ val subAlbum = AlbumImpl(currentSone, "sub-album-id")
+ album.addAlbum(subAlbum)
+ addAlbum("sub-album-id", subAlbum)
+ addHttpRequestPart("album", "sub-album-id")
+ verifyRedirect("imageBrowser.html?album=album-id") {
+ verify(core).deleteAlbum(subAlbum)
}
}
+ @Test
+ fun `page can be created by dependency injection`() {
+ assertThat(baseInjector.getInstance<DeleteAlbumPage>(), notNullValue())
+ }
+
+ @Test
+ fun `page is annotated with correct template path`() {
+ assertThat(page.templatePath, equalTo("/templates/deleteAlbum.html"))
+ }
+
}