欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python使用pytest接口自動化測試的使用

 更新時間:2021年04月16日 11:04:56   作者:迷茫的Test小白  
這篇文章主要介紹了python使用pytest接口自動化測試的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧

簡單的設(shè)計思路

  • 利用pytest對一個接口進行各種場景測試并且斷言驗證
  • 配置文件獨立開來(conf文件),實現(xiàn)不同環(huán)境下只需要改環(huán)境配置即可
  • 測試的場景讀取excle的測試用例,可支持全量執(zhí)行或者自定義哪條用例執(zhí)行(用例內(nèi)帶加密變量);
  • 接口入?yún)⑦€包含了加密的邏輯,所以需加一層加密處理

用例的樣例:


應(yīng)用的庫包含:

import pytest
import time, json
import base64, hmac
import hashlib, uuid, re
import requests
import pandas as pd

1. 先定義好conf配置代碼

def config_txt(file_name="config.txt"):
    data_head = list()
    data_tail = list()
    for line in open(file_name, encoding='gb18030', errors='ignore'):
        head, sep, tail = line.partition('=')
        data_head.append(head.strip('\n '))
        if tail.find('#') != -1:
            tail, tail_b, tail_c = tail.partition('#')
        data_tail.append(tail.strip('\n  '))
    txt_data = dict(zip(data_head, data_tail))
    heada, sepa, taila = txt_data["GATEWAY_URL"].partition('/test_a')
    txt_data['HTTP_URI'] = "/test_a" + taila
    return txt_data

conf文件配置樣例:
GATEWAY_URL = https://127.0.0.1:8051/test_a/adk #url鏈接地址
zhu_KEY = test_key  #用戶信息1
zhu_SECRET = test_secret #用戶2
zhu_ID = 18825176013    #用戶ID
zhuLY_ID = 588347220  #用戶信息3

2. 簡單處理一下加密的處理,給后續(xù)持續(xù)調(diào)用

def md5(data_md5):
    data_md5 = hashlib.md5(data_md5.encode(encoding='UTF-8')).hexdigest()
    return data_md5

def sha256(data_sha256):
    data_sha256 = hashlib.sha256(data_sha256.encode(encoding='UTF-8')).hexdigest()
    return data_sha256

def hash_hmac(app_secret, msg, sha1):
    hmac_code = hmac.new(app_secret.encode(), msg.encode(), sha1).digest()
    return base64.b64encode(hmac_code).decode()

3. 處理用例里面的加密變量,例如:請求參數(shù)md5(18812345678)先進行數(shù)據(jù)預(yù)處理

def body_encrypt(data_encrypt):
    if data_encrypt.find("sha256(") != -1:
        sha_ss = re.findall(r"sha256[(](.+?)[)]", data_encrypt)
        for i in range(len(sha_ss)):
            data_encrypt = re.compile("sha256[(]" + str(sha_ss[i]) + '[)]').sub(str(sha256(sha_ss[i])), data_encrypt)
    if data_encrypt.find("md5(") != -1:
        md5_ss = re.findall(r"md5[(](.+?)[)]", data_encrypt)
        for i in range(len(md5_ss)):
            data_encrypt = re.compile("md5[(]" + str(md5_ss[i]) + '[)]').sub(str(md5(md5_ss[i])), data_encrypt)
    return data_encrypt

4. 讀取excel文檔里面的用例數(shù)據(jù)做為測試場景

def excel_case(file_name="case_file2.xlsx", case_id="all"):  # 讀取excel賬號及路由代理信息file_name
    data_excle = pd.read_excel(file_name, sheet_name=0, engine="openpyxl")
    df = pd.DataFrame(data_excle)
    if case_id != "all":
        df_data = df[(df.case_id == case_id)].to_dict('list')
    else:
        df_data = df.to_dict('list')
    case_id, case_name = df_data['case_id'], df_data['case_name']
    case_body, case_assert = df_data['case_body'], df_data['case_assert']
    case_body1 = body_encrypt(str(case_body))
    txt_data = list(zip(case_id, case_name, eval(case_body1), case_assert))
    return txt_data

5. 上主菜,pytest的使用

