0

我正在使用 Scala Play 2.7.x(该项目可在此处获得 Play-Silhouette-Seed)并且想测试我的 daos。我首先把这个简单的放在一起来检查 2.7.x 中测试 play + slick + guice 的“新模式”是什么:

package models.daos

import java.util.UUID
import org.specs2.mock._
import org.specs2.mutable._
import utils.AwaitUtil
import javax.inject.Inject
import models.generated.Tables.LoginInfoRow

class LoginInfoDaoSpec @Inject() (loginInfoDao: LoginInfoDao) extends Specification with Mockito with AwaitUtil {

  "Creating a new LoginInfo" should {
    "save it in the empty database" in {
      loginInfoDao.create(LoginInfoRow(0, UUID.randomUUID().toString, UUID.randomUUID().toString))
      loginInfoDao.findAll.size should beEqualTo(1)
    }
  }
}

不幸的是,我的测试没有提供 guice 依赖项LoginInfoDao,然后我收到错误:

[play-silhouette-seed] $ testOnly models.daos.LoginInfoDaoSpec
[info] Done compiling.
[error] Can't find a suitable constructor with 0 or 1 parameter for class models.daos.LoginInfoDao
[info] ScalaTest
[info] Run completed in 1 second, 966 milliseconds.
[info] Total number of tests run: 0
[info] Suites: completed 0, aborted 0
[info] Tests: succeeded 0, failed 0, canceled 0, ignored 0, pending 0
[info] No tests were executed.
[error] Error: Total 1, Failed 0, Errors 1, Passed 0

如何让 guice 为我的测试用例加载所需的模块?

一个模块定义为:

class SilhouetteModule extends AbstractModule with ScalaModule {
  override def configure() {
    // ...
    bind[LoginInfoDao].to[LoginInfoDaoImpl]
    // ...
  }
}

我有一个application.test.conf可用的定义为:

include "application.conf"

slick.dbs {
  default {
    profile="slick.jdbc.MySQLProfile$"
    db.driver="com.mysql.cj.jdbc.Driver"
    db.url="jdbc:mysql://localhost:3306/mytestdb?useUnicode=true&searchpath=public&serverTimezone=CET"
    db.user="dev"
    db.password="12345"
  }
}
4

1 回答 1

2

您应该使用另一个数据库进行测试,H2 是常见的选择。

class Module extends AbstractModule with ScalaModule {
...
}

使用该名称,您需要让游戏知道有一个要加载的模块,如果您将其称为模块,它会自动知道要加载什么并且应该可以正常工作(如果您在测试中只需要 1 个模块)

如果这不起作用,请告诉我

于 2019-05-26T10:04:12.090 回答