在做接口测试时,在python中内置了HTTP库 urllib,可以用于发送http请求。基于urllib二次封装的三方库Requests,相较于urllib更佳简介易用。所以,在接口自动化测试中通常使用Requests库对接口进行测试
Requests安装
因为Requests是第三方库,所以需要对其进行安装,通常安装使用pip命令安装即可
# 在终端命令行或python编辑工具pycharm的Terminal中输入以下指令即可
pip install requests
安装完成后,在编辑器中引入对应的库import requests
Requests常见请求类型
HTTP接口测试涉及到3个方面
-
请求方法:get、post、put、 delete、head ......
-
请求体:form、json、xml、 binary
-
响应结果:status code、 response body、 json path、 xpath
接口常见的请求方法及类型如下
#【如有问题,关注公众号:程序员山茶】留言
r = requests.get('http://127.0.0.1:8080/shancha/test_one') #get请求
r = requests.post('http://127.0.0.1:8080/shancha/test_one', data = {'key':'value'})#post请求
r = requests.put('http://127.0.0.1:8080/shancha/test_one', data = {'key':'value'})
r = requests.delete('http://127.0.0.1:8080/shancha/test_one')
r = requests.head('http://127.0.0.1:8080/shancha/test_one')
r = requests.options('http://127.0.0.1:8080/shancha/test_one')
#【如有问题,关注公众号:程序员山茶】留言
# 构造请求目标
import resquests
r = requests.get('http://127.0.0.1:8080/shancha/test_one')
print(r.status_code) # 响应结果为 200
# 构造请求头
url = 'http://127.0.0.1:8080/shancha/test_one'
headers ={'user-agent': 'my-app/0.0.1'}
r = requests.get(url, headers=headers)
print(r.status_code) # 响应结果为 200
# 构造请求cookie
url = 'http://127.0.0.1:8080/shancha/test_one'
cookies = dict(cookies_are='chengxuyuanshancha')
r = requests.get(url, cookies=cookies)
print(r.status_code) # 响应结果为 200
Requests请求体构造
请求体key:value 即键值对的形式存在,如query参数、form请求、binary请求(上传文件)以及json、xml、 json rpc等结构化请求
# form 和 Json 示例如下
#【如有问题,关注公众号:程序员山茶】留言
# form请求
payload = {'key':'valuel','key2':'value2'}
r = requests.post("http://127.0.0.1:8080/shancha/test_one", data=payload)
print(r.status_code) # 响应结果为 200
# JSON请求
url = 'http://127.0.0.1:8080/shancha/test_one'
payload = {'some': 'data'}
r = requests.post(url, json=payload)
print(r.status_code) # 响应结果为 200
Requests响应断言
在做测试时,结果判断是功能实现的重要依据之一。结果判断也可以称之为响应断言,即对请求动作结果返回的预期
-
响应的类型有多种
-
r.url:
-
r.status_code
-
r.headers
-
r.cookies
-
r.encoding
-
r.content
-
r.text
-
r.json()
-
以接口API为例
#【如有问题,关注公众号:程序员山茶】留言
# 结构化响应断言方式
import requests
import json
r = requests.get('https://api.github.com/repos/hiyongz/DjangoDemo')
json_data = r.json()
print(json.dumps(json_data, indent=4))
# 返回信息结果为
{
"message": "API rate limit exceeded for 50.7.252.58. (But here's the good news: Authenticated requests get a higher rate limit. Check out the documentation for more details.)",
"documentation_url": "https://docs.github.com/rest/overview/resources-in-the-rest-api#rate-limiting"
}
除了常用的Assert断言以外, 还有Hamcrest 断言、xml解析断言、schema断言、JSONPath断言等多种断言方式,断言也可以组合使用,在测试过程中要根据返回的结果数据选择适合的断言方法
接口测试示例
使用Springboot编写一个接口“/shancha/test_one”,且在web端也可以访问
@RestController
@RequestMapping("/shancha")
public class FirstController {
@Autowired
FirstService firstService;
@GetMapping("/test_one")
public String showNlefer(){
System.out.println("我是山茶,公众号:程序员山茶。有问题请公众号留言!");
return "{\"name\":\"山茶\",\"公众号\":\"程序员山茶\"}";
}
}
web端访问结果
使用requests测试接口
import requests
def requestsShanCha():
r = requests.get('http://127.0.0.1:8080/shancha/test_one')
assert r.status_code == 200
print(r.status_code)
print(r.headers)
print(r.content)
print("返回信息结果:"+r.text)
if __name__ == '__main__':
requestsShanCha()
响应结果如下所示,与web浏览器响应结果一致
以上,本文完,如果你觉着有用就点个“赞呗👍”
作者简介:
程序员山茶,一个工作5年,并坚持探索测试之路的测试开发工程师。曾混迹于互联网大厂、IOTA行业领航企业、安全行业、大数据行业领航企业,欢迎和我一起沟通交流。
欢迎关注我, 和我一起探索AI+测试之路,终身成长