X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fmain%2FSoneModuleTest.kt;h=7b5b4af5f93477b143e1e11a948c38aec6eb5374;hb=8788d5ab31bba7dd145c25b979f99a8bc640c37e;hp=dd7923d1379ffa7d9913e7da9781bc2cad037bae;hpb=6ac356bc119250192e68934894bf9f5eedc4989c;p=Sone.git diff --git a/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt b/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt index dd7923d..7b5b4af 100644 --- a/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt @@ -1,21 +1,23 @@ package net.pterodactylus.sone.main +import com.codahale.metrics.* import com.google.common.base.* import com.google.common.eventbus.* import com.google.inject.Guice.* import com.google.inject.name.Names.* import freenet.l10n.* -import freenet.node.* import freenet.pluginmanager.* import net.pterodactylus.sone.core.* import net.pterodactylus.sone.database.* import net.pterodactylus.sone.database.memory.* +import net.pterodactylus.sone.freenet.plugin.* import net.pterodactylus.sone.freenet.wot.* import net.pterodactylus.sone.test.* import net.pterodactylus.util.config.* import net.pterodactylus.util.version.Version import org.hamcrest.MatcherAssert.* import org.hamcrest.Matchers.* +import org.mockito.Mockito.* import java.io.* import java.util.concurrent.atomic.* import kotlin.test.* @@ -36,11 +38,14 @@ class SoneModuleTest { whenever(l10n()).thenReturn(l10n) } - private val injector by lazy { createInjector( - SoneModule(sonePlugin), - FreenetInterface::class.isProvidedByDeepMock(), - PluginRespirator::class.isProvidedByDeepMock() - ) } + private val injector by lazy { + createInjector( + SoneModule(sonePlugin, EventBus()), + FreenetInterface::class.isProvidedByDeepMock(), + PluginRespiratorFacade::class.isProvidedByDeepMock(), + PluginConnector::class.isProvidedByDeepMock() + ) + } @AfterTest fun removePropertiesFromCurrentDirectory() { @@ -99,12 +104,6 @@ class SoneModuleTest { } @Test - fun `debug information flag is read from config`() { - File(currentDir, "sone.properties").writeText("Debug/ShowVersionInformation=true") - assertThat(injector.getInstance().debugInformation.showVersionInformation, equalTo(true)) - } - - @Test fun `event bus is bound`() { assertThat(injector.getInstance(), notNullValue()) } @@ -188,4 +187,36 @@ class SoneModuleTest { assertThat(testObject.ref.get(), sameInstance(event)) } + @Test + fun `core is created as singleton`() { + val firstCore = injector.getInstance() + val secondCore = injector.getInstance() + assertThat(secondCore, sameInstance(firstCore)) + } + + @Test + fun `core is registered with event bus`() { + val eventBus = mock() + val injector = createInjector( + SoneModule(sonePlugin, eventBus), + FreenetInterface::class.isProvidedByDeepMock(), + PluginRespiratorFacade::class.isProvidedByDeepMock(), + PluginConnector::class.isProvidedByDeepMock() + ) + val core = injector.getInstance() + verify(eventBus).register(core) + } + + @Test + fun `metrics registry can be created`() { + assertThat(injector.getInstance(), notNullValue()) + } + + @Test + fun `metrics registry is created as singleton`() { + val firstMetricRegistry = injector.getInstance() + val secondMetricRegistry = injector.getInstance() + assertThat(firstMetricRegistry, sameInstance(secondMetricRegistry)) + } + }