日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

利用Python如何实现数据驱动的接口自动化测试

發布時間:2025/7/14 python 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 利用Python如何实现数据驱动的接口自动化测试 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

大家在接口測試的過程中,很多時候會用到對CSV的讀取操作,本文主要說明Python3對CSV的寫入和讀取。下面話不多說了,來一起看看詳細的介紹吧。

1、需求

某API,GET方法,token,mobile,email三個參數

  • token為必填項
  • mobile,email 必填其中1項
  • mobile為手機號,email為email格式

2、方案

針對上面的API,在做接口測試時,需要的測試用例動輒會多達10+, 這個時候采用數據驅動的方式將共性的內容寫入配置文件或許會更合適。

這里考慮把API、參數、以及預期結果預行在格式化的CSV里保存,利用csv組件從CSV里讀取URL、參數以及預期結果,Requests組件發起請求,將響應結果與預期結果進行比對,最后把比對結果寫到結果CSV。

流程如下圖?

?

3、實現

1、在上代碼之前,先安裝好如下幾個組件:

  • csv? 讀寫CSV文件
  • json
  • requests? 發起請求,獲取響應結果
  • unittest??? 測試用例調度

2、data.csv(本示例選取部分用例)

?

3、reader_CSV函數代碼示例

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 import csv import json import requests import time import unittest def readCSV(self,filename): ?''' ?:param filename: 需要讀取的數據文件 ?:return: [{data1},{data2}...] ?''' ?datas = [] ?try: ?#以DictReader的方式讀取數據文件,方便與json互做轉換 ?with open(filename,'r') as csvfile : ?#從文件里讀取到的數據轉換成字典列表的格式 ?reader = csv.DictReader(csvfile) ?for row in reader: ?data = {} ?data['id'] = row['id'] ?data['url'] = row['url'] ?data['token'] = str(row['token']) ?data['mobile'] = row['mobile'] ?data['email'] = row['email'] ?data['expect'] = json.dumps(row['expect']) \ ?if isinstance(row['expect'],dict) \ ?else row['expect'] #如果expect讀取出來的不是json則取其原值,否則轉為json格式保存到result里 ?datas.append(data) ?return datas ?#如果文件找不到,返回空的datas ?except FileNotFoundError: ?print("文件不存在",filename) ?return datas

4、request_URL函數示例(包含GET請求和POST請求2個方法)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 def get_request(self,url,params): ?''' ?通用的調用GET接口方法 ?:param url:string 接口路徑 ?:param params:{"":"","":""} 需要傳入的參數 ?:return: response響應體 ?''' ?print("調用API...") ?r = requests.get(url,params=params) ?print(r.text) ?return r def post_request(self,url,params): ?''' ?通用的調用POST接口方法 ?:param url: string 接口路徑 ?:param params: {"":"","":""} 需要傳入的參數 ?:return:response響應體 ?''' ?print("調用API...") ?r = requests.post(url,params=json.dumps(params)) #post的方法必須用json.dumps()轉化成json格式 ?print(r.text) ?return r

5、assert_Result函數示例

1 2 3 4 5 6 7 8 9 def assertResult(self,except_value,real_value): ?''' ?校驗樣本字符串中是否包含指定字符串 ?:param except_value: string 指定字符串 ?:param real_value: string 樣本字符串 ?:return: Boolean 樣本中包含指定字符串返回True,否則返回False ?''' ?ifsuccess = except_value in str(real_value) ?return ifsuccess

6、write_CSV函數示例

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 def writeCSV(self,filename,results): ?''' ?寫入csv文件指定內容 ?:param filename: string 需要寫入的文件名稱 ?:param results: [{data1},{data2},...] 寫入的內容 ?:return: 無 ?''' ?print("寫文件:",filename) ?#以DictWriter的方式寫文件 ?with open(filename,'w+') as csvfile: ?headers="id,url,token,mobile,email,expect,real_value,assert_value".split(",") ?writer = csv.DictWriter(csvfile,fieldnames=headers) ?#寫表頭 ?writer.writeheader() ?#寫數據 ?if results.__len__() > 0 : ?for result in results: ?writer.writerow(result) ?csvfile.close()

