3

我正在编写启动 Play 2.2.2 应用程序的集成测试(例如Helpers.running(fakeApplication) {...}。第一个测试完成没有错误,但下一个给出以下(删节的)堆栈跟踪:

java.sql.SQLException: Attempting to obtain a connection from a pool that has already been shutdown. 
Stack trace of location where pool was shutdown follows:
 java.lang.Thread.getStackTrace(Thread.java:1588)
 com.jolbox.bonecp.BoneCP.captureStackTrace(BoneCP.java:572)
 com.jolbox.bonecp.BoneCP.shutdown(BoneCP.java:161)
 com.jolbox.bonecp.BoneCPDataSource.close(BoneCPDataSource.java:143)
 play.api.db.BoneCPApi.shutdownPool(DB.scala:411)
 myApp.ApplicationTest$$anonfun$1.apply(ApplicationTest.scala:31)
    at com.jolbox.bonecp.BoneCP.getConnection(BoneCP.java:553)
    at controllers.Application$$anonfun$tests$1.apply(Application.scala:149)
    at play.api.mvc.ActionBuilder$$anonfun$apply$10.apply(Action.scala:221)
    at scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107)

我目前的解决方法是(根据这篇文章):

class MyBoneCPPlugin(app: play.api.Application) extends BoneCPPlugin(app) {

  override def onStop() {
    // Prevent stopping the plug-in to avoid "Attempting to obtain a connection from a pool that has already been 
    // shutdown" exceptions

    // super.onStop() 
  }
}

有没有更好的方法来做到这一点?根本问题是什么?在测试结束时关闭连接池很好,但我会认为第二次 Play 启动应用程序时会启动一个新的连接池?

4

0 回答 0