Replace web page test base with Kotlin version
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / UploadImagePageTest.kt
index 8bea89e..58e63a2 100644 (file)
@@ -20,20 +20,35 @@ import org.mockito.Mockito.verify
 /**
  * Unit test for [UploadImagePage].
  */
-class UploadImagePageTest : WebPageTest() {
+class UploadImagePageTest: WebPageTest(::UploadImagePage) {
 
        private val parentAlbum = mock<Album>().apply {
                whenever(id).thenReturn("parent-id")
                whenever(sone).thenReturn(currentSone)
        }
 
-       override fun getPage() = UploadImagePage(template, webInterface)
+       @Test
+       fun `page returns correct path`() {
+           assertThat(page.path, equalTo("uploadImage.html"))
+       }
+
+       @Test
+       fun `page requires login`() {
+           assertThat(page.requiresLogin(), equalTo(true))
+       }
+
+       @Test
+       fun `page returns correct title`() {
+           addTranslation("Page.UploadImage.Title", "upload image page title")
+               assertThat(page.getPageTitle(freenetRequest), equalTo("upload image page title"))
+       }
 
        @Test
        fun `get request does not redirect or upload anything`() {
-               page.handleRequest(freenetRequest, templateContext)
-               verify(core, never()).createTemporaryImage(any(), any())
-               verify(core, never()).createImage(any(), any(), any())
+               verifyNoRedirect {
+                       verify(core, never()).createTemporaryImage(any(), any())
+                       verify(core, never()).createImage(any(), any(), any())
+               }
        }
 
        @Test
@@ -66,10 +81,12 @@ class UploadImagePageTest : WebPageTest() {
                addAlbum("parent-id", parentAlbum)
                addHttpRequestPart("parent", "parent-id")
                addHttpRequestPart("title", "title")
-               addUploadedFile("image", "image.png", "image/png", "no-image.png")
-               page.handleRequest(freenetRequest, templateContext)
-               verify(core, never()).createTemporaryImage(any(), any())
-               assertThat(templateContext["messages"] as String?, equalTo<String>("Page.UploadImage.Error.InvalidImage"))
+               addUploadedFile("image", "image.png", "image/png", "upload-image-invalid-image.png")
+               addTranslation("Page.UploadImage.Error.InvalidImage", "upload error - invalid image")
+               verifyNoRedirect {
+                       verify(core, never()).createTemporaryImage(any(), any())
+                       assertThat(templateContext["messages"] as String, equalTo("upload error - invalid image"))
+               }
        }
 
        @Test
@@ -78,8 +95,9 @@ class UploadImagePageTest : WebPageTest() {
                addAlbum("parent-id", parentAlbum)
                addHttpRequestPart("parent", "parent-id")
                addHttpRequestPart("title", "Title")
-               addHttpRequestPart("description", "Description")
-               addUploadedFile("image", "image.png", "image/png", "image.png")
+               addHttpRequestPart("description", "Description @ http://localhost:8888/KSK@foo")
+               addHttpRequestHeader("Host", "localhost:8888")
+               addUploadedFile("image", "upload-image-value-image.png", "image/png", "upload-image-value-image.png")
                val temporaryImage = TemporaryImage("temp-image")
                val imageModifier = mockBuilder<Modifier>()
                val image = mock<Image>().apply {
@@ -92,7 +110,7 @@ class UploadImagePageTest : WebPageTest() {
                        verify(imageModifier).setWidth(2)
                        verify(imageModifier).setHeight(1)
                        verify(imageModifier).setTitle("Title")
-                       verify(imageModifier).setDescription("Description")
+                       verify(imageModifier).setDescription("Description @ KSK@foo")
                        verify(imageModifier).update()
                }
        }