我想为多个测试环境(生产、登台、开发)定义不同的数据库连接。在阅读了帖子“我如何为 sbt 测试指定带有 sbt 0.12.2 的配置文件? ”之后,似乎可以在早期版本的 Play 中使用以下 SBT 设置:
val main = play.Project(appName, appVersion, appDependencies).settings(
javaOptions in Test += "-Dconfig.file=conf/test.conf"
)
但是,如果我在 Build.scala 中使用此设置,则会收到以下错误:
not found: value javaOptions
所以我的问题是,如何为不同的测试环境定义不同的连接?
编辑: 一种可能的解决方法是在测试期间覆盖默认设置。这可以通过环境变量来完成。
object Config {
var defaultConfig = Map(
"db.default.user" -> "user",
"db.default.pass" -> "************"
)
def additionalConfiguration(): Map[String, _] = sys.env.getOrElse("PLAY_TEST_SCOPE", "") match {
case "development" => {
defaultConfig += "db.default.url" -> "jdbc:mysql://host:3306/development"
defaultConfig
}
case "staging" => {
defaultConfig += "db.default.url" -> "jdbc:mysql://host:3306/staging"
defaultConfig
}
case "production" => {
defaultConfig += "db.default.url" -> "jdbc:mysql://host:3306/production"
defaultConfig
}
case _ => {
throw new Exception("Environment variable `PLAY_TEST_SCOPE` isn't defined")
}
}
}
然后使用此配置运行一个假应用程序。
FakeApplication(additionalConfiguration = Config.additionalConfiguration())