将应用程序迁移到Play 2.4并将依赖注入引入应用程序的控制器后,我在运行单元测试时收到“池已关闭”。受影响的测试是这样的:
@RunWith(classOf[JUnitRunner])
class ApplicationSpec extends Specification {
"Application" should {
"doSomething" in running(TestUtil.app) {
val myId = IdGen.newId("someone")
...
}
}
}
IdGen类看起来像:
object IdGen {
def newId(name: String): ClientCredentials = {
DB.withTransaction("myDb") { implicit conn =>
...
}
}
}
使用
进行DB.withTransaction()调用时测试失败[error] Pool has been shutdown (HikariDataSource.java:89)
[error] com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:89)
[error] play.api.db.DefaultDatabase.getConnection(Databases.scala:143)
[error] play.api.db.DefaultDatabase.withConnection(Databases.scala:153)
[error] play.api.db.DefaultDatabase.withTransaction(Databases.scala:162)
[error] play.api.db.DB$.withTransaction(DB.scala:72)
[error] com.example.idGen$.newId...
我正在使用
初始化TestUtil.appobject TestUtil {
lazy val app = new GuiceApplicationBuilder()
.configure(defaultConfig ++ Helpers.inMemoryDatabase("myDB"))
.bindings(new TestModule) // Mock injections for test
.build
}
显然,我错过了让数据库启动并运行测试的东西,但我不确定是什么。
答案 0 :(得分:0)
解决了这个问题。
尝试用def替换lazy val,正如这个问题所回答:Testing: FakeApplication ignoring additionalConfiguration
这解决了这个问题。
如果有人可以解释原因,会爱吗?
答案 1 :(得分:0)
这个问题让我感到困惑,因为我在代码中持有应用程序状态。由于测试通常每个都从一个FakeApplication
实例获得自己的FakeApplication
,squireled-away状态,当在另一个FakeApplication
实例的上下文中使用时,将导致问题。一个具体的例子是play.api.Play.current
- 这需要为每个FakeApplication
实例重新评估,并且不应该在代码中保留(仅在评估一次之后)。