如何应用evolutions从DatabaseConfigProvider测试数据库

问题描述 投票:0回答:1

我想测试dao(play 2.6.21, play-slick 3.0.3):

@Singleton
class MyDao @Inject()(@NamedDatabase("default") protected val dbConfigProvider: DatabaseConfigProvider)
                             (implicit val sc: ExecutionContext)
  extends HasDatabaseConfigProvider[JdbcProfile] {
  ...

}

我将测试数据库的数据库配置放在测试资源中:

slick.dbs.default {
  profile = "slick.jdbc.PostgresProfile$"
  endpoint = "localhost:12345"
  schema = "my_test_schemma"

  db {
    driver = "org.postgresql.Driver"
    url = "jdbc:postgresql://"${slick.dbs.default.endpoint}"/"${slick.dbs.default.schema}""
  }
}

在测试中,我想申请进化:

class MyDaoSpec extends FlatSpec with GuiceFakeApplicationFactory {

  implicit lazy val app: Application = fakeApplication()

  "dao" should "something" in {

    val conf = app.injector.instanceOf[DatabaseConfigProvider]
    val db = app.injector.instanceOf[Database]
    Evolutions.applyEvolutions(db)

    val dao = app.injector.instanceOf[MyDao]
    //tests...

  }

}

但它给了我错误:

instanceOf[Database]的Guice配置错误:

1)没有绑定play.api.db.Database的实现。找到play.api.db.Database

那么我如何访问数据库并应用进化呢?

我发现,我需要使用EvolutionComponents,但不明白如何使用它

playframework guice slick play-slick
1个回答
0
投票

我的错误是,我添加了以下依赖项:

libraryDependencies ++= Seq(evolutions, jdbc)

但是正确的是:

"com.typesafe.play" %% "play-slick-evolutions" % "3.0.3",

在config中没有特殊的测试步骤:

play.evolutions.enabled = true
play.evolutions.autoApply = true
© www.soinside.com 2019 - 2024. All rights reserved.