前言
隨著項目對外輸出的接口日漸增多,接口測試逐漸提上日程。經過一段時間的學習和摸索后,總結了一下。
方案
對于一些比較簡單的接口,我們希望可以通過csv文件進行編輯和整理用例,對于一些復雜的接口可以通過自定義腳本的方式去實現,在執行完成后,以郵件的形式發送給相關同學。
為什么用CSV文件呢??接口測試大多數測試用例會比較相似,對類似的接口進行反復相同的校驗。針對這種簡單的情況,我們希望把測試用例與測試腳本分開。如果重復用數據去請求和重寫,是對測試資源的一種浪費,而CSV文件可以直接用EXCEL進行編輯,讀取也非常方便,因此選作我們測試的用例集合。
如何參與測試?
1、對于簡單的接口,我們直接用excel對csv文件進行編輯。
在選擇添加的時候,可以填寫當前請求的請求頭和請求數據(部分舉例)。
2、對于一些復雜的接口,我們可以自定義腳本。
支持自定義腳本的好處是,我們既可以單獨運行自定義測試腳本,也可以將自定義的文件納入全部測試用例中,作為回歸測試一起執行。
開發流程
測試用例準備——執行測試用例、生成質量報告——自動發送郵件
1、測試用例準備
測試用例包括兩部分,自定義測試腳本中的測試用例和CSV文件中自動讀取的測試用例。
Unittest是Python自帶的單元測試框架,默認有TestCase、TestResult、TestRunner等方法,非常方便。自定義接口測試的腳本類通過繼承Unittest,編寫并驗證一些較復雜的接口。
為兼容自定義接口用例與文件讀取的接口用例類型,從文件中讀取的接口用例也需繼承Unittest類。主要的實現思路是從指定CSV文件里面中讀取數據,每讀取一行,便通過自定義工場類TestFactory創建一個繼承于Unittest的AutoTest的類。
AutoTest類當中,通過unittest默認的setUP()方法對每個參數進行初始化、judge_rule()方法對每行輸入的數據進行重新處理(關于接口md5加密、urlencode、時間戳等)、test函數對接口進行簡單的驗證。
#每讀取一行,變加入TestSuit里一個已test為名的用例
test_case?=self.testf.create_test(row)
self.test_suit.addTests(map(test_case,?["test"]))
#通過unittest方法獲取到自定義以_test為后綴名的用例
self.get_auto_test_suit?=?unittest.defaultTestLoader.discover("../basepages/",pattern='*_test.py')
#將兩部分用例 通過addTests方法合并在一起,就是全部的接口測試用例
2、執行測試用例、生成質量報告
引入了BSTestRunner,對其進行修改和編輯后,生成測試報告。BSTestRunner也是通過重寫Unittest的TestResult方法,對執行的結果進行展示。
在生成質量報告中,BSTestRunner生成全部用例的執行結果報告。面對這個情況,我們希望可生成兩份報告,一份僅記錄執行失敗的用例報告,另一份為原生的全部用例執行結果報告。所以在BSTestRunner的基礎上稍微進行了些改進,讓其生成兩份報告。
#?自動化測試報告
fp?=open('../doc/my_report.html','wb')
#?僅錯誤版測試報告
fpe?=open('../doc/my_report_email_text.html','wb')
runner?=?BSTestRunner.BSTestRunner(
stream=fp,
stream2=?fpe,
title='接口測試自動質量報告',
description='如需接口測試完整報告'
)
這里簡單給大家介紹下BSTestRunner這個引入的開源測試框架。
BSTestRunner 繼承于 Template_mixin類,通過調用sortResult方法,將用例傳給_TestResult類,獲取到執行結果,用getReportAttribute()方法,將結果在html中展示出來。
了解這個開發測試框架后,我們對其改動就會很方便,這里我們重新定義了一個getReport()方法,僅將錯誤的執行結果在另一個html中保存。
3、發送測試報告郵件
使用python的smtpserver進行發送郵件,默認發送的郵件需要到具體郵箱里設置授權,這里注意password是授權碼,不是郵箱的密碼。
簡潔版的執行結果my_report_email_text.html作為郵件內容HTML模板,全部執行結果my_report.html作為郵件附件。
發送郵件后,就可以收到具體的測試質量報告啦!
BSTestRunner?Github地址: