0

(我有多个相关问题,所以我将它们突出显示为粗体)

我有一个播放应用程序

  • 播放:2.6.19
  • 斯卡拉:2.12.6
  • h2:1.4.197
  • PostgreSQL:42.2.5
  • 玩滑/玩滑进化:3.0.1
  • 光滑-pg:0.16.3

我正在为 DAO 添加一个测试,我相信它应该在一个 h2 内存数据库上运行,该数据库在测试开始时创建,在测试结束时清除。

但是,我的测试总是在我配置和使用的 PostgreSQL 数据库上运行。

# application.conf
slick.dbs.default.profile="slick.jdbc.PostgresProfile$"
slick.dbs.default.db.driver="org.postgresql.Driver"
slick.dbs.default.db.url="jdbc:postgresql://localhost:5432/postgres"

这是我的测试test/dao/TodoDAOImplSpec.scala

package dao

import play.api.inject.guice.GuiceApplicationBuilder
import play.api.test.{Injecting, PlaySpecification, WithApplication}

class TodoDAOImplSpec extends PlaySpecification {
  val conf = Map(
    "slick.dbs.test.profile" -> "slick.jdbc.H2Profile$",
    "slick.dbs.test.db.driver" -> "org.h2.Driver",
    "slick.dbs.test.db.url" -> "jdbc:h2:mem:test;MODE=PostgreSQL;DB_CLOSE_DELAY=-1;DATABASE_TO_UPPER=FALSE"
  )
  val fakeApp = new GuiceApplicationBuilder().configure(conf).build()
  //val fakeApp = new GuiceApplicationBuilder().configure(inMemoryDatabase()).build()
  //val fakeApp = new GuiceApplicationBuilder().configure(inMemoryDatabase("test")).build()
  "TodoDAO" should {
    "returns current state in local pgsql table" in new WithApplication(fakeApp) with Injecting {
      val todoDao = inject[TodoDAOImpl]
      val result = await(todoDao.index())
      result.size should_== 0
    }
  }
}

对于fakeApp,我尝试了所有三个,但它们都没有按预期工作 - 我的测试仍然在我的本地 PostgreSQL 表上运行(其中有 3 个待办事项),所以测试失败。

我尝试过/发现的:

首先,inMemoryDatabase()简单地返回一个,它看起来与我自己的地图Map("db.<name>.driver"->"org.h2.Driver", "db.<name>.url"->""jdbc:h2:mem:play-test-xxx")非常相似。conf但是,有两个主要区别:

  • inMemoryDatabasedb.<name>.xxx在我的conf地图使用时使用slick.dbs.<name>.db.xxx哪一个应该是正确的?

其次,将conf地图的键重命名为“slick.dbs.default.profile”、“slick.dbs.default.db.driver”和“slick.dbs.default.db.url”会报错。

[error] p.a.d.e.DefaultEvolutionsApi - Unknown data type: "status_enum"; SQL statement:
ALTER TABLE todo ADD COLUMN status status_enum NOT NULL [50004-197] [ERROR:50004, SQLSTATE:HY004]

cannot create an instance for class dao.TodoDAOImplSpec

  caused by @79bg46315: Database 'default' is in an inconsistent state!

这个发现很有趣——它与我使用 PostgreSQL ENUM 类型和slick-pg有关吗?(参见h2 的 slick-pg 问题)。这是否意味着这是运行 h2 内存测试的正确配置?如果是这样,问题就变成了How to fake PostgreSQL ENUM in h2

第三,我遵循这个线程sbt '; set javaOptions += "-Dconfig.file=conf/application-test.conf"; test'使用测试配置文件运行conf/application-test.conf

include "application.conf"

slick.dbs.default.profile="slick.jdbc.H2Profile$"
slick.dbs.default.db.driver="org.h2.Driver"
slick.dbs.default.db.url="jdbc:h2:mem:test;MODE=PostgreSQL;DB_CLOSE_DELAY=-1;DATABASE_TO_UPPER=FALSE"

毫不奇怪,我得到了与第二次试验相同的错误。

在我看来,第二次和第三次试验指向了正确的方向(将对此进行研究)。但是为什么我们必须设置namedefault还有其他更好的方法吗?

4

1 回答 1

0

在游戏中,默认数据库是default。但是,您可以将其更改为所需的任何其他数据库名称,但是您还需要添加数据库名称。例如,我想要一个包含表的comment数据库user

CREATE TABLE comment.User(
id                      int(250)         NOT NULL AUTO_INCREMENT,
username                varchar(255), 
comment                 varchar(255), 
PRIMARY KEY             (id)); 

然后我需要对其进行配置以连接到它(将其添加到application.conf文件中):

db.comment.url="jdbc:mysql://localhost/comment"
db.comment.username=admin-username
db.comment.password="admin-password"

test如上所述,您可以拥有用于测试的数据库并在测试中使用它。

本地数据库测试:为什么不像生产环境那样在本地拥有数据库?数据不存在,在本地运行测试不会触及生产数据库;为什么你需要一个额外的数据库?

状态不一致:这是您编写的 MYSQL 更改数据库中当前数据库的状态时,这可能是基于创建新表或您想要删除它时。

显然也status_enum不能识别为 MySQL 命令。如果不确定,请尝试要在 MySQL 控制台中使用的命令。

于 2018-09-23T15:58:36.227 回答