为什么80%的码农都做不了架构师?>>>
项目中使用到了spring_boot,我想在项目中写一些单元测试,但是由于对springboot 不熟悉并且springboot的中文资料非常的少,所以花了很长的时间才把springboot的junit测试环境搭好,虽然很简单,但是也发出来给大家参考一下吧。
一 准备
1 首先编写一个测试环境基类BaseDaoTest
package com.gome.superman.web.bussiness;import org.junit.runner.RunWith;
import org.springframework.boot.test.SpringApplicationConfiguration;
import org.springframework.boot.test.WebIntegrationTest;
import org.springframework.test.context.ActiveProfiles;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;/**
* @ClassName: BaseDaoTest
* @Description: TODO
* @author liujie14
* @date 2016年7月8日 下午5:37:27
*
*/
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = DaoConfiguration.class )
@WebIntegrationTest({"server.port=0","management.port=0"})
@ActiveProfiles("test")
public abstract class BaseDaoTest {
}
2 编写springboot配置类
package com.gome.superman.web.bussiness;
/**
* @Title: DaoConfiguration.java
* @Package com.gome.superman.common.sms
* @Description: TODO
* @author heshengchao
* @date 2016年7月8日 下午5:38:10
* @version V1.0
*/import com.gome.dubbo.DubboAutoConfiguration;import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.context.annotation.ImportResource;/**
* @ClassName: DaoConfiguration
* @Description: TODO
* @author liujie14
* @date 2016年7月8日 下午5:38:10
*
*/
@Configuration
@ComponentScan({"com.gome.superman.web.business"})
@Import({DubboAutoConfiguration.class} )
@ImportResource("classpath:spring/business-dubbo-consumer.xml")
@SpringBootApplication
public class DaoConfiguration {
}
二 开始编写测试
新建一个TestRest类 继承 BaseDaoTest
package com.gome.superman.web.bussiness.controller;import com.gome.superman.common.session.CacheSessionProvider; 看了前面一大段代码,相信大家也感觉比较迷糊。使用spingboot一个很重要的地方就是要对它的各种注解都要很熟悉,在这里我就对几个注解说下自己的理解吧。 先看两个注解: @Import @ImportResource 他们在springboot的官方文档中是这样介绍的 /** 意思就是。 @import 相当于我们在进行xml配置中的 @ImportResource 用来引入一些xml文件,从而使我们可以既用@Configuration类来配置,又可以用xml文件进行配置。 再看@SpringBootApplication 这个注解在源码中是这样定义的 @Target(ElementType.TYPE) 可见,使用了这个注解后,被标记的类就拥有@ComponentScan @Configuration 等等的特性。
import com.gome.superman.util.model.Response;
import com.gome.superman.util.redis.RedisUtils;
import com.gome.superman.web.business.controller.BrandController;
import com.gome.superman.web.business.controller.SuperManTradeRegistController;
import com.gome.superman.web.bussiness.BaseDaoTest;import org.junit.Assert;
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;import java.io.Serializable;
import java.util.Map;/*** @Author zengyu* @Date 2016-07-18* @Email zengyu2@gome.com.cn* @Desc*///用于自动化测试整个注册流程
public class testRegist extends BaseDaoTest {@AutowiredSuperManTradeRegistController superManTradeRegistController;@Testpublic void testRgist(){Response response = superManTradeRegistController.validatePhoneNum("18681277109");//效验手机号。Assert.assertTrue( response.isSuccess() );//发送短信 ,获取验证码response = superManTradeRegistController.sendMessage( null , "18681277109" );Assert.assertTrue( response.isSuccess() );String token = response.getResult().toString();String msgCode = getMsgCode( token );response = superManTradeRegistController.messageCodeValidate( token , msgCode );Assert.assertTrue( response.isSuccess() );//根据token获取验证码// 注册资料String msBase = "{ \"tradePhone\": \"18681277109\", \"tradePwd\": \"abcd1111\" }";String msSecurityInfo = "{ \"securityQuestionId\": 1, \"securityQuestionAnswer\": \"sdad\" }";response = superManTradeRegistController.regist( msBase , msSecurityInfo , token );System.out.println( response );Assert.assertTrue( response.isSuccess() );String baseInfos = "{ \"id\": 11, \"companyName\": \"llalal\", \"provinceId\": 1, \"cityId\": 2, \"districtId\": 3, \"provinceName\": \"llalal\", \"cityName\": \"xnclx\", \"districtName\": \"slxx\", \"tradePhone\": 18681277107, \"linkman\": \"sdalnvkd\", \"linkmanPhone\": 18681277109, \"companyPhone\": 2081996, \"companyDetailAddress\": \"nsdadnosfa\" }";String brandsInfo = "[ { \"brandId\": 2, \"brandName\": \"xniovadv\", \"brandEngName\": \"onzxvizo\" } ]";String categoriesInfo = "[]";response = superManTradeRegistController.saveSellerAuthenticationInformation( baseInfos , brandsInfo , categoriesInfo );System.out.println(response);Assert.assertTrue( response.isSuccess() );}public String getMsgCode( String token ){
// Map
// return (String) session.get("token");return RedisUtils.get(token);}} 三 注意事项
* Indicates one or more {@link Configuration @Configuration} classes to import.
*
* Provides functionality equivalent to the {@code
* Allows for importing {@code @Configuration} classes, {@link ImportSelector} and
* {@link ImportBeanDefinitionRegistrar} implementations, as well as regular component
* classes (as of 4.2; analogous to {@link AnnotationConfigApplicationContext#register}).
*
* {@code @Bean} definitions declared in imported {@code @Configuration} classes should be
* accessed by using {@link org.springframework.beans.factory.annotation.Autowired @Autowired}
* injection. Either the bean itself can be autowired, or the configuration class instance
* declaring the bean can be autowired. The latter approach allows for explicit, IDE-friendly
* navigation between {@code @Configuration} class methods.
*
* May be declared at the class level or as a meta-annotation.
*
* If XML or other non-{@code @Configuration} bean definition resources need to be
* imported, use the {@link ImportResource @ImportResource} annotation instead.
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@Configuration
@EnableAutoConfiguration
@ComponentScan
public @interface SpringBootApplication {