加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

scala – 使用数据库进行测试:“连接太多”

发布时间:2020-12-16 18:49:36 所属栏目:安全 来源:网络整理
导读:为了让 scalatest中的数据库具有evolutions,我使用了受 this SO question启发的默认PlaySpec的扩展: trait ResetDbSpec extends PlaySpec with BeforeAndAfterAll { lazy val appBuilder = new GuiceApplicationBuilder() lazy val injector = appBuilder.i
为了让 scalatest中的数据库具有evolutions,我使用了受 this SO question启发的默认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()
  }
}

它在套件启动时应用数据库演进,并在套件结束时恢复它们.然后测试看起来像

class ProjectsSpec extends ResetDbSpec with OneAppPerSuite { ...

在添加了更多这样的测试之后,我遇到了一些问题,当我单独运行它们时,某些测试会成功,但是会出现此错误:

com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected establishment of connection,message from server: “Too many connections”

从上面的代码可以看出,我试图添加该行

databaseApi.database("default").shutdown()

在afterAll()中缓解,但它没有任何效果.我试图不并行运行测试,但也没有效果.我在哪里打开数据库连接而不关闭它们,我应该在哪里调用shutdown()?

注:我使用Play 2.5.10和Slick 3.1.

解决方法

我有很多测试(大约500),我没有得到这个错误,我的代码唯一的区别是我添加

databaseApi.database("default").getConnection().close()

Play.stop(fakeApplication)

用于集成测试.

如果它改变了什么,请告诉我.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读