SpringBoot 構建RestFul API 含單元測試

  • 相關博文:html

  • 從消費者角度評估RestFul的意義java

    SpringBoot 構建RestFul API 含單元測試web

  • 首先,回顧並詳細說明一下在快速入門中使用的  @Controller 、  @RestController 、  @RequestMapping 註解。若是您對Spring MVC不熟悉而且尚未嘗試過快速入門案例,建議先看一下快速入門的內容。 ajax

    • @Controller :修飾class,用來建立處理http請求的對象 
    • @RestController :Spring4以後加入的註解,原來在  @Controller 中返回json須要  @ResponseBody 來配合,若是直接用  @RestController 替代  @Controller 就不須要再配置  @ResponseBody ,默認返回json格式。 
    • @RequestMapping :配置url映射
  • Controller 層
package com.creditease.bsettle.crm.controller.user;

import com.creditease.bsettle.crm.model.User;
import com.creditease.bsettle.crm.service.UserService;
import com.creditease.bsettle.crm.util.ResponseUtil;
import com.creditease.bsettle.monitor.base.controller.BaseCommonQueryController;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.Map;

@Slf4j
@RequestMapping(value = "/v1/users")
@RestController
public class UserControllerRestFulDemo extends BaseCommonQueryController<User>{

    @Autowired
    UserService userService;

    @RequestMapping(value = "",method = RequestMethod.GET)
    @ResponseBody
    public Map<String, Object> pageList(HttpServletRequest request, @RequestParam Map<String, String> searchParams) {
        Map<String, Object> maps = new HashMap<String, Object>();
        try {
            //TODO do something
            //maps = userService.queryPage(searchParams);
        } catch (Exception var4) {
            log.error(var4.getMessage(), var4);
            maps.put("retCode", Boolean.valueOf(false));
            maps.put("retMessage", var4.getMessage());
        }

        return maps;
    }

    /**
     * 根據用戶ID 查詢用戶信息
     * @param request
     * @param id
     * @return
     */
    @RequestMapping(value = "/{id}",method = RequestMethod.GET)
    @ResponseBody
    Map<String,Object>  findUser(HttpServletRequest request,@PathVariable Long id) {
        Map<String,Object> resultMap = ResponseUtil.createMap(true,"操做成功!");
        try {
            //TODO do something
           /* User user = userService.findUserById(id);
            resultMap.put("user",user);*/
        }catch(Exception e){
            log.error("findUserById is Exception !!! {} \n",e);
            resultMap = ResponseUtil.createMap(false,"操做失敗!"+e.getMessage());
        }
        return resultMap;
    }

    /**
     * 修改用戶信息
     * @param request
     * @param user
     * @param updateType 修改類型  1:修改密碼  2:修改用戶信息  3:修改用戶狀態
     * @return
     */
    @RequestMapping(value="/{id}", method = RequestMethod.PUT)
    @ResponseBody
    Map<String,Object> updateUserInfo(HttpServletRequest request,@ModelAttribute User user,@PathVariable Long id,
                                      @RequestParam("updateType") int updateType){
        Map<String,Object> resultMap = ResponseUtil.createMap(true,"操做成功!");
        try{
            //TODO do something
           // userService.updateUser(user,updateType,id);
        }catch (Exception e){
            log.error("updateUserInfo is Exception !!! {} \n",e);
            resultMap = ResponseUtil.createMap(false,"操做失敗!"+e.getMessage());
        }
        return resultMap;
    }

