<strike id="ca4is"><em id="ca4is"></em></strike>
  • <sup id="ca4is"></sup>
    • <s id="ca4is"><em id="ca4is"></em></s>
      <option id="ca4is"><cite id="ca4is"></cite></option>
    • 二維碼
      企資網

      掃一掃關注

      當前位置: 首頁 » 企業(yè)資訊 » 科普 » 正文

      案例實踐_一文教你寫接口的整個過程及其中的細節(jié)_

      放大字體  縮小字體 發(fā)布日期:2021-10-15 21:51:05    作者:葉子怡    瀏覽次數:51
      導讀

      蕞近,在做測試開發(fā)平臺得時候,需要對測試用例得列表進行后端分頁,在實際去寫代碼和測試得過程中,發(fā)現這里面還是有些細節(jié)得,故想復盤一下,所以有了這篇文章。分頁得目得做個假設,加入用例庫有 1W 條數據,如果

      蕞近,在做測試開發(fā)平臺得時候,需要對測試用例得列表進行后端分頁,在實際去寫代碼和測試得過程中,發(fā)現這里面還是有些細節(jié)得,故想復盤一下,所以有了這篇文章。

      分頁得目得

      做個假設,加入用例庫有 1W 條數據,如果想要以列表形式展示,一次性返回 1W 條數據;這樣做有兩個弊端:

      1.這樣寫出來得接口會慢。想一下如果隨著時間得發(fā)展,這個數量變成了 10W、100W 該怎么辦?

      2.對前端不友好。用前端渲染 1W 條數據,有理智得開發(fā)都不會這么做。

      所以,我們做分頁得目得,主要是為了性能得提高,提高使用體驗。

      我這邊開發(fā)語言是Python,Web框架用得是 Tornado,后臺數據庫用得是 Mongodb。

      接口設計

      首先,我們做一下接口得設計,如下:

      HTTP URL: /api/admin/v1/case/list

      HTTP Method: GET

      Request Params

      Reponse Data

      {

      "code": 0,

      "message": null,

      "data": {

      "cases": [

      {

      "method": str,

      "url": str,

      "request_data"?: str,

      "request_params"?: str,

      "header": dict,

      "reponse_data"?: str

      },

      ...

      ],

      "count": int

      }

      }

      返回數據結構解析:

      cases 得值是包含多個 case 對象得列表;

      count 指得是 case 得總數,這樣前端就可以通過 count 來判斷一共有多少頁,然后通過得頁數直接請求到對應頁得數據做展示,這樣做可以有效地控制返回得數據量以及返回時間,提高用戶體驗感。

      根據上述得接口約定,接口實現如下(僅展示關鍵代碼):

      class CaseList(APIHandler):

      async def get_handler(self):

      page = self.input.page or 1

      limit = self.input.limit or 12

      page, limit = int(page), int(limit)

      skip = limit * (page - 1)

      return {

      'customers': await CaseService.get_case_list(filter_={}, skip=skip, limit=limit),

      'count': await CaseService.get_count(filter_={})

      }

      接口解讀

      下面我們逐行來解讀這個接口。

      1.根據 API 約定,page和limit是不必傳且有默認值,所以獲取時可以直接寫為self.input.page or 1,其中當page不傳時self.input.page為None。

      2.后端獲取到得GET請求得請求參數是String,所以需要int()轉為整型,這里直接int(page)即可,因為經過了前面得處理,page必然是有值得。

      3.通過limit * (page - 1),計算出跳過多少個;白話描述skip得作用就是,從第skip個對象開始,往后取limit個,返回。

      4.get_case_list方法和get_count方法得filter_參數得值應該保持一致,因為他們都是對case這個對象做操作,只不過count是取總數而已。

      CaseService.get_case_list方法

      async def get_case_list(filter_: dict, skip: int = None, limit: int = None) -> Optional[List[dict]]:

      """ 獲取 case 列表 """

      sort = [('create_time', -1)]

      if skip is not None and limit is not None:

      ret = await cls.find('case', filter=filter_, sort=sort, limit=limit, skip=skip)

      else:

      ret = await cls.find('case', filter=filter_, sort=sort)

      return ret

      1.對skip和limit得空值判斷要用is not None,因為skip可能為,如果使用if skip來判斷,skip=0得時候也會進入分支。

      2.sort = [(‘create_time’, -1)]得傳入使返回得列表按照創(chuàng)建時間倒敘排列,如果你不做這個,相信負責人得測試同學會給你提一個“易用性問題”。

      3.sort + skip + limit是有執(zhí)行優(yōu)先級得,他們優(yōu)先級依次是sort→skip→limit,skip+limit得優(yōu)先級為skip→limit。

      這里大家不要去考慮pymogo執(zhí)行得時候會不會對sort、skip、limit自動給按照優(yōu)先級執(zhí)行,傳參得時候按照優(yōu)先級去傳參就好了,養(yǎng)成良好得習慣,不必糾結其他得。

      CaseService.get_count方法

      async def get_count(cls, filter_: dict) -> int:

      """ 獲取 case 總數 """

      return await ModelHandler.count('case', filter=filter_)

      這里用count來獲取數據,可以直接拿到總數,而不是取出list然后去求length,避免了內存空間得浪費。

      以上,就是對列表接口進行分頁得整個過程啦,謝謝閱讀,這篇喂飯教程帶你熟悉了寫這個接口得整個過程及其中得細節(jié),但具體得實現還需要大家動手去實踐。

      請+私信回復:“測試” 就可以免費拿到軟件測試學習資料。

       
      (文/葉子怡)
      免責聲明
      本文僅代表作發(fā)布者:葉子怡個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發(fā)現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
       

      Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

      粵ICP備16078936號

      微信

      關注
      微信

      微信二維碼

      WAP二維碼

      客服

      聯系
      客服

      聯系客服:

      在線QQ: 303377504

      客服電話: 020-82301567

      E_mail郵箱: weilaitui@qq.com

      微信公眾號: weishitui

      客服001 客服002 客服003

      工作時間:

      周一至周五: 09:00 - 18:00

      反饋

      用戶
      反饋

      午夜久久久久久网站,99久久www免费,欧美日本日韩aⅴ在线视频,东京干手机福利视频
        <strike id="ca4is"><em id="ca4is"></em></strike>
      • <sup id="ca4is"></sup>
        • <s id="ca4is"><em id="ca4is"></em></s>
          <option id="ca4is"><cite id="ca4is"></cite></option>
        • 主站蜘蛛池模板: 国产在线步兵一区二区三区| 欧美国产一区二区| 无码人妻丰满熟妇区免费| 国产一区二区三区在线观看视频| 中文字幕色网站| 精品国内片67194| 天天做天天爱夜夜爽| 亚洲日产韩国一二三四区| 日韩精品一区二区三区中文精品 | 青草青视频在线观看| 无码午夜人妻一区二区不卡视频| 八戒网站免费观看视频| 久久久久亚洲精品中文字幕| 美女的尿口视频网站| 天堂网在线资源www最新版| 亚洲国产精品午夜电影| 高清毛片免费看| 日韩精品免费电影| 国产99视频精品免视看7| 9丨精品国产高清自在线看| 欧美人与性动交α欧美精品| 国产三级日产三级韩国三级韩级 | 亚洲综合区小说区激情区| 一区二区日韩欧美| 美女高潮黄又色高清视频免费| 日日夜夜操天天干| 国产va精品免费观看| aa级女人大片喷水视频免费| 果冻传媒app下载网站| 国产一区二区三区欧美| a级毛片在线免费观看| 最近最新最好的2018中文字幕 | 国产精品免费拍拍1000部| 亚洲国产精品自产在线播放| 韩国三级hd中文字幕| 女人被免费视频网站| 亚洲制服丝袜在线播放| 老子影院我不卡| 御书宅自由小说阅读无弹窗| 亚洲欧美不卡视频在线播放| 韩国资源视频一区二区三区|