我想为多个测试环境(生产,登台,开发)定义不同的数据库连接。在阅读了帖子“How do I specify a config file with sbt 0.12.2 for sbt test?”后,似乎可以在早期版本的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())
答案 0 :(得分:8)
答案 1 :(得分:8)
我们可以混合上面的解决方案,将配置文件作为参数传递给sbt 这对于将测试集成到CI管道中非常有用
首先,在 Build.scala 文件中
val testOptions = "-Dconfig.file=conf/" + Option(System.getProperty("test.config")).getOrElse("application") + ".conf"
val main = PlayProject(appName, appVersion, appDependencies, mainLang = SCALA).settings(
javaOptions in Test += testOptions
)
然后,在命令行中使用 integ.conf
运行测试sbt -Dtest.config=integ test
使用默认的 application.conf
sbt test
答案 2 :(得分:5)
Play 2.5.x更新
不再需要显式导入导入Keys._,并且配置资源位置的vm参数已更改。
javaOptions in Test += "-Dconfig.resource=<conf_name>.conf"
答案 3 :(得分:4)
您可以使用备用配置文件从控制台运行您的应用程序,无论如何您需要使用-Dconfig.file
完整路径,因为存在一些问题...我无法用其他选项实现。有关unix环境中的示例:
play -Dconfig.file=/home/akkie/play/some-project/conf/local_akkie_dev.conf "~run 9123"
当然为了更容易启动,您可以创建用于调用此行的bash脚本。
修改:请注意,您无需在每个其他配置文件中编写整个配置,因为您只需 包含 在开始时配置,然后仅覆盖所需的属性:
include "application.conf"
key.to.override=blah