1 package net.pterodactylus.sone.web.pages
3 import net.pterodactylus.sone.data.Sone
4 import net.pterodactylus.sone.test.getInstance
5 import net.pterodactylus.sone.test.mock
6 import net.pterodactylus.sone.web.baseInjector
7 import net.pterodactylus.util.web.Method.POST
8 import org.hamcrest.MatcherAssert.assertThat
9 import org.hamcrest.Matchers.equalTo
10 import org.hamcrest.Matchers.notNullValue
12 import org.mockito.ArgumentMatchers.any
13 import org.mockito.ArgumentMatchers.eq
14 import org.mockito.Mockito.never
15 import org.mockito.Mockito.verify
18 * Unit test for [UntrustPage].
20 class UntrustPageTest: WebPageTest(::UntrustPage) {
23 fun `page returns correct path`() {
24 assertThat(page.path, equalTo("untrust.html"))
28 fun `page requires login`() {
29 assertThat(page.requiresLogin(), equalTo(true))
33 fun `page returns correct title`() {
34 addTranslation("Page.Untrust.Title", "untrust page title")
35 assertThat(page.getPageTitle(soneRequest), equalTo("untrust page title"))
39 fun `get request does not redirect`() {
41 verify(core, never()).untrustSone(eq(currentSone), any())
46 fun `post request without sone parameter does not untrust but redirects`() {
48 addHttpRequestPart("returnPage", "return.html")
49 verifyRedirect("return.html") {
50 verify(core, never()).untrustSone(eq(currentSone), any())
55 fun `post request with invalid sone parameter does not untrust but redirects`() {
57 addHttpRequestPart("returnPage", "return.html")
58 addHttpRequestPart("sone", "no-sone")
59 verifyRedirect("return.html") {
60 verify(core, never()).untrustSone(eq(currentSone), any())
65 fun `post request with valid sone parameter untrusts and redirects`() {
67 addHttpRequestPart("returnPage", "return.html")
68 addHttpRequestPart("sone", "sone-id")
69 val sone = mock<Sone>()
70 addSone("sone-id", sone)
71 verifyRedirect("return.html") {
72 verify(core).untrustSone(currentSone, sone)
77 fun `page can be created by dependency injection`() {
78 assertThat(baseInjector.getInstance<UntrustPage>(), notNullValue())