7、test_interface1函數示例

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 def test_interface1(self): ?#指定讀取的數據文件名稱 ?data_file = "../data/data.csv" ?#指定最終結果生成的數據文件名稱 ?result_file = "../data/result_{}.csv".format(str(time.time()).split(".")[0]) ?#讀取指定文件的數據 ?datas = self.readCSV(data_file) ?#數據文件有內容則調用接口,否則直接測試結束 ?if datas.__len__() > 0: ?results =[] ?#獲取數據文件里的每一行 ?for testcase in datas : ?result = {} ?result["id"] = testcase["id"] ?result["url"] = testcase["url"] ?result["token"] = testcase["token"] ?result["mobile"] = testcase["mobile"] ?result["email"] = testcase["email"] ?result["expect"] = testcase["expect"] ?#組裝參數 ?params = { ?"token":result["token"], ?"mobile":result["mobile"], ?"email":result["email"] ?} ?#調用API接口,獲取響應結果 ?real_value = self.get_request(result["url"],params) ?#調用assert方法,檢查預期結果是否在響應結果中存在 ?assert_value = self.assertResult(result["expect"],real_value.text) ?result["real_value"] = real_value.text ?result["assert_value"] = assert_value ?#獲取每一行里的所有字段以及實際結果和驗證結果 ?results.append(result) ?#執行完所有記錄后,將所有結果寫入result.csv ?self.writeCSV(result_file,results) #寫入csv文件 ?print("測試結束")

8、result_1523956055.csv(本示例中的測試結果請忽略)

?

?

總結

python封裝了很多方法,對于測試來說開發速度相對較快,接口自動化測試如果采用CSV管理的數據驅動方式,使用csv+requests是測試開發不容錯過的利器之一。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

?

轉載地址:https://www.jb51.net/article/139908.htm

轉載于:https://www.cnblogs.com/wangjq399/p/11315552.html

總結

以上是生活随笔為你收集整理的利用Python如何实现数据驱动的接口自动化测试的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: av综合色 | 天天干天天搞天天射 | 校园伸入裙底揉捏1v1h | 夜夜嗨老熟女av一区二区三区 | 男男野外做爰全过程69 | 午夜伦理在线观看 | 国产视频123区 | 成年人黄色片 | 欧美成人免费观看视频 | 男生操女生逼逼 | 青草视频在线观看视频 | 国产一区久久久 | 欧美嫩草 | 毛片av在线观看 | 极品淫少妇 | 亚洲在线一区 | 麻豆精品国产传媒av | 日本人妖xxxx | 巨胸爆乳美女露双奶头挤奶 | 91美女诱惑 | 国产视频导航 | 久久入口 | 男男做性免费视频网 | 少妇一级淫片免费看 | 国产精品国产馆在线真实露脸 | 毛片大全 | 红桃视频黄色 | 影音先锋男人的天堂 | 久久久久逼 | 国产激情精品一区二区三区 | 日本成人在线播放 | 中文字幕日本一区二区 | 尤物视频官网 | 亚洲国产欧美在线观看 | 亚洲日批 | 久久毛片网 | 久久久久久婷婷 | 女女高潮h冰块play失禁百合 | 成人毛片在线免费观看 | 国产一区二区三区视频免费观看 | 一区二区三区福利视频 | 精品无码在线视频 | 少妇高潮一区二区三区 | 久久久久久穴 | 国产成人精品三级麻豆 | 日本va在线 | 国产高清精品软件丝瓜软件 | 国产传媒在线播放 | 丰满少妇乱子伦精品看片 | www.伊人 | 99精品视频免费 | 国产精品视频亚洲 | 天天干天天操天天舔 | 一级片a级片 | 亚洲影院中文字幕 | 久久99精品国产麻豆91樱花 | 久久精品国产精品亚洲色婷婷 | 久久久资源 | 国产午夜精品无码 | 国精品一区二区 | 亚洲片国产一区一级在线观看 | 男人天堂欧美 | 精品国精品国产自在久不卡 | 国产老女人精品毛片久久 | 日本美女影院 | 国产精品一二三四五区 | 日韩女同一区二区三区 | 四虎国产成人永久精品免费 | 深夜免费福利 | 在线国产一区 | 亚洲视频一区二区三区在线观看 | 久久福利视频网 | 日b影院 | 日韩经典在线 | 制服丝袜在线播放 | 女人被男人躁得好爽免费视频 | 亚洲一本在线观看 | 国产一级片 | 免费国产a| 国产欧美一区二 | 日本特黄色片 | 风间由美在线视频 | 青青草久久 | 欧美日韩精品一区二区三区视频播放 | 在线精品视频播放 | 伊人网站在线观看 | 中文字幕无码不卡免费视频 | 国产777| 亚洲不卡在线 | 国产色区 | 1000部啪啪未满十八勿入超污 | 日本h片在线观看 | 国产精品高清在线 | 久久久久亚洲av无码专区首jn | 视频一区三区 | 超碰97久久| 欧美黄色网 | 国产微拍一区 | 色屁屁ts人妖系列二区 |