X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fmain%2FSoneModuleTest.kt;h=c6283347476efd47f7f1bf416082415ecce791c2;hp=77633bd8a0145e1ca13ab87615326d9cba96055f;hb=d673c44ae56fcaf8368bcf3488f417e3b947158e;hpb=c557e36a80799ed81831e246bcd6b0345a30259b diff --git a/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt b/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt index 77633bd..c628334 100644 --- a/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt +++ b/src/test/kotlin/net/pterodactylus/sone/main/SoneModuleTest.kt @@ -1,34 +1,56 @@ package net.pterodactylus.sone.main +import com.codahale.metrics.* import com.google.common.base.* import com.google.common.eventbus.* -import com.google.inject.* +import com.google.inject.Guice.* import com.google.inject.name.Names.* +import freenet.l10n.* +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.junit.experimental.categories.* +import org.mockito.Mockito.* import java.io.* +import java.util.concurrent.* import java.util.concurrent.atomic.* +import kotlin.test.* +const val versionString = "v80" + +@Category(NotParallel::class) 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, EventBus()), + FreenetInterface::class.isProvidedByDeepMock(), + PluginRespiratorFacade::class.isProvidedByDeepMock(), + PluginConnector::class.isProvidedByDeepMock() + ) } - @After + @AfterTest fun removePropertiesFromCurrentDirectory() { File(currentDir, "sone.properties").delete() } @@ -36,19 +58,19 @@ class SoneModuleTest { @Test fun `creator binds configuration when no file is present`() { File(currentDir, "sone.properties").delete() - assertThat(getInstance(), notNullValue()) + assertThat(injector.getInstance(), notNullValue()) } @Test fun `creator binds first start to true when no file is present`() { File(currentDir, "sone.properties").delete() - assertThat(getInstance(named("FirstStart")), equalTo(true)) + assertThat(injector.getInstance(named("FirstStart")), equalTo(true)) } @Test fun `config file is created in current directory if not present`() { File(currentDir, "sone.properties").delete() - val configuration = getInstance() + val configuration = injector.getInstance() configuration.save() assertThat(File(currentDir, "sone.properties").exists(), equalTo(true)) } @@ -56,94 +78,99 @@ class SoneModuleTest { @Test fun `creator binds configuration when file is present`() { File(currentDir, "sone.properties").writeText("Option=old") - assertThat(getInstance().getStringValue("Option").value, equalTo("old")) + assertThat(injector.getInstance().getStringValue("Option").value, equalTo("old")) } @Test fun `creator binds first start to false when file is present`() { File(currentDir, "sone.properties").writeText("Option=old") - assertThat(getInstance(named("FirstStart")), equalTo(false)) + assertThat(injector.getInstance(named("FirstStart")), equalTo(false)) } @Test fun `invalid config file leads to new config being created`() { File(currentDir, "sone.properties").writeText("Option=old\nbroken") - val configuration = getInstance() + val configuration = injector.getInstance() assertThat(configuration.getStringValue("Option").getValue(null), nullValue()) } @Test fun `invalid config file leads to new config being set to true`() { File(currentDir, "sone.properties").writeText("Option=old\nbroken") - assertThat(getInstance(named("NewConfig")), equalTo(true)) + assertThat(injector.getInstance(named("NewConfig")), equalTo(true)) } @Test fun `valid config file leads to new config being set to false`() { File(currentDir, "sone.properties").writeText("Option=old") - assertThat(getInstance(named("NewConfig")), equalTo(false)) + assertThat(injector.getInstance(named("NewConfig")), equalTo(false)) } @Test fun `event bus is bound`() { - assertThat(getInstance(), notNullValue()) + assertThat(injector.getInstance(), notNullValue()) } @Test fun `context is bound`() { - assertThat(getInstance().context, equalTo("Sone")) + assertThat(injector.getInstance().context, equalTo("Sone")) } @Test fun `optional context is bound`() { - assertThat(getInstance>().get().context, equalTo("Sone")) + assertThat(injector.getInstance>().get().context, equalTo("Sone")) } @Test fun `sone plugin is bound`() { - assertThat(getInstance(), sameInstance(sonePlugin)) + assertThat(injector.getInstance(), sameInstance(sonePlugin)) } @Test fun `version is bound`() { - assertThat(getInstance(), equalTo(pluginVersion)) + assertThat(injector.getInstance(), equalTo(pluginVersion)) } @Test fun `plugin version is bound`() { - assertThat(getInstance(), equalTo(PluginVersion(pluginVersion.toString()))) + assertThat(injector.getInstance(), equalTo(PluginVersion(versionString))) } @Test fun `plugin year is bound`() { - assertThat(getInstance(), equalTo(PluginYear(pluginYear))) + assertThat(injector.getInstance(), equalTo(PluginYear(pluginYear))) } @Test fun `plugin homepage in bound`() { - assertThat(getInstance(), equalTo(PluginHomepage(pluginHomepage))) + assertThat(injector.getInstance(), equalTo(PluginHomepage(pluginHomepage))) } @Test fun `database is bound correctly`() { - assertThat(getInstance(), instanceOf(MemoryDatabase::class.java)) + assertThat(injector.getInstance(), instanceOf(MemoryDatabase::class.java)) + } + + @Test + fun `translation is bound correctly`() { + assertThat(injector.getInstance(), notNullValue()) } @Test fun `default loader is used without dev options`() { - assertThat(getInstance(), instanceOf(DefaultLoaders::class.java)) + assertThat(injector.getInstance(), instanceOf(DefaultLoaders::class.java)) } @Test fun `default loaders are used if no path is given`() { File(currentDir, "sone.properties").writeText("Developer.LoadFromFilesystem=true") - assertThat(getInstance(), instanceOf(DefaultLoaders::class.java)) + assertThat(injector.getInstance(), instanceOf(DefaultLoaders::class.java)) } @Test fun `debug loaders are used if path is given`() { File(currentDir, "sone.properties").writeText("Developer.LoadFromFilesystem=true\nDeveloper.FilesystemPath=/tmp") - assertThat(getInstance(), instanceOf(DebugLoaders::class.java)) + assertThat(injector.getInstance(), instanceOf(DebugLoaders::class.java)) } class TestObject { @@ -156,20 +183,49 @@ class SoneModuleTest { @Test fun `created objects are registered with event bus`() { - val injector = createInjector() - val eventBus: EventBus = getInstance(injector = injector) - val testObject = getInstance(injector = injector) + val eventBus: EventBus = injector.getInstance() + val testObject = injector.getInstance() val event = Any() eventBus.post(event) assertThat(testObject.ref.get(), sameInstance(event)) } - private fun createInjector(): Injector = SoneModule(sonePlugin) - .let { Guice.createInjector(it) } + @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() + } - private inline fun getInstance(annotation: Annotation? = null, injector: Injector = createInjector()): R = - annotation - ?.let { injector.getInstance(Key.get(object : TypeLiteral() {}, it)) } - ?: injector.getInstance(Key.get(object : TypeLiteral() {})) + @Test + fun `notification ticker is created as singleton`() { + injector.verifySingletonInstance(named("notification")) + } + + @Test + fun `ticker shutdown is created as singleton`() { + injector.verifySingletonInstance() + } }