H2 데이터베이스와 & 봄과 함께 DBUnit을 사용합니다. 잘 작동 :
@SpringApplicationContext({ "classpath:test-context-dbunit.xml" })
@Transactional(TransactionMode.ROLLBACK)
@DataSet
public class ApplicationDaoTest extends UnitilsTestNG {
@SpringBeanByType
private ApplicationDao applicationDao;
@Test
public void findAll() throws Exception {
List<Application> actual = applicationDao.findAll();
assertNotNull(actual);
assertEquals(actual.size(), 3);
}
}
데이터는 XML 파일에 설정됩니다 Spring 테스트 맥락에서
<?xml version="1.0" encoding="UTF-8"?>
<dataset>
<APPLICATION APPLICATION_ID="1" name="APP3" enabled="1" application_type="TRADE" api_key="AK1" auto_create_topics="1" />
<APPLICATION APPLICATION_ID="2" name="APP1" enabled="1" application_type="TRADE" api_key="AK2" auto_create_topics="1" />
<APPLICATION APPLICATION_ID="3" name="APP2" enabled="0" application_type="TRADE" api_key="AK3" auto_create_topics="1" />
</dataset>
당신 같은 당신의 데이터 소스를 정의 방언으로
<bean id="dataSource" class="org.unitils.database.UnitilsDataSourceFactoryBean"/>
은 사용 : org.hibernate.dialect.H2Dialect
마지막으로 클래스 경로의 unitils.properties는
0입니다.
database.driverClassName=org.h2.Driver
database.url=jdbc:h2:mem:test
database.user=sa
database.password=
database.schemaNames=public
database.dialect=hsqldb
UPDATE
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="packagesToScan" value="..."/>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.H2Dialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">create-drop</prop>
</props>
</property>
</bean>