X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Ffreenet%2Fwot%2FIdentityLoaderTest.kt;h=4188adf3e3b2a0fe5e0475a9447091c8f77c84e5;hb=8b8e9d3b5321d67712e557da7b222a58538869d0;hp=0e0e336551834dfeda39011b5f4fac4ce3dcd12c;hpb=6ebf42a54cc1ef44bdd762ad06e9b1a84bd7ad25;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 0e0e336..4188adf 100644 --- a/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt @@ -17,9 +17,14 @@ package net.pterodactylus.sone.freenet.wot -import org.hamcrest.MatcherAssert.* -import org.hamcrest.Matchers.* -import org.junit.* +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 +import org.hamcrest.Matchers.hasSize +import org.hamcrest.Matchers.notNullValue +import org.junit.Test /** * Unit test for [IdentityLoader]. @@ -67,6 +72,38 @@ class IdentityLoaderTest { assertThat(identities[ownIdentity], equalTo>(trustedIdentities)) } + @Test + 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 identityLoader = IdentityLoader(webOfTrustConnector) + val allIdentities = identityLoader.loadAllIdentities() + assertThat(allIdentities[ownIdentity1]!!.first().trust[ownIdentity2], notNullValue()) + } + + @Test + 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 identityLoader = IdentityLoader(webOfTrustConnector) + val allIdentities = identityLoader.loadTrustedIdentities() + assertThat(allIdentities[ownIdentity1]!!.first().trust[ownIdentity2], notNullValue()) + } + } private fun createOwnIdentities() = listOf( @@ -90,18 +127,6 @@ private fun createTrustedIdentitiesForThirdOwnIdentity() = setOf( private fun createTrustedIdentitiesForFourthOwnIdentity(): Set = emptySet() -private fun createOwnIdentity(id: String, nickname: String, requestUri: String, insertUri: String, contexts: Set, properties: Map): OwnIdentity = - DefaultOwnIdentity(id, nickname, requestUri, insertUri).apply { - setContexts(contexts) - this.properties = properties - } - -private fun createIdentity(id: String, nickname: String, requestUri: String, contexts: Set, properties: Map): Identity = - DefaultIdentity(id, nickname, requestUri).apply { - setContexts(contexts) - this.properties = properties - } - private open class TestWebOfTrustConnector : WebOfTrustConnector { override fun loadAllOwnIdentities() = emptySet()