X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Ffreenet%2Fwot%2FIdentityLoaderTest.kt;h=1123becd051f79fd6c622f7d57e6527dc7dac814;hb=c66657eb61d863fe2b1f1ea534a2bd46e5064b89;hp=0426814f31b5a9dfa3dc20bcb0505340e6fa0bcf;hpb=6c9bd8dcb139302e29d9eb9c8e509589f31fcb58;p=Sone.git diff --git a/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt b/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt index 0426814..1123bec 100644 --- a/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt @@ -17,6 +17,8 @@ package net.pterodactylus.sone.freenet.wot +import net.pterodactylus.sone.test.createIdentity +import net.pterodactylus.sone.test.createOwnIdentity import org.hamcrest.MatcherAssert.assertThat import org.hamcrest.Matchers.containsInAnyOrder import org.hamcrest.Matchers.equalTo @@ -30,9 +32,9 @@ import org.junit.Test class IdentityLoaderTest { private val ownIdentities = createOwnIdentities() - private val webOfTrustConnector = object : TestWebOfTrustConnector() { - override fun loadAllOwnIdentities() = ownIdentities.toSet() - override fun loadTrustedIdentities(ownIdentity: OwnIdentity, context: String?) = + private val webOfTrustConnector = dummyWebOfTrustConnector + .overrideLoadAllOwnIdentities { ownIdentities.toSet() } + .overrideLoadTrustedIdentities { ownIdentity, _ -> when (ownIdentity) { ownIdentities[0] -> createTrustedIdentitiesForFirstOwnIdentity() ownIdentities[1] -> createTrustedIdentitiesForSecondOwnIdentity() @@ -40,7 +42,7 @@ class IdentityLoaderTest { ownIdentities[3] -> createTrustedIdentitiesForFourthOwnIdentity() else -> throw RuntimeException() } - } + } @Test fun loadingIdentities() { @@ -74,13 +76,14 @@ class IdentityLoaderTest { fun `loading all identities merges remote identities’ trust values`() { val ownIdentity1 = createOwnIdentity("o1") val ownIdentity2 = createOwnIdentity("o2") - val webOfTrustConnector = object : TestWebOfTrustConnector() { - override fun loadAllOwnIdentities() = setOf(ownIdentity1, ownIdentity2) - override fun loadAllIdentities(ownIdentity: OwnIdentity, context: String?) = when (ownIdentity) { - ownIdentity1 -> setOf(createIdentity().setTrust(ownIdentity1, Trust(100, 50, 2))) - else -> setOf(createIdentity().setTrust(ownIdentity2, Trust(80, 40, 2))) - } - } + val webOfTrustConnector = dummyWebOfTrustConnector + .overrideLoadAllOwnIdentities { setOf(ownIdentity1, ownIdentity2) } + .overrideLoadAllIdentities { ownIdentity, _ -> + when (ownIdentity) { + ownIdentity1 -> setOf(createIdentity().setTrust(ownIdentity1, Trust(100, 50, 2))) + else -> setOf(createIdentity().setTrust(ownIdentity2, Trust(80, 40, 2))) + } + } val identityLoader = IdentityLoader(webOfTrustConnector) val allIdentities = identityLoader.loadAllIdentities() assertThat(allIdentities[ownIdentity1]!!.first().trust[ownIdentity2], notNullValue()) @@ -90,13 +93,14 @@ class IdentityLoaderTest { fun `loading trusted identities merges remote identities’ trust values`() { val ownIdentity1 = createOwnIdentity("o1") val ownIdentity2 = createOwnIdentity("o2") - val webOfTrustConnector = object : TestWebOfTrustConnector() { - override fun loadAllOwnIdentities() = setOf(ownIdentity1, ownIdentity2) - override fun loadTrustedIdentities(ownIdentity: OwnIdentity, context: String?) = when (ownIdentity) { - ownIdentity1 -> setOf(createIdentity().setTrust(ownIdentity1, Trust(100, 50, 2))) - else -> setOf(createIdentity().setTrust(ownIdentity2, Trust(80, 40, 2))) - } - } + val webOfTrustConnector = dummyWebOfTrustConnector + .overrideLoadAllOwnIdentities { setOf(ownIdentity1, ownIdentity2) } + .overrideLoadTrustedIdentities { ownIdentity, _ -> + when (ownIdentity) { + ownIdentity1 -> setOf(createIdentity().setTrust(ownIdentity1, Trust(100, 50, 2))) + else -> setOf(createIdentity().setTrust(ownIdentity2, Trust(80, 40, 2))) + } + } val identityLoader = IdentityLoader(webOfTrustConnector) val allIdentities = identityLoader.loadTrustedIdentities() assertThat(allIdentities[ownIdentity1]!!.first().trust[ownIdentity2], notNullValue()) @@ -124,28 +128,3 @@ private fun createTrustedIdentitiesForThirdOwnIdentity() = setOf( ) private fun createTrustedIdentitiesForFourthOwnIdentity(): Set = emptySet() - -private fun createOwnIdentity(id: String = "", nickname: String = "", requestUri: String = "", insertUri: String = "", contexts: Set = setOf(), properties: Map = mapOf()): OwnIdentity = - DefaultOwnIdentity(id, nickname, requestUri, insertUri).apply { - setContexts(contexts) - this.properties = properties - } - -private fun createIdentity(id: String = "", nickname: String = "", requestUri: String = "", contexts: Set = setOf(), properties: Map = mapOf()): Identity = - DefaultIdentity(id, nickname, requestUri).apply { - setContexts(contexts) - this.properties = properties - } - -private open class TestWebOfTrustConnector : WebOfTrustConnector { - - override fun loadAllOwnIdentities() = emptySet() - override fun loadTrustedIdentities(ownIdentity: OwnIdentity, context: String?) = emptySet() - override fun loadAllIdentities(ownIdentity: OwnIdentity, context: String?) = emptySet() - override fun addContext(ownIdentity: OwnIdentity, context: String) = Unit - override fun removeContext(ownIdentity: OwnIdentity, context: String) = Unit - override fun setProperty(ownIdentity: OwnIdentity, name: String, value: String) = Unit - override fun removeProperty(ownIdentity: OwnIdentity, name: String) = Unit - override fun ping() = Unit - -}