4

我想针对 Play Slick 托管数据库编写数据库集成测试,并使用 Play 文档中描述的辅助方法应用和取消应用 Evolutions,Evolutions.applyEvolutions(database)Evolutions.cleanupEvolutions(database). 然而,这些需要一个play.api.db.Database无法从我所见的实例中获取的实例。该jdbc库与 play-slick 冲突,那么如何从 slick 获取数据库实例?我使用以下内容来获取一个用于运行 slick 查询的 slick 数据库 def:

val dbConfig = DatabaseConfigProvider.get[JdbcProfile]("my-test-db")(FakeApplication())  
import dbConfig.driver.api._
val db = dbConfig.db

谢谢,

莉安娜

4

1 回答 1

1

这是我使用 Guice 的方法:

我用 Guice 注入:

lazy val appBuilder = new GuiceApplicationBuilder()

lazy val injector = appBuilder.injector()

lazy val databaseApi = injector.instanceOf[DBApi] //here is the important line

(您必须导入 play.api.db.DBApi。)

在我的测试中,我只需执行以下操作(实际上我使用其他数据库进行测试):

override def beforeAll() = {
  Evolutions.applyEvolutions(databaseApi.database("default"))
}

override def afterAll() = {
  Evolutions.cleanupEvolutions(databaseApi.database("default"))
}

(我使用的是 Scalatest,但它与其他测试框架相同。)

于 2015-10-28T18:53:37.243 回答