package net.pterodactylus.sone.web.ajax
+import com.google.common.eventbus.EventBus
import freenet.clients.http.ToadletContext
import freenet.support.SimpleReadOnlyArrayBucket
import freenet.support.api.HTTPRequest
import net.pterodactylus.sone.core.Core
import net.pterodactylus.sone.core.ElementLoader
import net.pterodactylus.sone.core.LinkedElement
+import net.pterodactylus.sone.core.Preferences
+import net.pterodactylus.sone.data.Album
+import net.pterodactylus.sone.data.Image
import net.pterodactylus.sone.data.Post
import net.pterodactylus.sone.data.PostReply
import net.pterodactylus.sone.data.Profile
protected val webInterface = mock<WebInterface>()
protected val core = mock<Core>()
+ protected val eventBus = mock<EventBus>()
+ protected val preferences = Preferences(eventBus)
protected val elementLoader = mock<ElementLoader>()
protected open val page: JsonPage by lazy { pageSupplier(webInterface) }
- protected val json by lazy { page.createJsonObject(freenetRequest)!! }
+ protected val json by lazy { page.createJsonObject(freenetRequest) }
protected val toadletContext = mock<ToadletContext>()
protected val freenetRequest = mock<FreenetRequest>()
private val newReplies = mutableMapOf<String, PostReply>()
private val linkedElements = mutableMapOf<String, LinkedElement>()
private val notifications = mutableMapOf<String, Notification>()
+ private val albums = mutableMapOf<String, Album>()
+ private val images = mutableMapOf<String, Image>()
@Before
fun setupWebInterface() {
@Before
fun setupCore() {
+ whenever(core.preferences).thenReturn(preferences)
whenever(core.getSone(anyString())).thenAnswer { (localSones + remoteSones)[it.getArgument(0)].asOptional() }
whenever(core.getLocalSone(anyString())).thenAnswer { localSones[it[0]] }
whenever(core.getPost(anyString())).thenAnswer { (posts + newPosts)[it[0]].asOptional() }
whenever(core.getPostReply(anyString())).then { replies[it[0]].asOptional() }
+ whenever(core.getAlbum(anyString())).then { albums[it[0]] }
+ whenever(core.getImage(anyString())).then { images[it[0]] }
+ whenever(core.getImage(anyString(), anyBoolean())).then { images[it[0]] }
}
@Before
notifications[notificationId ?: notification.id] = notification
}
- protected fun addSone(sone: Sone) {
- remoteSones += sone.id to sone
+ protected fun addSone(sone: Sone, soneId: String? = null) {
+ remoteSones += (soneId ?: sone.id) to sone
}
protected fun addLocalSone(id: String, sone: Sone) {
linkedElements[link] = LinkedElement(link, failed, loading)
}
+ protected fun addAlbum(album: Album, albumId: String? = null) {
+ albums[albumId ?: album.id] = album
+ }
+
+ protected fun addImage(image: Image, imageId: String? = null) {
+ images[imageId ?: image.id] = image
+ }
+
@Test
fun `page returns correct path`() {
assertThat(page.path, equalTo(expectedPath))