亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:69日期:2022-06-22 11:18:14
簡單的設計思路 利用pytest對一個接口進行各種場景測試并且斷言驗證 配置文件獨立開來(conf文件),實現不同環境下只需要改環境配置即可 測試的場景讀取excle的測試用例,可支持全量執行或者自定義哪條用例執行(用例內帶加密變量); 接口入參還包含了加密的邏輯,所以需加一層加密處理用例的樣例:

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

應用的庫包含:

import pytestimport time, jsonimport base64, hmacimport hashlib, uuid, reimport requestsimport pandas as pd1. 先定義好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 #用戶信息1zhu_SECRET = test_secret #用戶2zhu_ID = 18825176013 #用戶IDzhuLY_ID = 588347220 #用戶信息3

2. 簡單處理一下加密的處理,給后續持續調用

def md5(data_md5): data_md5 = hashlib.md5(data_md5.encode(encoding=’UTF-8’)).hexdigest() return data_md5def sha256(data_sha256): data_sha256 = hashlib.sha256(data_sha256.encode(encoding=’UTF-8’)).hexdigest() return data_sha256def hash_hmac(app_secret, msg, sha1): hmac_code = hmac.new(app_secret.encode(), msg.encode(), sha1).digest() return base64.b64encode(hmac_code).decode()3. 處理用例里面的加密變量,例如:請求參數md5(18812345678)先進行數據預處理

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_encrypt4. 讀取excel文檔里面的用例數據做為測試場景

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_data5. 上主菜,pytest的使用

class Test_zhu(object): #類初始化,此處在測試執行中,全局只會執行一次(讀取配置文件) @classmethod def setup_class(self):self.text_data = config_txt() #方法初始化,此處在測試執行中,每條用例都會先執行一遍 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().hexmsg = 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(’**請求參數:{}.’.format(HTTP_BODY))response_one = requests.post(GATEWAY_URL, json=HTTP_BODY, headers=HTTP_HEADER, verify=True)print(’**響應結果:{}.’.format(response_one.text))return eval(response_one.text) #parametrize為數據驅動,此處獲取了excle用例里的數據;apitest定個標簽,后續冒煙啥的可以選擇性的跑(暫時無用); #excel_case(case_id='all')說明,all為全部用例執行或者指定用例執行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執行編號:' + 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

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

到此這篇關于python使用pytest接口自動化測試的使用的文章就介紹到這了,更多相關python 接口自動化測試內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 成人免费男女视频网站慢动作 | 伊人蕉久中文字幕无码专区 | 91视频免费观看网站 | 亚洲欧美另类在线观看 | 欧美色图在线观看 | 久久精品亚洲热综合一本奇米 | 99热视| 男啪女视频免费观看网站 | 成人黄 在线播放 | 国产a级特黄的片子视频 | 国产精品福利在线观看入口 | 嫩草视频在线看 | 亚洲黄色在线观看视频 | 黄色生活片 | 国外精品视频在线观看免费 | 黄色片免 | 久久精品国产免费看久久精品 | 亚洲精品入口一区二区乱 | 国产毛片一级国语版 | 手机国产精品一区二区 | 日韩欧美一区二区三区在线 | 在线看一区二区 | 久久精品国产精品青草图片 | 又黄又爽又猛午夜性色播在线播放 | 二区三区视频 | 亚洲另类视频 | 亚洲不卡影院 | 国产成人综合久久精品红 | 久久亚洲成人 | 普通话对白国产情侣自啪 | 久久亚洲精品中文字幕二区 | 国产亚洲精品自在久久不卡 | 在线观看视频www | 日本久久视频 | 黄色片大全在线观看 | 国产美女在线看 | 国产成人高清精品免费5388密 | 性满足久久久久久久久 | 中国女人freexxxx性mp4 | 免费观看一级特黄欧美大片 | 看全免费的一级毛片 |