requests接口測試

一、介紹

Requests是一個(gè)很實(shí)用的Python HTTP客戶端庫冗澈,編寫爬蟲和測試服務(wù)器響應(yīng)數(shù)據(jù)時(shí)經(jīng)常會(huì)用到朴艰,Requests是Python語言的第三方的庫,專門用于發(fā)送HTTP請(qǐng)求

二秧荆、前提

pip install requests

三、get的請(qǐng)求

1.GET無參請(qǐng)求

r = requests.get('http://www.baidu.com')

2.GET傳參

payload = {'key1': 'value1', 'key2': 'value2', 'key3': None}

r = requests.get('http://www.baidu.com ', params=payload)

3.案例:測試聚合數(shù)據(jù)

代碼

import requests

class UseRequestClass():

????????#get傳參的第一種方式

????????def XWTTMethod(self):

????????????????r=requests.get("http://v.juhe.cn/toutiao/index?type=guonei&key=4b72107de3a197b3bafd9adacf685790")

????????????????print(r.text)

????????#get傳參的第二種方式

????????def XWTTMethod(self):

????????????????params = {"type":"guonei","key":"4b72107de3a197b3bafd9adacf685790"}

????????????????r = requests.get("http://v.juhe.cn/toutiao/index",params=params)

????????????????print(r.text)

四埃仪、post請(qǐng)求

類似python中的表單提交

payload={'key1':'value1','key2':'value2'}

r=requests.post("http://httpbin.org/post",data=payload)

案例:測試聚合數(shù)據(jù)

代碼

import requests

class UseRequestClass():

????????def XWTTPostMethod(self):

????????params = {"type":"guonei","key":"4b72107de3a197b3bafd9adacf685790"}

????????r = requests.post("http://v.juhe.cn/toutiao/index",params=params) ???????????? ????????

????????#print(r.status_code)

????????return r.status_code

五乙濒、Requests響應(yīng)

r.status_code? ? ? ? 響應(yīng)狀態(tài)碼

r.heards? ? ? ? ? ? ? ? 響應(yīng)頭

r.cookies? ? ? ? ? ? ? ?響應(yīng)cookies

r.text? ? ? ? ? ? ? ? ? ? ?響應(yīng)文本

r. encoding? ? ? ? ? ?當(dāng)前編碼

r. content? ? ? ? ? ? ? 以字節(jié)形式(二進(jìn)制)返回

最常用的是根據(jù)響應(yīng)狀態(tài)碼判斷接口是否連通,經(jīng)常用于做接口中斷言判斷

六卵蛉、Request擴(kuò)充

1.添加等待時(shí)間

requests.get(url,timeout=1)? ? ? ? ? ? ? ? ? #超過等待時(shí)間則報(bào)錯(cuò)

2.添加請(qǐng)求頭信息

requests.get(url,headers=headers)? ? ? #設(shè)置請(qǐng)求頭

3.添加文件

requests.post(url,files=files)? ? ? ? ? ? ? ? ?#添加文件

文件傳輸

url = 'http://httpbin.org/post'

files = {'file': open('report.xls', 'rb')}

r = requests.post(url, files=files)

七颁股、requests+pytest+allure

1.流程如下

讀取文件中的數(shù)據(jù)

requests拿到數(shù)據(jù)請(qǐng)求接口返回狀態(tài)碼

通過斷言驗(yàn)證返回狀態(tài)碼和200對(duì)比

生成allure的測試報(bào)告

2.模塊總覽

dataDemo(存放數(shù)據(jù))>> readDemo(讀取數(shù)據(jù))

useRequests(發(fā)送請(qǐng)求)>>testDemo(生成報(bào)告)

3.讀取csv文件流程

3.1? 存儲(chǔ)數(shù)據(jù)(csv)

通過excel另存為csv即可。

3.2? 讀取數(shù)據(jù)(readDemo)

代碼展示

import csv

class ReadCsv():

????????def readCsv(self):

????????????????item = []

????????????????rr = csv.reader(open("../dataDemo/123.csv"))

????????????????for csv_i in rr:

????????????????????????item.append(csv_i)

????????????????item = item [1:]

????????????????return item

3.3? request請(qǐng)求接口返回狀態(tài)碼

代碼展示

import requests

from readDataDemo.readcsv import ReadCsv

r = ReadCsv()

ee = r.readCsv()

# print(ee)

class RequestCsv():

????????def requestsCsv(self):

????????????????item = []

????????????????for csv_i in ee:

????????????????????????if csv_i[2] =="get":

????????????????????????????????rr = requests.get(csv_i[0],params=csv_i[1])

????????????????????????????????item.append(rr.status_code)

????????????????????????else: rr = requests.post(csv_i[0],data=csv_i[1])

????????????????????????????????item.append(rr.status_code)

????????????????return item

3.4? pytest斷言設(shè)置并結(jié)合allure生成測試報(bào)告

代碼展示

import pytest,os,allure

from userequests.userequestsDemo.requestscsv import RequestCsv

r = RequestCsv()

ee = r.requestsCsv()

print(ee)

class TestClass02():

????????def test001(self):

????????????????for code in ee:

????????????????????????assert code == 200

if __name__ == '__main__':

????????pytest.main(['--alluredir', 'report/result', 'test_02csv.py'])

????????split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'

????????os.system(split)

3.5? 測試報(bào)告展示

4.讀取excle文件流程

4.1? 存儲(chǔ)數(shù)據(jù)(xlsx)

