私は好奇心旺盛なエラーで立ち往生しています。
私は小さなDBUnitテストを持っています:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:spring/testApplicationContext.xml")
@Category(Integrationtest.class)
@TestExecutionListeners({
DependencyInjectionTestExecutionListener.class,
DirtiesContextTestExecutionListener.class,
TransactionDbUnitTestExecutionListener.class
})
@DatabaseSetup("classpath:db/wbSchluesselwertData.xml")
public class KontaktrolleRepositoryIntegrationTest {
@Autowired
KontaktrolleRepository kontaktrolleRepository;
@Autowired
KontaktBeteiligterRepository kontaktBeteiligterRepository;
@Autowired
WbSchluesselwertRepository wbSchluesselwertRepository;
........
........
@Test
@Transactional
public void that_Kontaktrolle_Is_Inserted_Into_DB() throws Exception {
WbSchluesselwert wbRolle1 = wbSchluesselwertRepository.findOne(new Long(11));
KontaktBeteiligter b1 = new KontaktBeteiligterBuilderAws(erzeugtAm).withName("Posteingang")
.withStandort("Cologne").withOrganization("private").build();
KontaktBeteiligter result = kontaktBeteiligterRepository.save(b1);
Kontaktrolle r1 = new KontaktrolleBuilder(erzeugtAm).withBeteiligter(result).withRollenartId(wbRolle1).build();
Kontaktrolle resultRolle = kontaktrolleRepository.save(r1);
assertNotNull(resultRolle);
assertNotNull(resultRolle.getKontaktrolleId());
assertThat(resultRolle.getKontaktrolleId(), greaterThan(0L));
}
これ以上何もない。最初に、DBUnit (wbSchluesselwertData.xml) によって事前に入力されたエントリを検索します。その後、組み込みの H2 メモリ データベース内に Spring Data CrudRepository を介して 2 つのエントリを保存したいと考えています。
このデータソースは、HibernateJpaVendorAdapter と LocalContainerEntityManagerFactoryBean 内のアダプター自体によってラップされます。
<bean id="emf"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="jpaVendorAdapter" ref="jpaVendorAdapter" />
<property name="packagesToScan" value="de.axa.chronik.persistence.domain" />
</bean>
上記の単体テストを実行すると、次のエラーが発生しました。
21:21:55,808 DEBUG JpaTransactionManager:594 - Closing JPA EntityManager [org.hibernate.ejb.EntityManagerImpl@f6b9e9] after transaction
21:21:55,808 DEBUG EntityManagerFactoryUtils:338 - Closing JPA EntityManager
21:21:55,809 WARN TestContextManager:397 - Caught exception while allowing TestExecutionListener [com.github.springtestdbunit.TransactionDbUnitTestExecutionListener@4c4b3e] to process 'after' execution for test: method [public void de.axa.chronik.persistence.repository.KontaktrolleRepositoryIntegrationTest.that_Kontaktrolle_Is_Inserted_Into_DB() throws java.lang.Exception], instance [de.axa.chronik.persistence.repository.KontaktrolleRepositoryIntegrationTest@be41d5], exception [null]
org.springframework.transaction.TransactionSystemException: Could not roll back JPA transaction; nested exception is javax.persistence.PersistenceException: unexpected error when rollbacking
at org.springframework.orm.jpa.JpaTransactionManager.doRollback(JpaTransactionManager.java:544)...............
...........
Caused by: org.hibernate.TransactionException: unable to rollback against JDBC connection
at org.hibernate.engine.transaction.internal.jdbc.JdbcTransaction.doRollback(JdbcTransaction.java:167)
at org.hibernate.engine.transaction.spi.AbstractTransactionImpl.rollback(AbstractTransactionImpl.java:209)
... 33 more
Caused by: org.h2.jdbc.JdbcSQLException: Das Objekt wurde bereits geschlossen
The object is already closed [90007-175]
at org.h2.message.DbException.getJdbcSQLException(DbException.java:332)
そのため、接続が閉じられているため、その後のエンティティの永続化の試みは失敗します。休止状態の永続化と私が無視するSpring DBUnitの使用の間に既存の影響はありますか?
どんな助けでも大歓迎です。よろしくお願いします。
よろしく、ボードー