akk*_*kie 13 playframework-2.1
我想为多个测试环境(生产,登台,开发)定义不同的数据库连接.在阅读了文章" 如何使用sbt 0.12.2为sbt test指定配置文件? "后,似乎可以在早期版本的Play中使用以下SBT设置:
val main = play.Project(appName, appVersion, appDependencies).settings(
javaOptions in Test += "-Dconfig.file=conf/test.conf"
)
Run Code Online (Sandbox Code Playgroud)
但是,如果我在Build.scala中使用此设置,则会收到以下错误:
not found: value javaOptions
Run Code Online (Sandbox Code Playgroud)
所以我的问题是,如何为不同的测试环境定义不同的连接?
编辑: 可能的解决方法是在测试期间覆盖默认设置.这可以使用环境变量来完成.
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")
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后使用此配置运行假应用程序.
FakeApplication(additionalConfiguration = Config.additionalConfiguration())
Run Code Online (Sandbox Code Playgroud)
javaOptions包含在Keys对象中.
确保在Build.scala文件中使用正确的导入:
import Keys._
Run Code Online (Sandbox Code Playgroud)
我们可以混合上面的解决方案,将配置文件作为参数传递给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
)
Run Code Online (Sandbox Code Playgroud)
然后,在命令行中使用integ.conf运行测试
sbt -Dtest.config=integ test
Run Code Online (Sandbox Code Playgroud)
使用默认的application.conf
sbt test
Run Code Online (Sandbox Code Playgroud)
Play 2.5.x的更新
导入Keys._的显式导入不再需要,并且配置资源位置的vm参数已更改.
javaOptions in Test += "-Dconfig.resource=<conf_name>.conf"
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8452 次 |
| 最近记录: |