X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Ffcp%2FSoneCommandTest.kt;h=53976833e8aded5cf67b3fe4b99c5df32b679105;hp=b2fb4aeea47e61a85bd3ca266232e5299eb4cfd3;hb=fafe0029dcbef27ce918fdf7007e78c8705ca20f;hpb=00c0f66598af0a462cb367fbf1ad67512878cf5e diff --git a/src/test/kotlin/net/pterodactylus/sone/fcp/SoneCommandTest.kt b/src/test/kotlin/net/pterodactylus/sone/fcp/SoneCommandTest.kt index b2fb4ae..5397683 100644 --- a/src/test/kotlin/net/pterodactylus/sone/fcp/SoneCommandTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/fcp/SoneCommandTest.kt @@ -1,23 +1,25 @@ package net.pterodactylus.sone.fcp -import com.google.common.base.Optional import com.google.common.base.Optional.absent import freenet.support.SimpleFieldSet import net.pterodactylus.sone.core.Core +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.freenet.fcp.Command import net.pterodactylus.sone.freenet.fcp.FcpException +import net.pterodactylus.sone.template.SoneAccessor +import net.pterodactylus.sone.test.OneByOneMatcher import net.pterodactylus.sone.test.mock import net.pterodactylus.sone.test.whenever +import net.pterodactylus.sone.utils.asOptional import org.junit.Before import org.junit.Rule -import org.junit.Test import org.junit.rules.ExpectedException -import org.mockito.ArgumentMatchers import org.mockito.ArgumentMatchers.anyString /** - * TODO + * Base class for Sone FCP command tests. */ abstract class SoneCommandTest { @@ -36,31 +38,97 @@ abstract class SoneCommandTest { @Before fun setupCore() { - whenever(core.getSone(anyString())).thenReturn(absent()) + whenever(core.getSone(anyString())).thenReturn(null) + whenever(core.getPost(anyString())).thenReturn(absent()) + whenever(core.getPostReply(anyString())).thenReturn(null) + } + + protected fun createSone(id: String, name: String, firstName: String, lastName: String, time: Long) = mock().apply { + whenever(this.id).thenReturn(id) + whenever(this.name).thenReturn(name) + whenever(profile).thenReturn(Profile(this).apply { + this.firstName = firstName + this.lastName = lastName + }) + whenever(this.time).thenReturn(time) + } + + protected fun createPost(id: String, sone: Sone, recipientId: String?, time: Long, text: String) = mock().apply { + whenever(this.id).thenReturn(id) + whenever(this.sone).thenReturn(sone) + whenever(this.recipientId).thenReturn(recipientId.asOptional()) + whenever(this.time).thenReturn(time) + whenever(this.text).thenReturn(text) + } + + protected fun createReply(id: String, sone: Sone, post: Post, time: Long, text: String) = mock().apply { + whenever(this.id).thenReturn(id) + whenever(this.sone).thenReturn(sone) + whenever(this.post).thenReturn(post.asOptional()) + whenever(this.time).thenReturn(time) + whenever(this.text).thenReturn(text) + } + + protected fun executeCommandAndExpectFcpException() { + expectedException.expect(FcpException::class.java) + command.execute(parameters) } protected fun requestWithoutAnyParameterResultsInFcpException() { expectedException.expect(FcpException::class.java) - command.execute(parameters, null, null) + command.execute(parameters) } protected fun requestWithEmptySoneParameterResultsInFcpException() { - parameters.putSingle("Sone", null) - expectedException.expect(FcpException::class.java) - command.execute(parameters, null, null) + parameters += "Sone" to null + executeCommandAndExpectFcpException() } protected fun requestWithInvalidSoneParameterResultsInFcpException() { - parameters.putSingle("Sone", "InvalidSoneId") - expectedException.expect(FcpException::class.java) - command.execute(parameters, null, null) + parameters += "Sone" to "InvalidSoneId" + executeCommandAndExpectFcpException() } fun requestWithValidRemoteSoneParameterResultsInFcpException() { - parameters.putSingle("Sone", "RemoteSoneId") - whenever(core.getSone("RemoteSoneId")).thenReturn(Optional.of(remoteSone)) - expectedException.expect(FcpException::class.java) - command.execute(parameters, null, null) + parameters += "Sone" to "RemoteSoneId" + whenever(core.getSone("RemoteSoneId")).thenReturn(remoteSone) + executeCommandAndExpectFcpException() + } + + protected operator fun SimpleFieldSet.plusAssign(keyValue: Pair) = putSingle(keyValue.first, keyValue.second) + protected fun SimpleFieldSet.parsePost(prefix: String) = parseFromSimpleFieldSet(prefix, "ID", "Sone", "Recipient", "Time", "Text") + protected fun SimpleFieldSet.parseReply(prefix: String) = parseFromSimpleFieldSet(prefix, "ID", "Sone", "Time", "Text") + protected fun SimpleFieldSet.parseSone(prefix: String) = parseFromSimpleFieldSet(prefix, "ID", "Name", "NiceName", "LastUpdated", "Followed") + + (0 until this["${prefix}Field.Count"].toInt()).map { + ("Field." + this["${prefix}Field.$it.Name"]) to this["${prefix}Field.$it.Value"] + } + + private fun SimpleFieldSet.parseFromSimpleFieldSet(prefix: String, vararg fields: String): Map = fields + .associate { it to get(prefix + it) } + + protected fun matchesPost(post: Post) = OneByOneMatcher>().apply { + expect("ID", post.id) { it["ID"] } + expect("Sone", post.sone.id) { it["Sone"] } + expect("recipient", post.recipientId.orNull()) { it["Recipient"] } + expect("time", post.time.toString()) { it["Time"] } + expect("text", post.text.replace("\\", "\\\\").replace("\r", "\\r").replace("\n", "\\n")) { it["Text"] } + } + + protected fun matchesReply(reply: PostReply) = OneByOneMatcher>().apply { + expect("ID", reply.id) { it["ID"] } + expect("Sone", reply.sone.id) { it["Sone"] } + expect("time", reply.time.toString()) { it["Time"] } + expect("text", reply.text.replace("\\", "\\\\").replace("\r", "\\r").replace("\n", "\\n")) { it["Text"] } + } + + protected fun matchesSone(sone: Sone) = OneByOneMatcher>().apply { + expect("ID", sone.id) { it["ID"] } + expect("name", sone.name) { it["Name"] } + expect("last updated", sone.time.toString()) { it["LastUpdated"] } + expect("nice name", SoneAccessor.getNiceName(sone)) { it["NiceName"] } + sone.profile.fields.forEach { field -> + expect("field: ${field.name}", field.value) { it["Field.${field.name}"] } + } } }