Use verifyNoRedirect instead of calling the request handler directly
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / web / pages / ViewPostPageTest.kt
1 package net.pterodactylus.sone.web.pages
2
3 import net.pterodactylus.sone.data.Post
4 import net.pterodactylus.sone.data.Profile
5 import net.pterodactylus.sone.test.mock
6 import net.pterodactylus.sone.test.whenever
7 import org.hamcrest.MatcherAssert.assertThat
8 import org.hamcrest.Matchers.equalTo
9 import org.hamcrest.Matchers.nullValue
10 import org.junit.Test
11
12 /**
13  * Unit test for [ViewPostPage].
14  */
15 class ViewPostPageTest : WebPageTest() {
16
17         private val page = ViewPostPage(template, webInterface)
18         private val post = mock<Post>()
19
20         override fun getPage() = page
21
22         @Test
23         fun `the view post page is link-excepted`() {
24                 assertThat(page.isLinkExcepted(null), equalTo(true))
25         }
26
27         @Test
28         fun `get request without parameters stores null in template context`() {
29                 verifyNoRedirect {
30                         assertThat(templateContext["post"], nullValue())
31                         assertThat(templateContext["raw"] as? Boolean, equalTo(false))
32                 }
33         }
34
35         @Test
36         fun `get request with invalid post id stores null in template context`() {
37                 addHttpRequestParameter("post", "invalid-post-id")
38                 verifyNoRedirect {
39                         assertThat(templateContext["post"], nullValue())
40                         assertThat(templateContext["raw"] as? Boolean, equalTo(false))
41                 }
42         }
43
44         @Test
45         fun `get request with valid post id stores post in template context`() {
46                 addPost("post-id", post)
47                 addHttpRequestParameter("post", "post-id")
48                 verifyNoRedirect {
49                         assertThat(templateContext["post"], equalTo<Any>(post))
50                         assertThat(templateContext["raw"] as? Boolean, equalTo(false))
51                 }
52         }
53
54         @Test
55         fun `get request with valid post id and raw=true stores post in template context`() {
56                 addPost("post-id", post)
57                 addHttpRequestParameter("post", "post-id")
58                 addHttpRequestParameter("raw", "true")
59                 verifyNoRedirect {
60                         assertThat(templateContext["post"], equalTo<Any>(post))
61                         assertThat(templateContext["raw"] as? Boolean, equalTo(true))
62                 }
63         }
64
65         @Test
66         fun `page title for request without parameters is default title`() {
67                 assertThat(page.getPageTitle(freenetRequest), equalTo("Page.ViewPost.Title"))
68         }
69
70         @Test
71         fun `page title for request with invalid post is default title`() {
72                 addHttpRequestParameter("post", "invalid-post-id")
73                 assertThat(page.getPageTitle(freenetRequest), equalTo("Page.ViewPost.Title"))
74         }
75
76         @Test
77         fun `page title for request with valid post is first twenty chars of post plus sone name plus default title`() {
78                 whenever(currentSone.profile).thenReturn(Profile(currentSone).apply {
79                         firstName = "First"
80                         middleName = "M."
81                         lastName = "Last"
82                 })
83                 whenever(post.sone).thenReturn(currentSone)
84                 whenever(post.text).thenReturn("This is a text that is longer than twenty characters.")
85                 addPost("post-id", post)
86                 addHttpRequestParameter("post", "post-id")
87                 assertThat(page.getPageTitle(freenetRequest), equalTo("This is a text that … - First M. Last - Page.ViewPost.Title"))
88         }
89
90 }