1. 程式人生 > >介面測試框架接入效能測試實踐分享

介面測試框架接入效能測試實踐分享

# 1. 前言 現如今介面測試在軟體質量行業中的地位,已經越來越重要,相對於上層的UI自動化測試和下層的單元測試,介面測試的“低”投入、“高”回報,也成了絕大多數質量保障實踐的首選。 在開展介面測試時,往往很多時候都只在關注介面的功能性質量,而對於非功能性的質量保障驗證,比如效能、安全,在實際工程應用或者設計用例時關注度明顯不足(甚至很多壓根沒有這方面的測試實踐)。 今天就以Python系下**requests**庫(常用於介面測試)和**Robot FrameWork**框架為例,和大家聊聊在介面測試過程中,和功能需求同等重要的效能測試檢查項。 # 2. 介面測試需要考慮的效能檢查項 在介面測試過程中,除了要考慮產品需求的正常、異常、資料正確性等顯性功能需求質量外,還有很多隱性需求質量需要關注,以效能測試為例,常見需要關注的檢查項包括,但不限於: - 1、單使用者登入的響應時間是否小於 3 秒; - 2、單使用者登入時,後臺請求數量是否過多; - 3、高併發場景下使用者登入的響應時間是否小於 5 秒; - 4、高併發場景下服務端的監控指標是否符合預期; - 5、高集合點併發場景下,是否存在資源死鎖和不合理的資源等待; - 6、長時間大量使用者連續登入和登出,伺服器端是否存在記憶體洩漏。 本文重點以介面響應時間為例,介紹如何在requests庫和Robot FrameWork框架納入效能測試項,其它效能檢查項思路基本都是相通的。 # 3. requests庫介面測試校驗響應時間 通常在結合**requests**庫開展介面測試時,傳送請求後,介面的響應時間,也是我們需要關注的一個重點,如果響應時間太長,從產品業務或者使用者角度也是不可接受的。那如何進行請求響應時間校驗,也成為了介面測試人員需要掌握的一項小技能。 針對**requests**庫校驗請求響應時間,給大家提供兩種實現思路: **一、藉助請求響應超時機制** 具體實現: ```python #-*- coding:utf-8 -*- import requests from requests import exceptions try: req = requests.post(url=url, data=data, headers=headers, verify=False, timeout=3)      print r.json() except exceptions.Timeout as e:    print("丟擲異常") ``` 在上述實現中,通過增加timeout引數,設定請求響應超時機制,當timeout=3(可自由定義),當請求響應時間超過3秒,則會丟擲超時異常。 其中,額外補充的知識點:超時(預設單位:s),有兩種設定超時方法: - timeout=5:設定5s的超時時間 - timeout=(5,10):設定區間時間的等待  當請求出現超時時,則會丟擲此異常:requests.exceptions.ConnectTimeout: HTTPConnectionPool     2、獲取響應時間方法:`req.elapsed.total_seconds() ` **二、藉助requests介面響應返回值elapsed** 具體實現: ```python #-*- coding:utf-8 -*- import requests r = requests.post(url, data=data, headers=headers) print(r.status_code) print(r.elapsed) print(r.elapsed.total_seconds()) print(r.elapsed.microseconds) print(r.elapsed.seconds) elapsed_time = r.elapsed.total_seconds() #獲取實際的響應時間 assert elapsed_time>3 ``` 上述程式碼實現中,通過獲取請求返回的響應值來獲取介面響應時間,常見的幾個獲取響應時間引數為: - elapsed.total_seconds:獲取響應時間,單位s **(推薦)** - elapsed. microseconds:獲取響應時間,大於1s的時候,只截取了後面的小數部分 - elapsed.seconds:單位s,響應時間小於1s時,為0 # 4. Robot Framework框架校驗響應時間 在上述我們介紹了**requests**庫在開展介面測試過程,校驗請求響應時間的實現思路。而通過Robot Framework框架開展介面測試,主要會依賴RequestsLibray庫,而因此實現思路也是一樣的。 具體實現,可參考下述示例: ![img](https://tva1.sinaimg.cn/large/007S8ZIlgy1giqd4b9z5oj30qi0d6tbv.jpg) 上述校驗請求響應時間,核心就兩句程式碼: ```python ${elapsed_seconds}= set variable ${resp.elapsed.total_seconds()} should be true ${elapsed_seconds}<3 ``` **補充知識點**:響應體${resp}是一個類物件,原始碼可在requests/models/Response檢視,可以檢視找出該類的所有屬性,第6行列印結果: ![](https://tva1.sinaimg.cn/large/007S8ZIlgy1giqd8u95rwj30z40u0gub.jpg) # 5. 小結 作為測試工程師,你的目標是要保證系統在各種應用場景下的功能是符合設計要求的,所以你需要考慮的測試用例就需要更多、更全面。本文,通過介面測試如何融合介面效能檢查項,給大家提供一點思路,希望對你有所幫助或啟發。 如果覺得有用,**幫忙點個好看**或**朋友圈轉發分享**一下就行。