Python 接口自动化断言

本文介绍了如何在Python中使用requests库进行接口自动化测试,包括响应状态码断言和JSON内容断言。通过示例代码展示了断言成功的状态码检查以及断言JSON响应数据的具体元素。在响应状态码断言中,如果状态码不等于预期的200,会抛出AssertionError。对于JSON响应断言,通过r.json()方法获取响应内容,并断言特定JSON字段的值。
摘要由CSDN通过智能技术生成

Python 接口自动化断言
在发起请求后,使用一个变量r存储响应的内容,也就是Response对象。

r = requests.get("https://xxxxx")
1
响应结果:

{
  "args": {},
  "headers": {
    "Accept": "*/*",
    "Accept-Encoding": "gzip, deflate",
    "Host": "httpbin.ceshiren.com",
    "User-Agent": "python-requests/2.25.1",
    "X-Forwarded-Host": "httpbin.ceshiren.com",
    "X-Scheme": "https"
  },
  "origin": "119.123.205.82",
  "url": "https://xxxxx"
}

Response 对象有很多功能强大的方法可以调用,比如直接获取响应头,获取 Unicode 编码后的响应内容,获取二进制的响应内容,获取原始的响应内容等等。

响应断言
响应状态码断言

1、断言成功

import requests
r = requests.get('https://xxxxx')
assert r.status_code==200

assert是 python 的内置函数,用来判断表达式,当表达式条件为 False 的时候就会触发异常。r.status_code是 response 对象内的一个方法,用于获得返回值的状态码。assert r.status_code==200 就是在判断状态码是否等于 200,如果不等于 200 则会抛出异常。

2、断言失败

>>> import requests
>>> r = requests.get('https://xxxxx')
>>> assert r.status_code==400
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AssertionError

从以上例子可了解到,此响应状态码实际输出与预期结果状态码 400 不相等,所以抛出了异常。

Json 响应断言

data = {
      "hogwarts": ["a","b","c"]
  }
r = requests.post('https://xxxxx',json=data)
print(json.dumps(r.json(),indent=2))
assert r.status_code == 200
assert r.json()["json"]["hogwarts"][0] == "a"

响应结果:

"args": {},
  "data": "{"hogwarts": ["a", "b", "c"]}",
  "files": {},
  "form": {},
  "headers": {
    ...省略...
  },
  "json": {
    "hogwarts": [
      "a",
      "b",
      "c"
    ]
  },
  "origin": "113.89.8.68",
  "url": "https://xxxx"
}

通过 assert r.json()[“json”][“hogwarts”][0] == “a” 对 json 的内容进行断言,其中 r.json() 是获取相应的内容,r.json()[“json”] 是获取到 json 的内容,r.json()[“json”][“hogwarts”] 是获取到 hogwarts 的内容,r.json()[“json”][“hogwarts”][0] 是 hogwarts 下的第一个数据。
————————————————
版权声明:本文为CSDN博主「测试内卷王」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/NanFanzzZ/article/details/127496109

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值