package net.pterodactylus.sone.web.ajax
-import net.pterodactylus.sone.data.Post
-import net.pterodactylus.sone.data.PostReply
-import net.pterodactylus.sone.data.Sone
-import net.pterodactylus.sone.test.mock
-import net.pterodactylus.sone.test.whenever
-import org.hamcrest.MatcherAssert.assertThat
-import org.hamcrest.Matchers.equalTo
-import org.junit.Test
-import org.mockito.Mockito.any
-import org.mockito.Mockito.never
-import org.mockito.Mockito.verify
+import net.pterodactylus.sone.data.*
+import net.pterodactylus.sone.test.*
+import net.pterodactylus.sone.web.*
+import org.hamcrest.MatcherAssert.*
+import org.hamcrest.Matchers.*
+import org.junit.*
+import org.mockito.Mockito.*
/**
* Unit test for [MarkAsKnownAjaxPage].
@Test
fun `request without type results in invalid-type`() {
- assertThat(json.isSuccess, equalTo(false))
- assertThat(json.error, equalTo("invalid-type"))
+ assertThatJsonFailed("invalid-type")
}
@Test
fun `request with unknown sone returns successfully`() {
addRequestParameter("type", "sone")
addRequestParameter("id", "invalid")
- assertThat(json.isSuccess, equalTo(true))
+ assertThatJsonIsSuccessful()
verify(core, never()).markSoneKnown(any())
}
val sone2 = mock<Sone>().apply { whenever(id).thenReturn("sone-id2") }
addSone(sone1)
addSone(sone2)
- assertThat(json.isSuccess, equalTo(true))
+ assertThatJsonIsSuccessful()
verify(core).markSoneKnown(sone1)
verify(core).markSoneKnown(sone2)
}
val post2 = mock<Post>()
addPost(post1, "post1")
addPost(post2, "post2")
- assertThat(json.isSuccess, equalTo(true))
+ assertThatJsonIsSuccessful()
verify(core).markPostKnown(post1)
verify(core).markPostKnown(post2)
}
val reply2 = mock<PostReply>()
addReply(reply1, "reply1")
addReply(reply2, "reply2")
- assertThat(json.isSuccess, equalTo(true))
+ assertThatJsonIsSuccessful()
verify(core).markReplyKnown(reply1)
verify(core).markReplyKnown(reply2)
}
+ @Test
+ fun `page can be created by dependency injection`() {
+ assertThat(baseInjector.getInstance<MarkAsKnownAjaxPage>(), notNullValue())
+ }
+
}