org.hibernate.exception.JDBCConnectionException: Невозможно освободить соединение JDBC - PullRequest
0 голосов
/ 13 ноября 2018

Ситуация: я пишу юнит-тест для класса DAO, используя Hibernate и Maven surefire.Мы решили создать test_db из test_template перед модульными тестами и отбросить test_db после тестов.

После того, как я закончу код и протестирую его с помощью mvn test, он будет успешным, когда я тестирую только один тестовый класс: mvntest -Dtest = com.package.DummyTest, но не удалось, когда я тестирую все тестовые классы: mvn test -Dtest = com.package. * Test

Методы запросов setup (), teardown () и hibernate, а такжетрассировка стека ошибок показана ниже:

setUp ()

@BeforeClass
public static void setUpJdbc() throws IOException, InterruptedException, SQLException {
        Connection c = DriverManager.getConnection("jdbc:postgresql://localhost:5432/default_db", "user_name", "pw");
        Statement statement = c.createStatement();
        statement.executeUpdate("create database test_db with template test_template;");
        statement.close();
        c.close();
    }

tearDown ()

@AfterClass
public static void tearDownJdbc() throws SQLException {
            Connection c = DriverManager.getConnection("jdbc:postgresql://localhost:5432/default_db", "user_name", "pw");
            Statement statement = c.createStatement();
            statement.executeUpdate("REVOKE CONNECT ON DATABASE test_db FROM public;");
            statement.execute("SELECT pid, pg_terminate_backend(pid) \n" + 
                    "FROM pg_stat_activity \n" + 
                    "WHERE datname = 'test_db' AND pid <> pg_backend_pid();");
            statement.executeUpdate("drop database if exists test_db;");
            statement.close();
            c.close();
    }

Метод запроса Hibernate:

public List<Object> query(String sqlquery) throws DatabaseConnectionException {
    Session session = null;
    Transaction transcation = null;
    List<Object> sqlQueryResults = null;
    try {
        session = factory.openSession();
        transcation = session.beginTransaction();
        Query query = session.createNativeQuery(sqlquery);
        sqlQueryResults = query.list();
        transcation.commit();
    } catch (SQLGrammarException e) {
        if (transcation != null)
            transcation.rollback();
        throw new DatabaseConnectionException();
    } catch (HibernateException e) {
        if (transcation != null)
            transcation.rollback();
        throw new DatabaseConnectionException();
    } finally {
        if (session != null)
            session.close();
    }
    return sqlQueryResults;
}

Я не могу понять, что здесь происходит.Кажется, я не могу запустить session.close () должным образом.

org.hibernate.exception.JDBCConnectionException: Unable to release JDBC Connection
    at org.hibernate.exception.internal.SQLStateConversionDelegate.convert(SQLStateConversionDelegate.java:115)
    at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:111)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:97)
    at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.releaseConnection(LogicalConnectionManagedImpl.java:199)
    at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.close(LogicalConnectionManagedImpl.java:239)
    at org.hibernate.engine.jdbc.internal.JdbcCoordinatorImpl.close(JdbcCoordinatorImpl.java:189)
    at org.hibernate.internal.AbstractSharedSessionContract.close(AbstractSharedSessionContract.java:311)
    at org.hibernate.internal.SessionImpl.close(SessionImpl.java:423)
    at com.dummy.DataLayer.query(DataLayer.java:173)
    at com.dummy.MITypeCompositeDAO.getLatestExecutionForUser(MITypeCompositeDAO.java:71)
    at com.dummy.MITypeCompositeDAO.getMITypeCompositeForUser(MITypeCompositeDAO.java:137)
    at com.dummy.MITypeCompositeDAOTest.testGetMITypeCompositeForUser(MITypeCompositeDAOTest.java:62)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at org.junit.runners.BlockJUnit4ClassRunner.runNotIgnored(BlockJUnit4ClassRunner.java:79)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:71)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:49)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
    at org.apache.maven.surefire.junit4.JUnit4Provider.execute(JUnit4Provider.java:369)
    at org.apache.maven.surefire.junit4.JUnit4Provider.executeWithRerun(JUnit4Provider.java:275)
    at org.apache.maven.surefire.junit4.JUnit4Provider.executeTestSet(JUnit4Provider.java:239)
    at org.apache.maven.surefire.junit4.JUnit4Provider.invoke(JUnit4Provider.java:160)
    at org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:373)
    at org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:334)
    at org.apache.maven.surefire.booter.ForkedBooter.execute(ForkedBooter.java:119)
    at org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:407)
Caused by: org.postgresql.util.PSQLException: This connection has been closed.
    at org.postgresql.jdbc.PgConnection.checkClosed(PgConnection.java:766)
    at org.postgresql.jdbc.PgConnection.setAutoCommit(PgConnection.java:712)
    at org.hibernate.engine.jdbc.connections.internal.PooledConnections.add(PooledConnections.java:68)
    at org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.closeConnection(DriverManagerConnectionProviderImpl.java:195)
    at org.hibernate.internal.NonContextualJdbcConnectionAccess.releaseConnection(NonContextualJdbcConnectionAccess.java:46)
    at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.releaseConnection(LogicalConnectionManagedImpl.java:196)
    ... 35 more

Ситуация довольно сложная, поэтому, если вам нужна дополнительная информация, пожалуйста, дайте мне знать.

Я открытна любые мнения и советы, и я готов попробовать все, что вы предоставляете.Заранее спасибо!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...