Python3簡易介面自動化測試框架設計與實現(上)

秦無殤發表於2019-05-10

介面開發請參考:使用Django開發簡單介面:文章增刪改查

1、開發環境

  • 作業系統:Ubuntu18
  • 開發工具:IDEA+PyCharm外掛
  • Python版本:3.6

2、用到的模組

  • requests:用於傳送請求
  • xlrd:操作Excel,組織測試用例
  • smtplib,email:傳送測試報告
  • logging:日誌追蹤
  • json:資料格式化
  • Django:介面開發
  • configparser:讀取配置檔案

3、框架設計

3.1、流程

Python3簡易介面自動化測試框架設計與實現(上)

介面用例是通過Excel來組織的,定義了URL,Request Body等列。執行流程如下:

  • 使用xlrd工具讀取Excel中的資訊,拼接成一個個完整的請求。
  • 介面請求類拿到一個個完整的請求的去執行,這個過程需要記錄日誌,每一次執行情況都要有跡可循。
  • 回填測試結果,傳送郵件,歸檔每次的執行結果。更好一點的做法是把歷史執行情況做個報表,更直觀。

優點:

  • 用例通過Excel來組織,不需要編寫程式碼,上手難度小。
  • 在用例個數不是很多的情況,開發速度快。

缺點:

  • 用例依賴是痛點。
  • 只能支援介面自動化用例。
  • Excel中用例無法預先檢查正確性,只有跑一把才能知道。
  • 無法很好地管理大量用例,且不支援團隊協同作業,個人用來回歸測試或上線後的冒煙測試會是一個不錯的選擇。

通過優缺點的對比,可以明顯發現這個框架的硬傷其實很多了。所以無論是業界開源的自動化測試框架或企業自研的還沒有見過用Excel來組織用例的。值得一提的是個別企業自研的自動化框架非常難用,抑或是把一堆工具簡單組合到一起。根本無法提高團隊的生產力。不過好的產品也不是一蹴而就的,需要一個持續優化的過程。所以上面用Excel組織用例的框架還是值的玩一玩的,暫且命名為apitest吧。目前比較好的自動化測試框架有unittest,testng,pytest等。

3.2、專案結構

Python3簡易介面自動化測試框架設計與實現(上)

  • testcase:存放測試用例或請求的json檔案。
  • config:配置檔案。
  • report:測試報告和日誌檔案及其歸檔。
  • untils:工具集,send_request用來傳送請求,email_tool用來傳送郵件,excel_tool用來讀取Excel中的資料,check_result用來校驗結果,run_main用例執行入口,log_trace用來追蹤日誌。

5、日誌列印

採用內建logging模組才記錄執行日誌,設定日誌級別。
log_trace.log:

import  logging
filename = "../report/test_case_run.log"
logging.basicConfig(level=logging.INFO,
                    format='%(asctime)s %(levelname)s1 %(filename)s [line:%(lineno)d]  %(message)s',
                    datefmt='%a, %d %b %Y %H:%M:%S',
                    filename=filename,
                    filemode='w')

6、介面請求類封裝

安裝第三方模組requests

pip install requests

定義函式send_request,根據傳入的方法型別分別去呼叫request的get,post,delete,put等方法去傳送請求。send_request.py:

import  requests
from untils. log_trace import  *

#傳送get請求
def get_request(url,data=None,headers=None):
    res = requests.get(url=url,data=data,headers=headers)
    return res

#傳送post請求
def post_request(url,data,headers=None):
    res = requests.post(url=url,data=data,headers=headers)
    return res

#傳送delete請求
def del_request(url,data=None,headers=None):
    res = requests.delete(url,data=data)
    return res

#傳送put請求
def put_request(url,data,headers=None):
    pass

def send_request(method,url,data=None,headers=None):
    try:
        logging.info(headers)
        if headers:
            if method == "GET":
                return get_request(url,data,headers=headers)
            if method == "POST":
                return post_request(url,data=data,headers=headers)
            if method == "DELETE":
                return  del_request(url,data=data,headers=headers)
            #put使用頻率低,暫時不寫
            if method == "PUT":
                return  put_request(url,data=data,headers=headers)
        else:
            logging.info("Header is null")
    except Exception as e:
        logging.info("send request fail:%s"%e)

在untils_test.py中編寫程式碼測試send_request方法,程式碼如下:

#coding:utf-8
from untils.send_request import send_request

def test_send_request():
    url="http://127.0.0.1:9000/articles/"
    headers = {
        "X-Token":"0a6db4e59c7fff2b2b94a297e2e5632e"
    }
    res = send_request("GET",url,headers=headers)
    print(res.json())



if __name__ == "__main__":
    test_send_request()

執行結果:

/usr/bin/python3.6 /home/stephen/IdeaProjects/apitest/untils/untils_test.py
{'status': 'BS.200', 'all_titles': {'amy1': 'alive', 'modifytest': 'alive', 'addTest': 'alive'}, 'msg': 'query articles sucess.'}

Process finished with exit code 0

相關文章