    /**
     * 根據用戶ID刪除用戶
     * @param request
     * @param id
     * @return
     */
    @RequestMapping(value="/{id}", method = RequestMethod.DELETE)
    @ResponseBody
    Map<String,Object> delUserById(HttpServletRequest request,@PathVariable Long id){
        Map<String,Object> resultMap = ResponseUtil.createMap(true,"操做成功!");
        try{
            //TODO do something
            //userService.delete(id);
        }catch (Exception e){
            log.error("delUserById is Exception !!! {} \n",e);
            resultMap = ResponseUtil.createMap(false,"操做失敗!"+e.getMessage());
        }
        return resultMap;
    }
    /**
     * 保存用戶信息
     * @param request
     * @param user
     * @return
     */
    @RequestMapping(value = "", method = RequestMethod.POST)
    @ResponseBody
    Map<String,Object> saveUserInfo(HttpServletRequest request, @ModelAttribute User user){
        Map<String,Object> resultMap = ResponseUtil.createMap(true,"操做成功!");
        try{
            //TODO do something
           //userService.save(user);
        }catch (Exception e){
            log.error("saveUserInfo is Exception !!! {} \n",e);
            resultMap = ResponseUtil.createMap(false,"操做失敗!"+e.getMessage());
        }
        return resultMap;
    }
}
  •   View 層
    •    根據查詢條件獲取user列表
      $.ajax({
             url: '../v1/users',
             async: false,
             type: 'GET',
             dataType: 'json
             data: {
                 //TODO
             } ,
             success: function(data) {        
                        //TODO  
              }
         });

        ORspring

      $('#userTable').bootstrapTable({
          method: 'GET',
          url: '../v1/user',
          dataType: 'json',
          pagination: true,
          pageList: [5,10,15,20],
          pageNumber: 1,
          pageSize: 5,
          //singleSelect: true,
          clickToSelect: true,
          sidePagination: 'server',
          queryParams: queryParams,
          locale: 'zh-CN',
          //
      })

        

    • 獲取ID爲1 的用戶json

    • $.ajax({
         url: '../v1/user/1',
         type: 'GET',
         dataType: 'json',
         data: {
              //TODO
         },
         success: function(data) {
            //TODO
         }
      });
    • 更新用戶ID爲1 的用戶信息bootstrap

      $.ajax({
         url: '../v1/user/1',
         type: 'PUT',
         dataType: 'json',
         data: {
            //TODO new user data
         },
         success: function(data) {
            //TODO
         }
      });
    •  刪除用戶ID爲1的用戶

    • $.ajax({
         url: '../v1/user/1',
         type: 'DELETE',
         dataType: 'json',
         data: {
            //TODO other param
         },
         success: function(data) {
           //TODO
         }
      });

       

  •   測試用例
    package com.creditease.bsettle.crm;
    
    import org.junit.Before;
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.test.context.SpringBootTest;
    import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
    import org.springframework.test.context.web.WebAppConfiguration;
    import org.springframework.test.web.servlet.MockMvc;
    import org.springframework.test.web.servlet.RequestBuilder;
    import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
    import org.springframework.test.web.servlet.setup.MockMvcBuilders;
    import org.springframework.web.context.WebApplicationContext;
    
    import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print;
    import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
    import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
    
    /**
     * @author mengfanzhu
     * @Package com.creditease.bsettle.crm
     * @Description:
     * @date 5/19/17 10:40
     * */
     @RunWith(SpringJUnit4ClassRunner.class)
     @SpringBootTest(classes = CrmApplication.class)
     @WebAppConfiguration
     public class UserServiceRestTest {
    
        @Autowired
        private WebApplicationContext wac;
        private MockMvc mvc;
    
        @Before
        public void setUp() throws Exception {
    //        mvc = MockMvcBuilders.standaloneSetup(new UserControllerRestFulDemo()).build();
            mvc = MockMvcBuilders.webAppContextSetup(wac).build();
        }
    
        @Test
        public void getUserList() throws Exception {
            // 一、get查一下user列表
            RequestBuilder request = MockMvcRequestBuilders.get("/v1/users")
                    .header("auth", "false")
                    .param("pageNumber", "2")
                    .param("pageSize", "10");
            mvc.perform(request)
                    .andDo(print()) //print request and response to Console
                    .andExpect(status().isOk())
                    .andExpect(content().contentType("application/json;charset=UTF-8"));
        }
    
        @Test
        public void postUser() throws Exception {
            // 二、post提交一個userRequestBuilder
            RequestBuilder request = MockMvcRequestBuilders.post("/v1/user")
                    .header("auth","false")
                    .param("isModifyPassword","N")
                    .param("status","O")
                    .param("userName","testName"+System.currentTimeMillis())
                    .param("userLoginPassword","aaaa1234")
                    .param("mobile","13322221111")
                    .param("email","fjksdfj@11.com")
                    .param("crmEnterpriseId","1");
            mvc.perform(request)
                    .andDo(print());
    
        }
    
        @Test
        public void getUser() throws Exception {
            // get獲取user列表,應該有剛纔插入的數據
            RequestBuilder request = MockMvcRequestBuilders.get("/v1/user?mobile=13322221111")
                    .header("auth","false")
                    .param("pageNumber", "1")
                    .param("pageSize", "10");;
            mvc.perform(request)
                    .andDo(print())
                    .andExpect(status().isOk());
        }
    
        @Test
        public void getUserById() throws Exception {
            // get一個id爲1的user
            RequestBuilder  request = MockMvcRequestBuilders.get("/v1/user/1")
                    .header("auth","false");
            mvc.perform(request)
                .andDo(print());
        }
    
        @Test
        public void putUserInfoById() throws Exception {
               // put修改id爲1358的user
            RequestBuilder request = MockMvcRequestBuilders.put("/v1/user/1358")
                    .header("auth","false")
                    .param("updateType","2")
                    .param("userName", "測試終極大師")
                    .param("email", "11111@qq.com");
            mvc.perform(request)
                .andDo(print());
    
        }
    
        @Test
        public void delUserInfoById() throws Exception {
            //del刪除id爲1358的user
            RequestBuilder request = MockMvcRequestBuilders.delete("/v1/user/1358")
                    .header("auth","false");
            mvc.perform(request)
                    .andDo(print());
    
        }
    }
相關文章
相關標籤/搜索