SimpleJdbcTemplate jdbcTemplate = new SimpleJdbcTemplate(dataSource);
The query is expected to be a single row/single column query that results in an int value.
String sql = "SELECT COUNT(1) FROM bmw_users";
int result = jdbcTemplate.queryForInt(sql);
The results will be mapped to a List (one entry for each row) of Maps (one entry for each column, using the column name as the key).
String sql = "SELECT * FROM bmw_users WHERE city=? AND user_gender=? ";
List<Map> resutls = jdbcTemplate.queryForList(sql, "杭州","m");
like queryForList but mapping each row to a Java object
String sql = "SELECT user_id userId,nick,user_gender sex FROM bmw_users WHERE city=? AND user_gender=?";
List resutls = jdbcTemplate.query(sql, ParameterizedBeanPropertyRowMapper.newInstance(User.class),"杭州","m");
String sql = "DELETE FROM bmw_users WHERE id=? ";
jdbcTemplate.update(sql, “1111”);
对SimpleJdbcTemplate的介绍就到这里,更多的用法可参考其JavaDoc或源码。
2.2 思考&实践
由于测试过程中用到的sql不会很复杂,我们利用SimpleJdbcTemplate可以封装一些常用的操作,在用例代码中甚至不需要编写sql语句即可完成数据库操作。下面的例子展示了运用封装的JdbcTestUtil根据条件查询某表的数据。Map args = new HashMap();
args.put("nick", "tbtest561");
List results = JdbcTestUtil.queryData(jdbcTemplate, "bmw_users", args);
JdbcTestUtil的更多用法可参考svn…
3 TestContext
TestContext本来是为了测试基于Spring的应用程序而开发的,其实在非Spring程序测试中一样可以运用它,方便的解决配置等问题,而且
其提供的监听器机制为我们自定义工具对用例运行进行细微控制提供了良好的思路。下面通过简单的示例入手,接着通过分析源码,找出了可为我们所用的扩展点。
3.1 合理准备配置文件
这个在基类文件中引入,子类配置会自动继承。这是个最大化的文件,基本包含了所有声明。 。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd"
default-lazy-init="true">
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:jdbc.properties</value>
</list>
</property>
</bean>
<!-- 使用annotation 自动注册bean -->
<context:component-scan base-package="com.taobao"/>
<context:annotation-config />
</beans>
Jdbc配置信息统一在一个文件里,方便维护。
jdbc.driverClassName=oracle.jdbc.OracleDriver
dev-db1.jdbc.url=jdbc:oracle:thin:@192.168.205.37:1521:dev-db1
taobao.jdbc.username=taobao
taobao.jdbc.password=taobao
dev-dbc.jdbc.url=jdbc:oracle:thin:@192.168.205.37:1521:dev-dbc
tbcat.jdbc.username=tbcat
tbcat.jdbc.password=tbcat
我们测试项目需要多个数据源,但一个测试类一般只需要一个,因此建议每个数据源一个配置文件,用例类只需引入自己相关的配置文件。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<bean id="itemDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${dev-db1.jdbc.url}"/>
<property name="username" value="${taobao.jdbc.username}"/>
<property name="password" value="${taobao.jdbc.password}"/>
</bean>
</beans>
3.2 简单应用示例
@ContextConfiguration(locations = { "classpath:applicationContext.xml" })//①
public class BaseCase extends AbstractJUnit4SpringContextTests {//②
}
@ContextConfiguration(locations = { "classpath:datasource-item.xml" })//③
public class ItemAddTest extends BaseCase {
private SimpleJdbcTemplate jdbcTemplate;
@Autowired//④
public void init(DataSource dataSource) {
jdbcTemplate = new SimpleJdbcTemplate(dataSource);
}
}
上面的示例对TestContext的应用非常简单,归纳起来就是一个基类两个注解。
TestContext根据这个配置文件启动Spring容器。我们可在基类引入基础配置文件如①,在子类只引入相关的配置文件如③
当 Spring 容器启动时,将扫描 Spring 容器中所有 Bean,当发现 Bean 中拥有 @Autowired 注释时就找到和其匹配(默认按类型匹配)的 Bean,并注入到对应的地方中去。
如果容器中配置了类型相同的多个Bean,可用@Qualifier指定名称,例如如果类中引入了多个数据源,其示例代码如下 @Autowired
另外@Autowired还可标注于成员变量和构造器,例如如果配置了要测试的类TaobaoDirectJsonRestClient,可通过下面的方法实例化。
public void init(@Qualifier("itemDataSource")
DataSource dataSource) {
jdbcTemplateItem = new SimpleJdbcTemplate(dataSource);
}
@Autowired
public void init2(@Qualifier("userDataSource")
DataSource dataSource) {
jdbcTemplateUser = new SimpleJdbcTemplate(dataSource);
}@Autowired
private TaobaoDirectJsonRestClient client;
3.3 源码分析
在上面的示例中我们通过继承AbstractJUnit4SpringContextTests和@ContextConfiguration标注就完成了Spring容器的启动和与Junit的结合,下面我们通过源码分析更进一步了解其深层原理。
AbstractJUnit4SpringContextTests的骨干代码如下:@RunWith(SpringJUnit4ClassRunner.class)//①
@TestExecutionListeners({DependencyInjectionTestExecutionListener.class, DirtiesContextTestExecutionListener.class})//②
public abstract class AbstractJUnit4SpringContextTests implements ApplicationContextAware {
在②处的标注跟Junit没啥关系,我们先看①处的@RunWith,
Junit4中广泛使用测试运行器,通过@RunWith注解告诉Junit采用何种运行器,事实上如果没有指定@RunWith,那么测试类仍然会使用
一个默认运行器
(org.junit.internal.runners.TestClassRunner,继承于JUnit4ClassRunner)执行,我们继续
看SpringJUnit4ClassRunner做了什么。SpringJUnit4ClassRunner核心代码如下:public class SpringJUnit4ClassRunner extends JUnit4ClassRunner {
private final TestContextManager testContextManager;
@Override
protected Object createTest() throws Exception {
Object testInstance = super.createTest();
getTestContextManager().prepareTestInstance(testInstance);// ③
return testInstance;
}
//这里忽略了其他非关键代码
}
SpringJUnit4ClassRunner同样继承了JUnit4ClassRunner,主要覆盖了其createTest方法,在
createTest方法里利用TestContextManager对testInstance进行处理。继续再看看
TestContextManager的关键代码。public class TestContextManager {
private final TestContext testContext;// ④
private final List testExecutionListeners = new ArrayList(); //⑤,与前面的②呼应
至此脉络大致清晰,对Spring TestContext核心类总结如下:
3.4 思考&实践
Spring TestContext本身运用是比较简单的,只需要准备配置文件、继承它提供的抽象类以及掌握几个注解即可。另外,通过源码分析我们发现了两个可扩展点,如果有必要可以利用这些扩展点在不改变其程序的情况下,开发符合我们自己需求的工具类。
在我的下篇博文-Managing test data with DbUnit And @XDataSet
里展示了运用扩展点二定制一个监听器,该监听器负责根据测试类或方法中的注解完成测试数据的准备和清理,具有支持多数据源及多种类型的数据集如XLS、XML等特性。
4 小结
本文通过简单的示例说明了如何在接口测试中应用Spring的JdbcTemplate和TestContext,最后通过源码分析发现了两个可扩展点,
为量身定做符合自己的测试工具找到了入口点。关于对其中一个扩展点TestExecutionListener的实践应用请关注我的下篇博文-Managing test data with DbUnit And @XDataSet
。
相关推荐
在IT行业中,接口测试是软件开发过程中的重要环节,它主要负责验证系统组件之间的交互是否正常,确保数据传输的准确性和系统的稳定性。Spring MVC作为Java领域广泛应用的Web框架,其接口设计与测试同样至关重要。本...
接下来介绍如何在传统的Java Web应用中调用Spring Cloud服务提供的接口: - **HTTP请求方法**:传统的Java Web应用可以通过发送HTTP请求来调用Spring Cloud服务。这里给出一个简单的HTTP GET请求示例方法: ```...
标题 "Spring3.2 MVC+ehcache+接口测试" 暗示了这个项目或教程是关于使用Spring框架的MVC模块,Ehcache缓存系统以及如何进行接口测试的。我们将深入探讨这三个核心概念。 **Spring MVC** Spring MVC是Spring框架的...
在接口测试中,Clover 可以帮助团队了解测试用例的完整性和有效性。 ##### 5.8 Mock Mock 是一种测试技术,用于模拟接口或类的行为,以帮助隔离被测对象。Mock 对象允许测试人员控制输入并预期输出,从而验证接口...
契约测试是一种接口测试方法,它关注的是服务间的交互,而不是服务的内部实现。通过定义双方之间的合同,服务消费者和提供者都可以独立地进行测试,确保在实际运行时能够正确交互。 2. **Spring Cloud Contract的...
在本测试实例中,我们将深入了解Spring MVC的核心组件,包括DispatcherServlet、Controller以及如何在MyEclipse环境中部署和运行应用程序。 首先,DispatcherServlet是Spring MVC的前端控制器,它是所有请求进入...
在Spring框架中,测试是确保代码质量和正确性的重要环节。"Spring相关测试1全部"这一主题涵盖了许多核心概念,这些都是理解和高效使用Spring框架的关键。以下是对这些知识点的详细阐述: 1. **注入属性值**:Spring...
在本接口工程中,Spring Boot作为基础框架,负责应用的启动、管理、监控等核心功能。 接着,Java作为后端开发的主流语言,以其强大的类型系统、丰富的库支持和成熟的社区闻名。在本项目中,Java不仅提供了面向对象...
开发者可能会创建一个简单的Service类,注入Repository接口,然后在测试类中验证Service的某些方法是否正确调用了Repository的方法。 总的来说,"spring 的简单小测试"旨在通过实际操作帮助开发者掌握Spring的基本...
6. **CXF_Spring中的示例**:在提供的压缩包文件"CXF_Spring"中,可能包含了示例代码、配置文件以及相关文档,用于演示如何整合CXF和Spring进行SOAP接口开发。通过研究这些示例,开发者可以更好地理解和实践上述知识...
通过查阅文档中的类、接口和方法,开发者可以迅速掌握Spring框架的使用,提升开发效率。由于作者承诺下载人数超过100人后会修订并发布新版本,这表明该文档将随着Spring框架的发展而不断更新,始终保持最新和最全面...
本教程将详细讲解如何将Web Service服务接口与Spring框架进行整合,以便在实际开发中实现高效、灵活的服务提供。 首先,让我们了解一下Web Service的基本概念。Web Service是一种软件系统,它通过使用开放标准(如...
《Spring框架开发参考中文手册》是一本专门为Java开发者设计的指南,旨在帮助他们深入理解和熟练运用Spring框架进行软件开发。Spring作为Java企业级应用开发的主流框架,以其强大的功能、灵活的设计和广泛的社区支持...
【标题】:“基于Java平台,依赖于Spring,适用于目前大部分项目的接口测试”这一主题涉及到的是在Java开发环境中,使用Spring框架进行接口自动化测试的技术实践。Java作为一种广泛应用的编程语言,其丰富的类库和...
《Spring 4.x 企业开发应用实战》这本书深入探讨了Spring框架在企业级应用程序开发中的应用,涵盖了Spring 4.x版本的重要特性和最佳实践。Spring作为Java生态系统中最受欢迎的轻量级框架,它提供了全面的解决方案,...
在接口测试中,我们可以利用Mockito来模拟依赖,避免真实调用其他服务,保持测试的独立性。 5. **Spring Test**:Spring Test为Spring应用提供了测试支持,包括SpringBootTest和WebMvcTest等注解,它们可以帮我们...
在本示例中,单元测试用于检查Spring Boot与Activiti的集成是否正确,以及相关的业务逻辑是否稳定可靠。通常,JUnit和Mockito等库会用于编写和执行这些测试,确保代码在修改后仍然正确。 **项目结构与文件** ...
单元测试是 Spring Boot 中的一个非常重要的组件,可以帮助我们快速地测试应用程序的正确性。通过使用 MockMVC、Mock 和其他测试工具,我们可以快速地测试 Controller、Service 和 Mapper,提高开发效率。
在这个名为“springDataJpa测试demo”的项目中,我们看到它是一个基于Maven构建的工程,目的是演示如何在Spring应用中集成并测试Spring Data JPA的功能。这里我们将详细探讨Spring Data JPA以及与Maven和MySQL数据库...