class Test_zhu(object):
    #類初始化,此處在測試執(zhí)行中,全局只會執(zhí)行一次(讀取配置文件)
    @classmethod
    def setup_class(self):
        self.text_data = config_txt()
   #方法初始化,此處在測試執(zhí)行中,每條用例都會先執(zhí)行一遍
    def setup_method(self):
        time.sleep(0.4)
        self.time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
   #request接口請求的邏輯
    def request_id(self, GATEWAY_URL, http_body):
        HTTP_BODY = eval(http_body)
        TIME_STAMP = str(int((time.time() + 5) * 1000))
        zhuCE = uuid.uuid1().hex
        msg = self.text_data['zhuLY_ID'] + "\n" + TIME_STAMP + "\n" + zhuCE + "\n" + self.text_data['zhu_KEY'] + "\n" + \
              self.text_data["HTTP_URI"] + "\n" + json.dumps(HTTP_BODY)
        HTTP_HEADER = {
            "zhu_ID": self.text_data['zhu_ID'],
            "zhuLY_ID": self.text_data['zhuLY_ID'],
            "zhuCE": zhuCE,
            "zhu_KEY": self.text_data['zhu_KEY'],
            "TIMESTAMP": TIME_STAMP,
            "SIGNATURE": hash_hmac(self.text_data['zhu_SECRET'], msg, hashlib.sha1)}
        print('**請求參數(shù):{}.'.format(HTTP_BODY))
        response_one = requests.post(GATEWAY_URL, json=HTTP_BODY, headers=HTTP_HEADER, verify=True)
        print('**響應(yīng)結(jié)果:{}.'.format(response_one.text))
        return eval(response_one.text)
    #parametrize為數(shù)據(jù)驅(qū)動,此處獲取了excle用例里的數(shù)據(jù);apitest定個標簽,后續(xù)冒煙啥的可以選擇性的跑(暫時無用);
    #excel_case(case_id="all")說明,all為全部用例執(zhí)行或者指定用例執(zhí)行case_0001
    @pytest.mark.parametrize('case_id,case_name, case_body, case_assert', excel_case(case_id="all"))
    @pytest.mark.apitest
    def test_zhu_case(self, case_id, case_name, case_body, case_assert):
        print("**\n執(zhí)行編號:" + case_id + "\n**用例名稱:" + case_name)
        case_assert_a = json.loads(case_assert)
        alertText = self.request_id(self.text_data['GATEWAY_URL'], case_body)
        retcode = case_assert_a.get('code') if case_assert_a.get('retcode') == None else case_assert_a.get('retcode')
        alertText_a = alertText.get('code') if alertText.get('retcode') == None else alertText.get('retcode')
        #此處為斷言,判斷用例通過還是不通過
        assert alertText_a == retcode
if __name__ == '__main__':
    pytest.main(["-sv", 'zhu_testA.py'])

6. 利用pytest-html庫可以生成html報告

命令:pytest zhu_testA.py --html=report.html --self-contained-html

 

到此這篇關(guān)于python使用pytest接口自動化測試的使用的文章就介紹到這了,更多相關(guān)python 接口自動化測試內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 離線部署Python環(huán)境的詳細過程

    離線部署Python環(huán)境的詳細過程

    本文主要介紹了離線部署Python環(huán)境的全過程,包括前置工作、部署Python、測試Python、配置環(huán)境和驗證Python五個步驟,為讀者提供了詳細的操作指南,希望能對需要離線部署Python環(huán)境的讀者提供幫助
    2024-10-10
  • python爬蟲教程之爬取百度貼吧并下載的示例

    python爬蟲教程之爬取百度貼吧并下載的示例

    這篇文章主要介紹了python爬取百度貼吧整個html文件下載到本地的示例,需要的朋友可以參考下
    2014-03-03
  • python簡單貪吃蛇開發(fā)

    python簡單貪吃蛇開發(fā)

    這篇文章主要為大家詳細介紹了python簡單貪吃蛇開發(fā),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 如何使用Python逆向抓取APP數(shù)據(jù)

    如何使用Python逆向抓取APP數(shù)據(jù)

    今天給大伙分享一下 Python 爬蟲的教程,這次主要涉及到的是關(guān)于某 APP 的逆向分析并抓取數(shù)據(jù),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • win10下tensorflow和matplotlib安裝教程

    win10下tensorflow和matplotlib安裝教程

    這篇文章主要為大家詳細介紹了win10下tensorflow和matplotlib安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • Python接口自動化淺析Token應(yīng)用原理

    Python接口自動化淺析Token應(yīng)用原理

    本文主要介紹token基本概念、運行原理及在自動化中接口如何攜帶token進行訪問,附含源碼,內(nèi)容非常詳細易理解,有需要的朋友可以參考下
    2021-08-08
  • python3 hdf5文件 遍歷代碼

    python3 hdf5文件 遍歷代碼

    這篇文章主要介紹了python3 hdf5文件 遍歷代碼,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • python中cv2模塊安裝詳細圖文教程

    python中cv2模塊安裝詳細圖文教程

    在Python中cv2是OpenCV庫的一個模塊,這是一個開源的計算機視覺和機器學(xué)習軟件庫,下面這篇文章主要給大家介紹了關(guān)于python中cv2模塊安裝的相關(guān)資料,需要的朋友可以參考下
    2024-05-05
  • 利用python來跟蹤ip地址的方法

    利用python來跟蹤ip地址的方法

    今天來介紹一個流行的 python庫 ip2geotools,使用它可以確定 IP地址 對應(yīng)的 國家、地區(qū)、城市、緯度和經(jīng)度等,文中通過代碼示例介紹了如何使用python來跟蹤ip地址,需要的朋友可以參考下
    2023-06-06
  • python+selenium+chrome批量文件下載并自動創(chuàng)建文件夾實例

    python+selenium+chrome批量文件下載并自動創(chuàng)建文件夾實例

    這篇文章主要介紹了python+selenium+chrome批量文件下載并自動創(chuàng)建文件夾實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04

最新評論