Jul*_*enD 6 testing scala playframework play-slick playframework-2.5
为了让scalatest中有一个数据库可用,我使用这个SO问题PlaySpec启发的默认扩展:
trait ResetDbSpec extends PlaySpec with BeforeAndAfterAll {
lazy val appBuilder = new GuiceApplicationBuilder()
lazy val injector = appBuilder.injector()
lazy val databaseApi = injector.instanceOf[DBApi]
override def beforeAll() = {
Evolutions.applyEvolutions(databaseApi.database("default"))
}
override def afterAll() = {
Evolutions.cleanupEvolutions(databaseApi.database("default"))
databaseApi.database("default").shutdown()
}
}
Run Code Online (Sandbox Code Playgroud)
它在套件启动时应用数据库演进,并在套件结束时恢复它们.然后测试看起来像
class ProjectsSpec extends ResetDbSpec with OneAppPerSuite { ...
Run Code Online (Sandbox Code Playgroud)
在添加了更多这样的测试之后,我遇到了一些问题,当我单独运行它们时,某些测试会成功,但是会出现此错误:
com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException:数据源拒绝建立连接,来自服务器的消息:"连接太多"
从上面的代码可以看出,我试图添加该行
databaseApi.database("default").shutdown()
Run Code Online (Sandbox Code Playgroud)
在afterAll()减轻这一点,但它没有任何效果.我试图不并行运行测试,但也没有效果.我在哪里打开数据库连接而不关闭它们,我应该在哪里打电话shutdown()?
NB我使用Play 2.5.10和Slick 3.1.
我进行了很多测试(大约 500 个),但没有收到此错误,我与您的代码的唯一区别是我添加了
databaseApi.database("default").getConnection().close()
Run Code Online (Sandbox Code Playgroud)
和
Play.stop(fakeApplication)
Run Code Online (Sandbox Code Playgroud)
用于集成测试。
如果它改变了什么,请告诉我。
| 归档时间: |
|
| 查看次数: |
1274 次 |
| 最近记录: |