🔀 Merge branch 'release/v82'
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / DeleteImagePageTest.kt
1 package net.pterodactylus.sone.web.pages
2
3 import net.pterodactylus.sone.data.*
4 import net.pterodactylus.sone.data.impl.*
5 import net.pterodactylus.sone.test.*
6 import net.pterodactylus.sone.web.*
7 import net.pterodactylus.sone.web.page.*
8 import net.pterodactylus.util.web.Method.*
9 import org.hamcrest.MatcherAssert.*
10 import org.hamcrest.Matchers.*
11 import org.junit.*
12 import org.mockito.Mockito.*
13
14 /**
15  * Unit test for [DeleteImagePage].
16  */
17 class DeleteImagePageTest : WebPageTest(::DeleteImagePage) {
18
19         private val sone = mock<Sone>()
20         private val image = ImageImpl("image-id").modify().setSone(sone).update()!!
21
22         @Before
23         fun setupImage() {
24                 AlbumImpl(sone, "album-id").also { it.addImage(image) }
25                 whenever(sone.isLocal).thenReturn(true)
26         }
27
28         @Test
29         fun `page returns correct path`() {
30                 assertThat(page.path, equalTo("deleteImage.html"))
31         }
32
33         @Test
34         fun `page requires login`() {
35                 assertThat(page.requiresLogin(), equalTo(true))
36         }
37
38         @Test
39         fun `get request with invalid image redirects to invalid page`() {
40                 verifyRedirect("invalid.html")
41         }
42
43         @Test
44         fun `get request with image from non-local sone redirects to no permissions page`() {
45                 whenever(sone.isLocal).thenReturn(false)
46                 addImage("image-id", image)
47                 addHttpRequestParameter("image", "image-id")
48                 verifyRedirect("noPermission.html")
49         }
50
51         @Test
52         fun `get request with image from local sone sets image in template context`() {
53                 addImage("image-id", image)
54                 addHttpRequestParameter("image", "image-id")
55                 page.processTemplate(freenetRequest, templateContext)
56                 assertThat(templateContext["image"], equalTo<Any>(image))
57         }
58
59         @Test
60         fun `post request with abort delete flag set redirects to image browser`() {
61                 setMethod(POST)
62                 addImage("image-id", image)
63                 addHttpRequestPart("image", "image-id")
64                 addHttpRequestPart("abortDelete", "true")
65                 verifyRedirect("imageBrowser.html?image=image-id")
66         }
67
68         @Test
69         fun `post request deletes image and redirects to image browser`() {
70                 setMethod(POST)
71                 addImage("image-id", image)
72                 addHttpRequestPart("image", "image-id")
73                 verifyRedirect("imageBrowser.html?album=album-id") {
74                         verify(webInterface.core).deleteImage(image)
75                 }
76         }
77
78         @Test
79         fun `page can be created by dependency injection`() {
80                 assertThat(baseInjector.getInstance<DeleteImagePage>(), notNullValue())
81         }
82
83         @Test
84         fun `page is annotated with correct template path`() {
85                 assertThat(page.templatePath, equalTo("/templates/deleteImage.html"))
86         }
87
88 }