X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fmain%2FSoneModuleTest.kt;h=7f6b8d02f3dea52d29d29e50a5cbb2dea558e04e;hp=83d3535e372d35590a8306800249595f8aaffd1b;hb=c7e1d396f81935e872d0e49339fa19baf16abada;hpb=b447a1e0b8ce1fb977faf3fc5a7f4c24ac4639ff diff --git a/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt b/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt index 83d3535..7f6b8d0 100644 --- a/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt @@ -1,36 +1,54 @@ 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.pluginmanager.* +import net.pterodactylus.sone.core.* import net.pterodactylus.sone.database.* import net.pterodactylus.sone.database.memory.* +import net.pterodactylus.sone.freenet.* +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.junit.* +import org.mockito.Mockito.* import java.io.* import java.util.concurrent.atomic.* +import kotlin.test.* + +const val versionString = "v80" class SoneModuleTest { private val currentDir: File = File(".") - private val pluginVersion = Version("", 0, 1, 2) + private val pluginVersion = Version("", 80) private val pluginYear = 2019 private val pluginHomepage = "home://page" + private val l10n = deepMock() private val sonePlugin = mock().apply { - whenever(version).thenReturn(pluginVersion.toString()) + whenever(version).thenReturn(versionString) whenever(year).thenReturn(pluginYear) whenever(homepage).thenReturn(pluginHomepage) + whenever(l10n()).thenReturn(l10n) } - private val injector by lazy { createInjector(SoneModule(sonePlugin)) } + private val injector by lazy { + createInjector( + SoneModule(sonePlugin, EventBus()), + FreenetInterface::class.isProvidedByDeepMock(), + PluginRespiratorFacade::class.isProvidedByDeepMock(), + PluginConnector::class.isProvidedByDeepMock() + ) + } - @After + @AfterTest fun removePropertiesFromCurrentDirectory() { File(currentDir, "sone.properties").delete() } @@ -113,7 +131,7 @@ class SoneModuleTest { @Test fun `plugin version is bound`() { - assertThat(injector.getInstance(), equalTo(PluginVersion(pluginVersion.toString()))) + assertThat(injector.getInstance(), equalTo(PluginVersion(versionString))) } @Test @@ -132,6 +150,11 @@ class SoneModuleTest { } @Test + fun `translation is bound correctly`() { + assertThat(injector.getInstance(), notNullValue()) + } + + @Test fun `default loader is used without dev options`() { assertThat(injector.getInstance(), instanceOf(DefaultLoaders::class.java)) } @@ -165,4 +188,32 @@ class SoneModuleTest { assertThat(testObject.ref.get(), sameInstance(event)) } + @Test + fun `core is created as singleton`() { + injector.verifySingletonInstance() + } + + @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 is created as singleton`() { + injector.verifySingletonInstance() + } + + @Test + fun `wot connector is created as singleton`() { + injector.verifySingletonInstance() + } + }