当前位置: 首页 > news >正文

【五、接口自动化测试】5分钟掌握python + requests接口测试

你好啊!我是山茶,一个持续探索AI + 测试的程序员!

在做接口测试时,在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 jsonr = 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 {@AutowiredFirstService firstService;@GetMapping("/test_one")public String showNlefer(){System.out.println("我是山茶,公众号:程序员山茶。有问题请公众号留言!");return "{\"name\":\"山茶\",\"公众号\":\"程序员山茶\"}";}}

web端访问结果

使用requests测试接口

import requestsdef requestsShanCha():r = requests.get('http://127.0.0.1:8080/shancha/test_one')assert r.status_code == 200print(r.status_code)print(r.headers)print(r.content)print("返回信息结果:"+r.text)if __name__ == '__main__':requestsShanCha()

响应结果如下所示,与web浏览器响应结果一致

以上,本文完,如果你觉着有用就点个“赞呗👍”

作者简介:

程序员山茶,一个工作5年,并坚持探索测试之路的测试开发工程师。曾混迹于互联网大厂、IOTA行业领航企业、安全行业、大数据行业领航企业,欢迎和我一起沟通交流。


欢迎关注我,  和我一起探索AI+测试之路,终身成长

http://www.lryc.cn/news/316767.html

相关文章:

  • 双边市场的基本理论
  • R统计学2 - 数据分析入门问题21-40
  • 蓝桥杯2023年-买瓜(dfs,类型转换同样耗时)
  • 生成式人工智能服务安全基本要求实务解析
  • nginx详解,配置http,https,负载均衡,反向代理,SMTP 代理步骤说明
  • ARTS Week 20
  • python如何读取文件
  • InnoDB和MyISAM存储引擎
  • DataGrip 2023:让数据库开发变得更简单、更高效 mac/win
  • 突破编程_C++_设计模式(命令模式)
  • LeetCode102题:二叉树的层序遍历(python3)
  • linux服务器保存git账号密码命令
  • 基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的田间杂草检测系统(深度学习模型+UI界面+Python代码+训练数据集)
  • java Lambda表达式如何支持静态方法引用
  • SpringMVC04、Controller 及 RestFul
  • 【机器学习300问】33、决策树是如何进行特征选择的?
  • 剑指offer C ++双栈实现队列
  • 【YOLOv9】训练模型权重 YOLOv9.pt 重新参数化轻量转为 YOLOv9-converted.pt
  • Zookeeper搭建
  • 2.Datax数据同步之Windows下,mysql和sqlserver之间的自定义sql文数据同步
  • commonjs和esmodule
  • Android的编译系统
  • Midjourney指控Stability AI夜袭数据,网络风波一触即发
  • JVM知识整体学习
  • 蓝桥杯--日期统计
  • [leetcode~dfs]1261. 在受污染的二叉树中查找元素
  • PyQt5使用
  • 利用GPT开发应用005:Codex、Turbo、ChatGPT、GPT-4
  • 制造行业大数据应用:四大领域驱动产业升级与智慧发展
  • 25.5 MySQL 聚合函数