import net.pterodactylus.sone.data.Sone
import net.pterodactylus.sone.test.mock
import net.pterodactylus.sone.test.whenever
-import net.pterodactylus.sone.web.WebTestUtils.redirectsTo
import net.pterodactylus.util.web.Method.GET
import net.pterodactylus.util.web.Method.POST
import org.hamcrest.MatcherAssert.assertThat
/**
* Unit test for [DeleteAlbumPage].
*/
-class DeleteAlbumPageTest : WebPageTest() {
+class DeleteAlbumPageTest: WebPageTest() {
private val page = DeleteAlbumPage(template, webInterface)
private val album = mock<Album>()
private val parentAlbum = mock<Album>()
+ override fun getPage() = page
+
@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)
}
@Test
+ fun `page returns correct path`() {
+ assertThat(page.path, equalTo("deleteAlbum.html"))
+ }
+
+ @Test
+ fun `page requires login`() {
+ assertThat(page.requiresLogin(), equalTo(true))
+ }
+
+ @Test
fun `get request with invalid album ID results in redirect to invalid page`() {
request("", GET)
whenever(core.getAlbum(anyString())).thenReturn(null)
- expectedException.expect(redirectsTo("invalid.html"))
- page.handleRequest(freenetRequest, templateContext)
+ verifyRedirect("invalid.html")
}
@Test
val album = mock<Album>()
addAlbum("album-id", album)
addHttpRequestParameter("album", "album-id")
- page.handleRequest(freenetRequest, templateContext)
+ page.processTemplate(freenetRequest, templateContext)
assertThat(templateContext["album"], equalTo<Any>(album))
}
@Test
fun `post request redirects to invalid page if album is invalid`() {
request("", POST)
- expectedException.expect(redirectsTo("invalid.html"))
- page.handleRequest(freenetRequest, templateContext)
+ verifyRedirect("invalid.html")
}
@Test
whenever(sone.isLocal).thenReturn(false)
addAlbum("album-id", album)
addHttpRequestParameter("album", "album-id")
- expectedException.expect(redirectsTo("noPermission.html"))
- page.handleRequest(freenetRequest, templateContext)
+ verifyRedirect("noPermission.html")
}
@Test
addAlbum("album-id", album)
addHttpRequestParameter("album", "album-id")
addHttpRequestParameter("abortDelete", "true")
- expectedException.expect(redirectsTo("imageBrowser.html?album=album-id"))
- page.handleRequest(freenetRequest, templateContext)
+ verifyRedirect("imageBrowser.html?album=album-id")
}
@Test
request("", POST)
addAlbum("album-id", album)
addHttpRequestParameter("album", "album-id")
- expectedException.expect(redirectsTo("imageBrowser.html?sone=sone-id"))
- try {
- page.handleRequest(freenetRequest, templateContext)
- } finally {
+ 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")
- expectedException.expect(redirectsTo("imageBrowser.html?album=parent-id"))
- try {
- page.handleRequest(freenetRequest, templateContext)
- } finally {
+ verifyRedirect("imageBrowser.html?album=parent-id") {
verify(core).deleteAlbum(album)
}
}