X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FViewSonePageTest.kt;h=dc586bdcc583359a456117127e9a6da8a1ec29ea;hp=6b5a08f2f112fd7817443889fb2ea13c71b714e4;hb=bce70170ce5ddaa142e67fcc67985215e1eadac2;hpb=1604283131120a5b4eb17a856ea688a20c03dc60 diff --git a/src/test/kotlin/net/pterodactylus/sone/web/pages/ViewSonePageTest.kt b/src/test/kotlin/net/pterodactylus/sone/web/pages/ViewSonePageTest.kt index 6b5a08f..dc586bd 100644 --- a/src/test/kotlin/net/pterodactylus/sone/web/pages/ViewSonePageTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/web/pages/ViewSonePageTest.kt @@ -4,40 +4,45 @@ import net.pterodactylus.sone.data.Post import net.pterodactylus.sone.data.PostReply import net.pterodactylus.sone.data.Profile import net.pterodactylus.sone.data.Sone +import net.pterodactylus.sone.test.getInstance +import net.pterodactylus.sone.test.isOnPage import net.pterodactylus.sone.test.mock import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.utils.Pagination import net.pterodactylus.sone.utils.asOptional +import net.pterodactylus.sone.web.baseInjector +import net.pterodactylus.sone.web.page.* import org.hamcrest.MatcherAssert.assertThat import org.hamcrest.Matchers.contains import org.hamcrest.Matchers.equalTo +import org.hamcrest.Matchers.notNullValue import org.hamcrest.Matchers.nullValue import org.junit.Before import org.junit.Test +import java.net.* /** * Unit test for [ViewSonePage]. */ -class ViewSonePageTest: WebPageTest() { +class ViewSonePageTest: WebPageTest(::ViewSonePage) { init { whenever(currentSone.id).thenReturn("sone-id") } - private val page = ViewSonePage(template, webInterface) private val post1 = createPost("post1", "First Post.", 1000, currentSone) private val post2 = createPost("post2", "Second Post.", 2000, currentSone) - private val foreignPost1 = createPost("foreign-post1", "First Foreign Post.", 1000, mock()) - private val foreignPost2 = createPost("foreign-post2", "Second Foreign Post.", 2000, mock()) - private val directed1 = createPost("post3", "First directed.", 1500, mock(), recipient = currentSone) - private val directed2 = createPost("post4", "Second directed.", 2500, mock(), recipient = currentSone) - - override fun getPage() = page + private val foreignPost1 = createPost("foreign-post1", "First Foreign Post.", 1000, mock()) + private val foreignPost2 = createPost("foreign-post2", "Second Foreign Post.", 2000, mock()) + private val foreignPost3 = createPost("foreign-post3", "Third Foreign Post.", 3000, mock()) + private val directed1 = createPost("post3", "First directed.", 1500, mock(), recipient = currentSone) + private val directed2 = createPost("post4", "Second directed.", 2500, mock(), recipient = currentSone) @Before fun setup() { whenever(currentSone.posts).thenReturn(mutableListOf(post2, post1)) whenever(core.getDirectedPosts("sone-id")).thenReturn(setOf(directed1, directed2)) - core.preferences.postsPerPage = 2 + core.preferences.newPostsPerPage = 2 } @Test @@ -96,6 +101,7 @@ class ViewSonePageTest: WebPageTest() { addHttpRequestParameter("sone", "sone-id") verifyNoRedirect { assertThat(templateContext["posts"] as Iterable, contains(directed2, post2)) + assertThat(templateContext["postPagination"] as Pagination, isOnPage(0).hasPages(2)) } } @@ -107,6 +113,7 @@ class ViewSonePageTest: WebPageTest() { addHttpRequestParameter("postPage", "1") verifyNoRedirect { assertThat(templateContext["posts"] as Iterable, contains(directed1, post1)) + assertThat(templateContext["postPagination"] as Pagination, isOnPage(1).hasPages(2)) } } @@ -119,38 +126,69 @@ class ViewSonePageTest: WebPageTest() { @Test @Suppress("UNCHECKED_CAST") fun `replies are shown correctly`() { - val reply1 = createReply("First Reply", 1500, foreignPost1) + val reply1 = createReply("First Reply", 1500, foreignPost1) + val reply2 = createReply("Second Reply", 2500, foreignPost2) + val reply3 = createReply("Third Reply", 1750, post1) + val reply4 = createReply("Fourth Reply", 2250, post2) + val reply5 = createReply("Fifth Reply", 1600, post1) + val reply6 = createReply("Sixth Reply", 2100, directed1) + val reply7 = createReply("Seventh Reply", 2200, null) + val reply8 = createReply("Eigth Reply", 2300, foreignPost1) + val reply9 = createReply("Ninth Reply", 2050, foreignPost3) + whenever(currentSone.replies).thenReturn(setOf(reply1, reply2, reply3, reply4, reply5, reply6, reply7, reply8, reply9)) + whenever(core.getReplies("post1")).thenReturn(listOf(reply3, reply5)) + whenever(core.getReplies("post2")).thenReturn(listOf(reply4)) + whenever(core.getReplies("foreign-post1")).thenReturn(listOf(reply8, reply1)) + whenever(core.getReplies("foreign-post2")).thenReturn(listOf(reply2)) + whenever(core.getReplies("post3")).thenReturn(listOf(reply6)) + whenever(core.getReplies("foreign-post3")).thenReturn(listOf(reply9)) + addSone("sone-id", currentSone) + addHttpRequestParameter("sone", "sone-id") + verifyNoRedirect { + assertThat(templateContext["repliedPosts"] as Iterable, contains(foreignPost2, foreignPost1)) + assertThat(templateContext["repliedPostPagination"] as Pagination, isOnPage(0).hasPages(2)) + } + } + + @Test + @Suppress("UNCHECKED_CAST") + fun `second page of replies is shown correctly`() { + val reply1 = createReply("First Reply", 1500, foreignPost1) val reply2 = createReply("Second Reply", 2500, foreignPost2) val reply3 = createReply("Third Reply", 1750, post1) val reply4 = createReply("Fourth Reply", 2250, post2) - val reply5 = createReply("Fifth Reply", 1600, post1) - val reply6 = createReply("Sixth Reply", 2100, directed1) - val reply7 = createReply("Seventh Reply", 2200, null) - val reply8 = createReply("Eigth Reply", 2300, foreignPost1) - whenever(currentSone.replies).thenReturn(setOf(reply1, reply2, reply3, reply4, reply5, reply6, reply7, reply8)) + val reply5 = createReply("Fifth Reply", 1600, post1) + val reply6 = createReply("Sixth Reply", 2100, directed1) + val reply7 = createReply("Seventh Reply", 2200, null) + val reply8 = createReply("Eigth Reply", 2300, foreignPost1) + val reply9 = createReply("Ninth Reply", 2050, foreignPost3) + whenever(currentSone.replies).thenReturn(setOf(reply1, reply2, reply3, reply4, reply5, reply6, reply7, reply8, reply9)) whenever(core.getReplies("post1")).thenReturn(listOf(reply3, reply5)) whenever(core.getReplies("post2")).thenReturn(listOf(reply4)) - whenever(core.getReplies("foreign-post1")).thenReturn(listOf(reply1)) + whenever(core.getReplies("foreign-post1")).thenReturn(listOf(reply8, reply1)) whenever(core.getReplies("foreign-post2")).thenReturn(listOf(reply2)) whenever(core.getReplies("post3")).thenReturn(listOf(reply6)) + whenever(core.getReplies("foreign-post3")).thenReturn(listOf(reply9)) addSone("sone-id", currentSone) addHttpRequestParameter("sone", "sone-id") + addHttpRequestParameter("repliedPostPage", "1") verifyNoRedirect { - assertThat(templateContext["repliedPosts"] as Iterable, contains(foreignPost2, foreignPost1)) + assertThat(templateContext["repliedPosts"] as Iterable, contains(foreignPost3)) + assertThat(templateContext["repliedPostPagination"] as Pagination, isOnPage(1).hasPages(2)) } } @Test fun `page title is default for request without parameters`() { addTranslation("Page.ViewSone.Page.TitleWithoutSone", "view sone page without sone") - assertThat(page.getPageTitle(freenetRequest), equalTo("view sone page without sone")) + assertThat(page.getPageTitle(soneRequest), equalTo("view sone page without sone")) } @Test fun `page title is default for request with invalid sone parameters`() { addHttpRequestParameter("sone", "invalid-sone-id") addTranslation("Page.ViewSone.Page.TitleWithoutSone", "view sone page without sone") - assertThat(page.getPageTitle(freenetRequest), equalTo("view sone page without sone")) + assertThat(page.getPageTitle(soneRequest), equalTo("view sone page without sone")) } @Test @@ -163,12 +201,22 @@ class ViewSonePageTest: WebPageTest() { lastName = "Last" }) addTranslation("Page.ViewSone.Title", "view sone page") - assertThat(page.getPageTitle(freenetRequest), equalTo("First M. Last - view sone page")) + assertThat(page.getPageTitle(soneRequest), equalTo("First M. Last - view sone page")) } @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(), notNullValue()) + } + + @Test + fun `page is annotated with correct template path`() { + assertThat(page.templatePath, equalTo("/templates/viewSone.html")) } }