X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Ffreenet%2Fwot%2FIdentityLoaderTest.kt;h=1123becd051f79fd6c622f7d57e6527dc7dac814;hb=06341a31cb9d80b027e395510e93c078aa988fcf;hp=780288d15056156364a9a89f33d9762b34141489;hpb=392c4ab7bb87fa31b0d77377694df60a8f647652;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 780288d..1123bec 100644 --- a/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/freenet/wot/IdentityLoaderTest.kt @@ -1,5 +1,5 @@ /* - * Sone - IdentityLoaderTest.java - Copyright © 2013–2019 David Roden + * Sone - IdentityLoaderTest.kt - Copyright © 2013–2020 David Roden * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -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]. @@ -27,9 +32,9 @@ import org.junit.* 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() @@ -37,12 +42,12 @@ class IdentityLoaderTest { ownIdentities[3] -> createTrustedIdentitiesForFourthOwnIdentity() else -> throw RuntimeException() } - } + } @Test fun loadingIdentities() { val identityLoader = IdentityLoader(webOfTrustConnector, Context("Test")) - val identities = identityLoader.loadIdentities() + val identities = identityLoader.loadTrustedIdentities() assertThat(identities.keys, hasSize(4)) assertThat(identities.keys, containsInAnyOrder(ownIdentities[0], ownIdentities[1], ownIdentities[2], ownIdentities[3])) verifyIdentitiesForOwnIdentity(identities, ownIdentities[0], createTrustedIdentitiesForFirstOwnIdentity()) @@ -54,7 +59,7 @@ class IdentityLoaderTest { @Test fun loadingIdentitiesWithoutContext() { val identityLoaderWithoutContext = IdentityLoader(webOfTrustConnector) - val identities = identityLoaderWithoutContext.loadIdentities() + val identities = identityLoaderWithoutContext.loadTrustedIdentities() assertThat(identities.keys, hasSize(4)) assertThat(identities.keys, containsInAnyOrder(ownIdentities[0], ownIdentities[1], ownIdentities[2], ownIdentities[3])) verifyIdentitiesForOwnIdentity(identities, ownIdentities[0], createTrustedIdentitiesForFirstOwnIdentity()) @@ -67,6 +72,40 @@ 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 = 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()) + } + + @Test + fun `loading trusted identities merges remote identities’ trust values`() { + val ownIdentity1 = createOwnIdentity("o1") + val ownIdentity2 = createOwnIdentity("o2") + 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()) + } + } private fun createOwnIdentities() = listOf( @@ -89,30 +128,3 @@ 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() - override fun loadTrustedIdentities(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 getTrust(ownIdentity: OwnIdentity, identity: Identity) = Trust(null, null, null) - override fun setTrust(ownIdentity: OwnIdentity, identity: Identity, trust: Int, comment: String) = Unit - override fun removeTrust(ownIdentity: OwnIdentity, identity: Identity) = Unit - override fun ping() = Unit - -}