我有一套系统测试使用Spring的JUnit运行,数据库的配置是这样的:刷新数据库连接
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="org.postgresql.Driver" />
<property name="url" value="${clustercatalog.jdbc.url}" />
<property name="username" value="${clustercatalog.jdbc.username}" />
<property name="password" value="${clustercatalog.jdbc.password}" />
<property name="initialSize" value="5" />
<property name="maxActive" value="50" />
<property name="poolPreparedStatements" value="true" />
<property name="maxOpenPreparedStatements" value="100" />
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="packagesToScan" value="com.xxx" />
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
<prop key="hibernate.show_sql">${jdbc.show.sql}</prop>
<prop key="hibernate.id.new_generator_mappings">true</prop>
</props>
</property>
<property name="namingStrategy" ref="namingStrategy" />
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<tx:annotation-driven />
的测试用例中,我运行一些的设置bash脚本,该脚本从先前完成的备份中在底层PostgreSQL数据库上运行pg_restore。这是因为我需要在每个测试方法之前使数据库的状态保持一致。这种还原是在用@BeforeTransaction进行注解的方法中完成的。
测试类都被注解
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration({ "/systemTests-applicationContext.xml", "/applicationContext.xml" })
@TransactionConfiguration(defaultRollback = false)
@Transactional()
在测试中,当我执行使用当前Hibernate的Session的代码,它不会看到已恢复的表。当我重新启动整个测试然后看到他们,但显然这是我想要的,但它证明了数据库是好的,但是当我做pg_restore时,Spring/Hibernate丢失了。我得到SQLGrammarException表,该表不存在。
我正在寻找一种方法来手动重新连接到数据库。我怎样才能做到这一点?我应该以某种方式在sessionFactory或某些Spring组件上执行此操作吗?