✅ Don’t run some tests in parallel
[Sone.git] / src / test / kotlin / net / pterodactylus / sone / main / SoneModuleTest.kt
index 83d3535..c628334 100644 (file)
@@ -1,36 +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.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<PluginL10n>()
        private val sonePlugin = mock<SonePlugin>().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 +133,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 +152,11 @@ class SoneModuleTest {
        }
 
        @Test
+       fun `translation is bound correctly`() {
+               assertThat(injector.getInstance<Translation>(), notNullValue())
+       }
+
+       @Test
        fun `default loader is used without dev options`() {
                assertThat(injector.getInstance<Loaders>(), instanceOf(DefaultLoaders::class.java))
        }
@@ -165,4 +190,42 @@ class SoneModuleTest {
                assertThat(testObject.ref.get(), sameInstance(event))
        }
 
+       @Test
+       fun `core is created as singleton`() {
+               injector.verifySingletonInstance<Core>()
+       }
+
+       @Test
+       fun `core is registered with event bus`() {
+               val eventBus = mock<EventBus>()
+               val injector = createInjector(
+                               SoneModule(sonePlugin, eventBus),
+                               FreenetInterface::class.isProvidedByDeepMock(),
+                               PluginRespiratorFacade::class.isProvidedByDeepMock(),
+                               PluginConnector::class.isProvidedByDeepMock()
+               )
+               val core = injector.getInstance<Core>()
+               verify(eventBus).register(core)
+       }
+
+       @Test
+       fun `metrics registry is created as singleton`() {
+               injector.verifySingletonInstance<MetricRegistry>()
+       }
+
+       @Test
+       fun `wot connector is created as singleton`() {
+               injector.verifySingletonInstance<WebOfTrustConnector>()
+       }
+
+       @Test
+       fun `notification ticker is created as singleton`() {
+               injector.verifySingletonInstance<ScheduledExecutorService>(named("notification"))
+       }
+
+       @Test
+       fun `ticker shutdown is created as singleton`() {
+               injector.verifySingletonInstance<TickerShutdown>()
+       }
+
 }