为了让
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)
用于集成测试.
如果它改变了什么,请告诉我.