4.2? 讀取數(shù)據(jù)(readDemo)

安裝openpyxl:

pip install openpyxl

from openpyxl import load_workbook

class Readxcel():

????????def getTestExcel(self):

????????# 打開表

????????workbook = load_workbook("G:\python\pythonProject\pytest05a\\requestdemo\\a.xlsx")

????????# 定位表單

????????sheet = workbook['Sheet1']

????????print(sheet.max_row)? ? ? ?# 3 行

????????print(sheet.max_column)? ? ?# 3 列

????????test_data = []? ? ?# 把所有行的數(shù)據(jù)放到列表中

????????for i in range(2, sheet.max_row + 1):

????????????????sub_data = {}? ? ?# 把每行的數(shù)據(jù)放到字典中

????????????????for j in range(1, sheet.max_column + 1):

????????????????????????sub_data[sheet.cell(1, j).value] = sheet.cell(i, j).value

????????????????test_data.append(sub_data)? ? ? # 拼接每行單元格的數(shù)據(jù)

????????return test_data

t = Readxcel()

f = t.getTestExcel()

print(f)

4.3? request請(qǐng)求接口返回狀態(tài)碼

import requests

from requestdemo.readexcel import Readxcel

class GetStatusCode():

????????def getStatusCode(self):

????????????????t = Readxcel()

????????????????f = t.getTestExcel()

????????????????item = []

????????????????for excel_i in f:

????????????????????????if excel_i["method"] == "get":

????????????????????????????????rr = requests.get(excel_i["url"], params=excel_i["params"])

????????????????????????????????item.append(rr.status_code)

????????????????????????else:

????????????????????????????????rr = requests.post(excel_i["url"], data=excel_i["params"])

????????????????????????????????item.append(rr.status_code)

????????????????return item

print(GetStatusCode().getStatusCode())

4.4? pytest斷言設(shè)置并結(jié)合allure生成測試報(bào)告

import allure, pytest, os

from requestdemo.getStatusCode import GetStatusCode

get = GetStatusCode()

statusCodes = get.getStatusCode()

class TestReadExcel():

????????def testReadExcel(self):

????????????????for code in statusCodes:

????????????????????????assert code == 200

if __name__ == "__main__":

????????# 生成測試報(bào)告json

????????pytest.main(["-s", "-q", '--alluredir', 'report/result', 'testreadexcel.py'])

????????# 將測試報(bào)告轉(zhuǎn)為html格式

????????split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'

????????os.system(split)

4.5? 測試報(bào)告展示

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市感帅,隨后出現(xiàn)的幾起案子驶俊,更是在濱河造成了極大的恐慌,老刑警劉巖梧疲,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異运准,居然都是意外死亡幌氮,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門胁澳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來该互,“玉大人,你說我怎么就攤上這事韭畸∮钪牵” “怎么了?”我有些...
    開封第一講書人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵胰丁,是天一觀的道長随橘。 經(jīng)常有香客問我,道長锦庸,這世上最難降的妖魔是什么机蔗? 我笑而不...
    開封第一講書人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮甘萧,結(jié)果婚禮上萝嘁,老公的妹妹穿的比我還像新娘。我一直安慰自己扬卷,他們只是感情好牙言,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著怪得,像睡著了一般咱枉。 火紅的嫁衣襯著肌膚如雪卑硫。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,541評(píng)論 1 305
  • 那天庞钢,我揣著相機(jī)與錄音拔恰,去河邊找鬼。 笑死基括,一個(gè)胖子當(dāng)著我的面吹牛颜懊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播风皿,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼河爹,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了桐款?” 一聲冷哼從身側(cè)響起咸这,我...
    開封第一講書人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎魔眨,沒想到半個(gè)月后媳维,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡遏暴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年侄刽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片朋凉。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡州丹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出杂彭,到底是詐尸還是另有隱情墓毒,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布亲怠,位于F島的核電站所计,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏团秽。R本人自食惡果不足惜醉箕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望徙垫。 院中可真熱鬧,春花似錦放棒、人聲如沸姻报。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吴旋。三九已至损肛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間荣瑟,已是汗流浹背治拿。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留笆焰,地道東北人劫谅。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像嚷掠,于是被迫代替她去往敵國和親捏检。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 一不皆、介紹 Requests是一個(gè)很實(shí)用的Python HTTP客戶端庫贯城,編寫爬蟲和測試服務(wù)器響應(yīng)數(shù)據(jù)時(shí)經(jīng)常會(huì)用到,...
    老友_9e40閱讀 242評(píng)論 0 0
  • 1.介紹: Requests是一個(gè)很實(shí)用的Python HTTP客戶端庫霹娄,用來做接口測試 *做接口測試前需要pip...
    我向星明許愿閱讀 174評(píng)論 0 0
  • 一能犯、介紹 Requests是一個(gè)很實(shí)用的Python HTTP客戶端庫,編寫爬蟲和測試服務(wù)器響應(yīng)數(shù)據(jù)時(shí)經(jīng)常會(huì)用到犬耻,...
    ldxzs閱讀 172評(píng)論 0 0
  • 1.介紹: Requests是一個(gè)很實(shí)用的Python HTTP客戶端庫踩晶,用來做接口測試 *做接口測試前需要pip...
    小董小董閱讀 168評(píng)論 0 0
  • 1.介紹: Requests是一個(gè)很實(shí)用的Python HTTP客戶端庫,用來做接口測試 *做接口測試前需要pip...
    Nostalgia_9ea7閱讀 178評(píng)論 0 0