響應(yīng)以及斷言
在“發(fā)送HTTP請求”一講中,我們講解了APIPOST中響應(yīng)數(shù)據(jù)的查看重贺。
點(diǎn)擊發(fā)送按鈕后回懦,如果有數(shù)據(jù)返回怯晕,則會顯示返回數(shù)據(jù),響應(yīng)時間,響應(yīng)碼稚晚,Cookie等型诚。
注意:返回數(shù)據(jù)默認(rèn)是?美化?模式狰贯,便于查看 JSON XML 格式涵紊。您可以通過切換?原生?或?預(yù)覽?模式 查看其它類型的類型。
除了查看結(jié)果外颤练,ApiPost也提供了強(qiáng)大的測試校驗功能嗦玖。在這里我們也可以使用斷言來進(jìn)行響應(yīng)結(jié)果的校驗宇挫。
在APIPOST 5.4版本后,支持“響應(yīng)結(jié)果分屏展示”翠储,從而提升工作區(qū)的空間娱局。
協(xié)作開發(fā)耻涛,版本升級,服務(wù)器升級澈蟆,接口返回有可能因為一些bug卓研,和我們預(yù)期結(jié)果不一致奏赘。為了便于開發(fā)&測試人員能夠更快的發(fā)現(xiàn)bug,有利于整個產(chǎn)品質(zhì)量以及進(jìn)度的保證疲憋。我們推出斷言功能缚柳。
定義測試用例
驗證測試用例
例如接口返回:
{
"errcode": 0,
"errstr": "success",
"post": [],
"get": [],
"request": [],
"put": "",
"header": {
"Host": "echo.apipost.cn",
"Connection": "keep-alive",
"Content-Length": "0",
"Accept": "application/json, text/javascript, */*; q=0.01",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN",
"Content-Type": "application/json",
"Cookie": "PHPSESSID=n3k73k06o6ghnie4e9re4rbf0t",
"Origin": "https://echo.apipost.cn",
"User-Agent": "Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1"
}
}
定義測試用例:
apt.assert('response.raw.status==200');
apt.assert('response.raw.type=="json"');
apt.assert('response.json.errcode==0');
apt.assert('response.raw.responseTime<100');
apt.assert('response.json.header.Host=="echo.apipost.cn"');
點(diǎn)擊發(fā)送按鈕后:
綠色表示測試通過秋忙,紅色表示測試不通過。
特別注意:每個測試用例是一行构舟,不能換行翰绊。
例:apt.assert(‘response.json.header.Host==“echo.apipost.cn”’);
1)response.json.header.Host 表示響應(yīng)json下面的header數(shù)組中的Host字段,
2)必須都為1,才會通過监嗜。
常見的測試用例可以通過后執(zhí)行腳本獲刃程础:
response.raw:原始響應(yīng)數(shù)據(jù)
調(diào)用示例:
response.raw.status //響應(yīng)狀態(tài)碼(200、301裁奇、404等)
response.raw.responseTime //響應(yīng)時間(毫秒)
response.raw.type //響應(yīng)類型(json等)
response.raw.responseText //響應(yīng)文本
response.json:json格式的響應(yīng)數(shù)據(jù)
調(diào)用示例如上面示例:
response.json.data.token //也可以 response.json.data["token"]
調(diào)用示例:
response.headers.server //也可以 response.headers["server"]
response.cookies :響應(yīng)cookie
調(diào)用示例:
response.cookies.PHPSESSION //也可以 response.cookies["PHPSESSION"]
1、檢查response body中是否包含某個string
apt.assert('response.raw.responseText=="test"');? // 檢查響應(yīng)文本是否等于test字符串
apt.assert('response.raw.responseText.indexOf("test") > -1');? // 檢查響應(yīng)文本是否含有test字符串
2刽肠、檢測返回JSON中的某個值是否等于預(yù)期的值
apt.assert('response.json.hasOwnProperty("errcode")'); // 檢測返回json對象的是否含有errcode字段
apt.assert('response.json.errcode=="success"');? // 檢測返回json對象的errcode字段是否等于success字符串
apt.assert('response.json.errcode.indexOf("success") > -1');? // 檢測返回json對象的errcode字段是否含有success字符串
apt.assert('response.json.errcode!="success"');? // 檢測返回json對象的errcode字段是否不等于success字符串
apt.assert('response.json.errcode>=1');? // 檢測返回json對象的errcode字段是否大于1
apt.assert('response.json.errcode==null'); // 檢測返回json對象的errcode字段是否是null
3溃肪、測試response Headers中的某個元素是否存在(如:Content-Type)
apt.assert('response.headers.hasOwnProperty("content-type")');
4、驗證Status code(響應(yīng)碼)的值是不是等于200
apt.assert('response.raw.status==200');
5音五、驗證Response time(請求耗時)是否大于某個值
apt.assert('response.raw.responseTime>=100');
6惫撰、驗證返回類型是不是json
apt.assert('response.raw.type=="json"');