From 0a1cb6c99438a8c265c9caebd1f150b84b9ac07a Mon Sep 17 00:00:00 2001 From: Oleksandr Mordyk Date: Thu, 31 Oct 2024 04:49:04 -0700 Subject: [PATCH] issue 597: Rework unit-test for ExchangeConfig - Increased the number of test cases to cover corner cases. Signed-off-by: Oleksandr Mordyk --- .../exchangeapi/ExchConfigSuite.scala | 25 ------- .../TestExchConfiguration.scala | 73 +++++++++++++++++++ 2 files changed, 73 insertions(+), 25 deletions(-) delete mode 100644 src/test/scala/org/openhorizon/exchangeapi/ExchConfigSuite.scala create mode 100644 src/test/scala/org/openhorizon/exchangeapi/utility/exchconfiguration/TestExchConfiguration.scala diff --git a/src/test/scala/org/openhorizon/exchangeapi/ExchConfigSuite.scala b/src/test/scala/org/openhorizon/exchangeapi/ExchConfigSuite.scala deleted file mode 100644 index cdc7da1f..00000000 --- a/src/test/scala/org/openhorizon/exchangeapi/ExchConfigSuite.scala +++ /dev/null @@ -1,25 +0,0 @@ -package org.openhorizon.exchangeapi - -import org.scalatest.funsuite.AnyFunSuite -import org.junit.runner.RunWith -import org.scalatestplus.junit.JUnitRunner -import org.openhorizon.exchangeapi._ -import org.openhorizon.exchangeapi.utility.Configuration - -/** - * Tests for the Version and VersionRange case classes - */ -@RunWith(classOf[JUnitRunner]) -class ExchConfigSuite extends AnyFunSuite { - test("ExchConfig tests") { - Configuration.reload() - // Note: this test needs to work with the default version of config.json that is in src/main/resources (so that 'make test' in travis works) - assert(Configuration.getConfig.getInt("api.limits.maxNodes") === 45000) - assert(Configuration.getConfig.getInt("api.limits.maxAgreements") === 0) - assert(Configuration.getConfig.getInt("api.limits.maxMessagesInMailbox") === 0) - assert(Configuration.getConfig.getString("exchange-db-connection.dataSourceClass") === "org.postgresql.ds.PGSimpleDataSource") - // assert(Configuration.getConfig.getInt("api.db.minPoolSize") === 1) - // assert(Configuration.getConfig.getInt("api.db.acquireIncrement") === 1) - // assert(Configuration.getConfig.getInt("api.db.maxPoolSize") === 50) - } -} \ No newline at end of file diff --git a/src/test/scala/org/openhorizon/exchangeapi/utility/exchconfiguration/TestExchConfiguration.scala b/src/test/scala/org/openhorizon/exchangeapi/utility/exchconfiguration/TestExchConfiguration.scala new file mode 100644 index 00000000..ac85131c --- /dev/null +++ b/src/test/scala/org/openhorizon/exchangeapi/utility/exchconfiguration/TestExchConfiguration.scala @@ -0,0 +1,73 @@ +package org.openhorizon.exchangeapi + +import org.scalatest.funsuite.AnyFunSuite +import org.openhorizon.exchangeapi._ +import org.openhorizon.exchangeapi.utility.Configuration + +import com.typesafe.config.{Config, ConfigFactory} +import org.scalatest.BeforeAndAfterEach + +class TestConfiguration extends AnyFunSuite with BeforeAndAfterEach { + + override def beforeEach(): Unit = { + Configuration.reload() + } + + test("Should load the configuration successfully") { + val config: Config = Configuration.getConfig + assert(config != null) + } + + test("Should validate necessary configuration keys") { + val config: Config = Configuration.getConfig + assert(config.hasPath("api")) + assert(config.hasPath("exchange-db-connection")) + } + + test ("Should set logback properties correctly") { + val config: Config = Configuration.getConfig + // Extract expected values from the config + val logbackConfigValues = Map( + "log.logback.appenderrefmodelhandler" -> config.getString("logback.core.model.processor.AppenderRefModelHandler"), + "log.logback.loggermodelhandler" -> config.getString("logback.classic.model.processor.LoggerModelHandler"), + "log.hikari.config" -> config.getString("logback.hikari.HikariConfig"), + "log.hikari.datasource" -> config.getString("logback.hikari.HikariDataSource"), + "log.hikari.pool" -> config.getString("logback.hikari.pool.HikariPool"), + "log.hikari.pool.base" -> config.getString("logback.hikari.pool.PoolBase"), + "log.guavacache" -> config.getString("logback.scalacache.guava.GuavaCache"), + "log.action" -> config.getString("logback.slick.basic.BasicBackend.action"), + "log.stream" -> config.getString("logback.slick.basic.BasicBackend.stream"), + "log.qcomp" -> config.getString("logback.slick.compiler-log"), + "log.jdbc.driver" -> config.getString("logback.slick.jdbc.DriverDataSource"), + "log.jdbc.bench" -> config.getString("logback.slick.jdbc.JdbcBackend.benchmark"), + ) + + logbackConfigValues.foreach { case (key, expectedValue) => + assert(System.getProperty(key) == expectedValue, "Expected $key to be $expectedValue, but was ${System.getProperty(key)}") + } + } + + test ("Allow reloading of configuration") { + val initialConfig: Config = Configuration.getConfig + + // Simulate a reload + Configuration.reload() + val reloadedConfig: Config = Configuration.getConfig + + // Verify that the config remains the same (or check for specific changes) + assert(initialConfig == reloadedConfig, "Reloaded config should be the same as initial") + } + + test ("Should have correct ExchConfig values") { + // Assertions based on the expected values in your config.json + assert(Configuration.getConfig.getInt("api.limits.maxNodes") === 45000) + assert(Configuration.getConfig.getInt("api.limits.maxAgreements") === 0) + assert(Configuration.getConfig.getInt("api.limits.maxMessagesInMailbox") === 0) + assert(Configuration.getConfig.getString("exchange-db-connection.dataSourceClass") === "org.postgresql.ds.PGSimpleDataSource") + + // Uncomment if you want to test these as well + // assert(Configuration.getConfig.getInt("api.db.minPoolSize") === 1) + // assert(Configuration.getConfig.getInt("api.db.acquireIncrement") === 1) + // assert(Configuration.getConfig.getInt("api.db.maxPoolSize") === 50) + } +}