专栏首页程序猿DDSpring Boot构建RESTful API与单元测试

Spring Boot构建RESTful API与单元测试

首先,回顾并详细说明一下在快速入门中使用的 @Controller@RestController@RequestMapping注解。如果您对Spring MVC不熟悉并且还没有尝试过快速入门案例,建议先看一下快速入门的内容。

  • @Controller:修饰class,用来创建处理http请求的对象
  • @RestController:Spring4之后加入的注解,原来在 @Controller中返回json需要 @ResponseBody来配合,如果直接用 @RestController替代 @Controller就不需要再配置 @ResponseBody,默认返回json格式。
  • @RequestMapping:配置url映射

下面我们尝试使用Spring MVC来实现一组对User对象操作的RESTful API,配合注释详细说明在Spring MVC中如何映射HTTP请求、如何传参、如何编写单元测试。

* RESTful API具体设计如下:*

User实体定义:

public class User {    
private Long id; 
private String name;   
private Integer age;     // 省略setter和getter } 

实现对User对象的操作接口

下面针对该Controller编写测试用例验证正确性,具体如下。当然也可以通过浏览器插件等进行请求提交验证。

@RunWith(SpringJUnit4ClassRunner.class) 
@SpringApplicationConfiguration(classes = MockServletContext.class)
 @WebAppConfiguration public class ApplicationTests {    
  private MockMvc mvc;     
  @Before    
  
    public void setUp() throws Exception {   
          mvc = MockMvcBuilders.standaloneSetup(new UserController()).build(); 
  }     
  
  @Test     public void testUserController() throws Exception {        
   // 测试UserController         
   RequestBuilder request = null;       
     // 1、get查一下user列表,应该为空      
        request = get("/users/");         
        mvc.perform(request)                
         .andExpect(status().isOk())            
              .andExpect(content().string(equalTo("[]")));  
                     //2、post提交一个user    
          request = post("/users/")      
          .param("id", "1")                 
          .param("name", "测试大师")                 
          .param("age", "20");        
           mvc.perform(request)           
                 .andExpect(content().string(equalTo("success")));       
                   // 3、get获取user列表,应该有刚才插入的数据    
          request = get("/users/");     
          mvc.perform(request)                 
          .andExpect(status().isOk())                 
          .andExpect(content().string(equalTo("[{\"id\":1,\"name\":\"测试大师\",\"age\":20}]")));         
          // 4、put修改id为1的user         
          request = put("/users/1")                 
          
          .param("name", "测试终极大师")                
           .param("age", "30");         
           mvc.perform(request)                 
           .andExpect(content().string(equalTo("success")));         
           // 5、get一个id为1的user         
           request = get("/users/1");         
           mvc.perform(request)                 
           .andExpect(content().string(equalTo("{\"id\":1,\"name\":\"测试终极大师\",\"age\":30}")));
           // 6、del删除id为1的user         
           
           request = delete("/users/1");         
           mvc.perform(request)                 
           .andExpect(content().string(equalTo("success")));         
           // 7、get查一下user列表,应该为空         
           request = get("/users/");         
           mvc.perform(request)                 
           .andExpect(status().isOk())                 
           .andExpect(content().string(equalTo("[]"))); 
               } 
} 

至此,我们通过引入web模块(没有做其他的任何配置),就可以轻松利用Spring MVC的功能,以非常简洁的代码完成了对User对象的RESTful API的创建以及单元测试的编写。其中同时介绍了Spring MVC中最为常用的几个核心注解: @Controller, @RestController, RequestMapping以及一些参数绑定的注解: @PathVariable, @ModelAttribute, @RequestParam等。

本文分享自微信公众号 - 程序猿DD(didispace),作者:翟永超

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-08-01

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Spring Cloud Zuul重试机制探秘

    作者:李刚 原文:http://www.spring4all.com/article/208 简介 本文章对应spring cloud的版本为(Dalston....

    程序猿DD
  • 如何将Markdown文章轻松地搬运到微信公众号并完美地呈现代码内容

    相信有很多童鞋跟我一样,热衷于用Markdown来编写文章。由于其简单的语法和清晰的渲染效果,受到广大码农朋友们的推崇。但是,当我们想维护起自己的公众号时,公众...

    程序猿DD
  • 缓存穿透、缓存并发、热点缓存之最佳招式

    一、前言 我们在用缓存的时候,不管是Redis或者Memcached,基本上会通用遇到以下三个问题: 缓存穿透 缓存并发 缓存失效 缓存穿透 ? ? ? 注: ...

    程序猿DD
  • CDB 的控制台的超时雪崩问题

    近日,测试同学 R 反馈整个测试环境,CDB 的相关页面都不能访问了,到底是什么原因导致呢 ? 本文记录了本次问题的查找过程、问题结论以及解决方案。

    云加社区
  • C++课程设计类作业3

    1 #include <bits/stdc++.h> 2 using namespace std; 3 class A 4 { 5 public: ...

    Angel_Kitty
  • [__NSArrayM enqueue:]: unrecognized selector sent to instance 0x280ab5770

    解决方案: Target->Buid Settings->Linking 下 Other Linker Flags 项添加-all_load

    honey缘木鱼
  • 最优布线问题

    【问题描述】   学校有n台计算机,为了方便数据传输,现要将它们用数据线连接起来。两台计算机被连接是指它们间有数据线连接。由于计算机所处的位置不同,因此不同的两...

    attack
  • 城市公交网建设问题

    【问题描述】   有一张城市地图,图中的顶点为城市,无向边代表两个城市间的连通关系,边上的权为在这两个城市之间修建高速公路的造价,研究后发现,这个地图有一个特点...

    attack
  • UITableView 编辑状态(删除、添加、移动)

    LeeCen
  • python+mysql上传图片和上传文件 转

    参考博客:http://www.cognize.me/2016/05/09/djangopic

    晓歌

扫码关注云+社区

领取腾讯云代金券