我现在正在和Hibernate学习Spring。我有一个POJO模型类,该类带有Hibernate注释(称为Person,PersonDao接口),它是hibernate实现和PersonService类。我使用的是注释,因此在spring-config.xml中没有将其定义为bean。现在,我想为PersonService类编写一些JUnit4测试,但是我想在测试时使用其他数据库。这是我的spring-config.xml
<context:component-scan base-package="org.example" />
<tx:annotation-driven />
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost/example" />
<property name="username" value="root" />
<property name="password" value="pwd" />
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
<property name="annotatedClasses">
<list>
...
</list>
</property>
</bean>
我想在测试中使用jdbc:mysql:// localhost / example_test数据库。我该如何实现?
移至jdbc:mysql://localhost/example
配置文件(db.properties
)
database.uri = jdbc:mysql:// localhost / example
将此文件放在classpath中的某个位置(即src/main/resources
)
在Spring上下文中设置属性占位符并使用数据库URI属性键
<context:property-placeholder location="classpath:db.properties" />
...
<property name="url" value="${database.uri}" />
在测试类路径(src/test/resources
)中创建具有相同名称的配置文件
将数据库URI属性更改为测试值(jdbc:mysql://localhost/example_test
)
database.uri = jdbc:mysql:// localhost / example_test
利润
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句