package net.pterodactylus.sone.web.pages
-import net.pterodactylus.sone.data.Album
-import net.pterodactylus.sone.data.Image
-import net.pterodactylus.sone.data.Sone
-import net.pterodactylus.sone.test.mock
-import net.pterodactylus.sone.test.whenever
-import org.hamcrest.MatcherAssert.assertThat
-import org.hamcrest.Matchers.contains
-import org.hamcrest.Matchers.equalTo
-import org.junit.Test
+import net.pterodactylus.sone.data.*
+import net.pterodactylus.sone.test.*
+import net.pterodactylus.sone.web.*
+import net.pterodactylus.sone.web.page.*
+import org.hamcrest.MatcherAssert.*
+import org.hamcrest.Matchers.*
+import org.junit.*
+import java.net.*
/**
* Unit test for [ImageBrowserPage].
*/
-class ImageBrowserPageTest : WebPageTest() {
-
- private val page = ImageBrowserPage(template, webInterface)
+class ImageBrowserPageTest : WebPageTest(::ImageBrowserPage) {
@Test
fun `page returns correct path`() {
- assertThat(page.path, equalTo("imageBrowser.html"))
+ assertThat(page.path, equalTo("imageBrowser.html"))
}
@Test
fun `page requires login`() {
- assertThat(page.requiresLogin(), equalTo(true))
+ assertThat(page.requiresLogin(), equalTo(true))
}
@Test
fun `page returns correct title`() {
- whenever(l10n.getString("Page.ImageBrowser.Title")).thenReturn("image browser page title")
- assertThat(page.getPageTitle(freenetRequest), equalTo("image browser page title"))
+ addTranslation("Page.ImageBrowser.Title", "image browser page title")
+ assertThat(page.getPageTitle(soneRequest), equalTo("image browser page title"))
}
@Test
addAlbum("album-id", album)
addHttpRequestParameter("album", "album-id")
addHttpRequestParameter("page", "5")
- page.processTemplate(freenetRequest, templateContext)
- assertThat(templateContext["albumRequested"], equalTo<Any>(true))
- assertThat(templateContext["album"], equalTo<Any>(album))
- assertThat(templateContext["page"], equalTo<Any>("5"))
+ verifyNoRedirect {
+ assertThat(templateContext["albumRequested"], equalTo<Any>(true))
+ assertThat(templateContext["album"], equalTo<Any>(album))
+ assertThat(templateContext["page"], equalTo<Any>("5"))
+ }
}
@Test
val image = mock<Image>()
addImage("image-id", image)
addHttpRequestParameter("image", "image-id")
- page.processTemplate(freenetRequest, templateContext)
- assertThat(templateContext["imageRequested"], equalTo<Any>(true))
- assertThat(templateContext["image"], equalTo<Any>(image))
+ verifyNoRedirect {
+ assertThat(templateContext["imageRequested"], equalTo<Any>(true))
+ assertThat(templateContext["image"], equalTo<Any>(image))
+ }
}
@Test
val sone = mock<Sone>()
addSone("sone-id", sone)
addHttpRequestParameter("sone", "sone-id")
- page.processTemplate(freenetRequest, templateContext)
- assertThat(templateContext["soneRequested"], equalTo<Any>(true))
- assertThat(templateContext["sone"], equalTo<Any>(sone))
+ verifyNoRedirect {
+ assertThat(templateContext["soneRequested"], equalTo<Any>(true))
+ assertThat(templateContext["sone"], equalTo<Any>(sone))
+ }
}
@Test
val secondSone = createSone("third album", "fourth album")
addSone("sone2", secondSone)
addHttpRequestParameter("mode", "gallery")
- page.processTemplate(freenetRequest, templateContext)
- assertThat(templateContext["galleryRequested"], equalTo<Any>(true))
- @Suppress("UNCHECKED_CAST")
- assertThat(templateContext["albums"] as Iterable<Album>, contains(
- firstSone.rootAlbum.albums[0],
- secondSone.rootAlbum.albums[1],
- firstSone.rootAlbum.albums[1],
- secondSone.rootAlbum.albums[0]
- ))
+ verifyNoRedirect {
+ assertThat(templateContext["galleryRequested"], equalTo<Any>(true))
+ @Suppress("UNCHECKED_CAST")
+ assertThat(templateContext["albums"] as Iterable<Album>, contains(
+ firstSone.rootAlbum.albums[0],
+ secondSone.rootAlbum.albums[1],
+ firstSone.rootAlbum.albums[1],
+ secondSone.rootAlbum.albums[0]
+ ))
+ }
+ }
+
+ @Test
+ fun `get request for gallery can show second page`() {
+ core.preferences.newImagesPerPage = 2
+ val firstSone = createSone("first album", "second album")
+ addSone("sone1", firstSone)
+ val secondSone = createSone("third album", "fourth album")
+ addSone("sone2", secondSone)
+ addHttpRequestParameter("mode", "gallery")
+ addHttpRequestParameter("page", "1")
+ verifyNoRedirect {
+ assertThat(templateContext["galleryRequested"], equalTo<Any>(true))
+ @Suppress("UNCHECKED_CAST")
+ assertThat(templateContext["albums"] as Iterable<Album>, contains(
+ firstSone.rootAlbum.albums[1],
+ secondSone.rootAlbum.albums[0]
+ ))
+ }
}
private fun createSone(firstAlbumTitle: String, secondAlbumTitle: String): Sone {
@Test
fun `requesting nothing will show the albums of the current sone`() {
- page.processTemplate(freenetRequest, templateContext)
- assertThat(templateContext["soneRequested"], equalTo<Any>(true))
- assertThat(templateContext["sone"], equalTo<Any>(currentSone))
+ verifyNoRedirect {
+ assertThat(templateContext["soneRequested"], equalTo<Any>(true))
+ assertThat(templateContext["sone"], equalTo<Any>(currentSone))
+ }
}
@Test
fun `page is link-excepted`() {
- assertThat(page.isLinkExcepted(null), equalTo(true))
+ assertThat(page.isLinkExcepted(URI("")), equalTo(true))
+ }
+
+ @Test
+ fun `page can be created by dependency injection`() {
+ assertThat(baseInjector.getInstance<ImageBrowserPage>(), notNullValue())
+ }
+
+ @Test
+ fun `page is annotated with correct menuname`() {
+ assertThat(page.menuName, equalTo("ImageBrowser"))
+ }
+
+ @Test
+ fun `page is annotated with correct template path`() {
+ assertThat(page.templatePath, equalTo("/templates/imageBrowser.html"))
}
}