接口是什么&如何开展pycharm+requests接口自动化

一、了解接口

(一)接口测试

  • 定义:对系统或组件之间的接口进行测试,主要是校验数据的交换,传递和控制管理过程,以及相互逻辑依赖关系。
  • 接口分类:内部接口(登录、查看数据)、外部接口(购物、支付)
  • 目的:保证接口的正确性和稳定性
  • 原理:模拟客户端向服务器发送请求报文,服务器接收请求报文后对相应的报文做处理并向客户端返回应答,客户端接收应答的过程
  • 接口自动化:
    通过编写测试脚本覆盖接口,并通过脚本执行发现接口问题,主要用于回归测试。

(二)接口的请求部分

Accept:客户端可识别的内容类型列表

Authorization:授权信息( Bearer Token:通过使用访问密钥对请求进行身份验证)

User-Agent:告诉HTTP服务器, 客户端使用的操作系统和浏览器的名称和版本

Content-Type:用来告诉服务端消息主体是序列化的json字符串

(三)接口的响应部分

Content-Type:WEB服务器告诉浏览器自己响应的对象的类型和字符集

Server:指明HTTP服务器的软件信息

常见响应代码:
1xx:指示信息------表示请求已经接受,继续处理
2xx:成功------表示请求已经被成功接收、理解、接受。
3xx:重定向------要完成请求必须进行更进一步的操作
4xx:客户端错误------请求有语法错误或请求无法实现
5xx:服务器端错误------服务器未能实现合法的请求。

二、接口自动化怎么做

(一)基本流程

需要明确,接口自动化的开展是接口较稳定的阶段

  • 需求分析
    了解项目的业务功能,bug较多的模块,比较稳定接口有哪些,核心功能有哪些
  • 了解接口
    查看接口文档,了解接口的请求和响应;使用postman调试确保接口连通
  • 用例设计
  • 设计并调试接口脚本
    编码设计、调试接口脚本,分析用例失败原因
  • 维护脚本
    项目中存在修改、新增接口时,同步修改接口脚本
    日常优化框架,如:使用更简单的插件

(二)了解requests库

Requests库是python实现的最简单易用的HTTP库,允许发送各种 HTTP 请求,处理 cookies、会话、连接池、重定向、多种认证方式等,使得处理 HTTP 请求变得非常便捷。

通过pip命令安装:

python 复制代码
pip install requests

使用时,需要导入:

python 复制代码
import requests

(三)get请求实例

以下为get请求的实例,我打印了响应的代码,响应体文本和请求的地址,并且添加了一个断言。

python 复制代码
def test_case_get():
    """get请求示例"""
    url = "http://httpbin.org/get"
    resp = requests.get(url=url, params=None, headers=None)
    logger.info("响应代码为:{}".format(resp.status_code))
    logger.info("响应体为:{}".format(resp.text))
    logger.info("host为{}".format(resp.json()["headers"]['Host']))
    assert "headers" in resp.text
    return resp

实例的运行结果:

想要了解get请求可以添加什么参数,也可以查看get封装的源码,ctrl+b可以进入到关键字封装的源码,查看详细内容,可以看到,get请求除了url必填外,其余的参数都是可选的,比如params

(四)post请求实例

以下为post请求的实例,我打印了响应的代码,响应体文本和请求的地址,并且添加了一个断言。

python 复制代码
def test_case_post():
    """post请求示例"""
    url = "https://httpbin.org/post"
    data = {'key': 'value'}
    resp = requests.post(url=url, data=data)
    logger.info("响应代码为:{}".format(resp.status_code))
    logger.info("响应体为:{}".format(resp.text))
    logger.info("host为{}".format(resp.json()["headers"]['Host']))
    assert "form" in resp.text
    return resp

实例的运行结果:

post请求的参数,分享给大家了解:

当然,我们常见的请求之外,还有一些如put请求,delete请求,这些后续可以自行研究学习。

(五)初识pytest框架

pytest的特性:

  • 自动识别测试用例。(unittest当中,需要引入TestSuite,主动加载测试用例。)
  • 简单的断言表达:assert 表达式即可。(unittest当中,self.assert*)
  • 有测试会话、测试模块、测试类、测试函数级别的fixture。(unittest当中是测试类、测试函数级别的fixture)
  • 有非常丰富的插件,目前在600+,比如allure插件。(unittest无)
  • 测试用例不需要封装在测试类当中。(unittest中需要自定义类并继承TestCase)

识别规则(文件命名规范):

  • 搜索根目录:默认从当前目录中搜集测试用例
  • 搜索规则:
    1)搜索文件:符合命名规则 test_*.py 或者 *_test.py 的文件
    2)在满足1)的文件中识别用例的规则:
    2.1)以test_开头的函数名;
    2.2)以Test开头的测试类(没有__init__函数)当中,以test_开头的函数

(六)框架内各部分介绍

  • Common:存放常用工具,如自己封装的一些函数: 数据库连接、日志定制封装
  • Outputs:测试输出,包括logs和reports
  • TestCase:放置测试用例,可根据实际业务情况创 建模块,分类归档,用例脚本
  • Conftest.py:该文件主要用来做全局用例共享使用, 如参数的共享、测试fixture的定义等,一些初 始化的操作通常会放到该文件
  • Pytest.ini:为pytest本身自带的配置文件,文件位置 必须为整个工程的根目录下
  • run.py:脚本运行入口

(七)常用的库

import requests ················get、post、delete、put...

Import pytest ················pytest库,pytest.main()执行脚本

import pymysql ················连接mysql,做数据校验

Import time ················time.sleep(5)控制运行等待时间

Import json················ 响应数据json字段提取

相关推荐
Oooon_the_way2 小时前
UI自动化-Puppeteer
自动化
宇钶宇夕4 小时前
针对工业触摸屏维修的系统指南和资源获取途径
单片机·嵌入式硬件·自动化
真智AI8 小时前
利用 Claude Opus 4 自动化 GitHub 工作流:从安装到实战详解
运维·自动化·github
思则变10 小时前
[Pytest][Part 1]Pytest 自动化测试框架
pytest
艾立泰智能包装12 小时前
电商分拣的“效率密码”:艾立泰轻量化托盘引领自动化流水线革新
运维·自动化
cpsvps_net12 小时前
Windows内存泄漏自动化
运维·自动化
古月居GYH17 小时前
【数据分析】如何在PyCharm中高效配置和使用SQL
ide·sql·pycharm
风清再凯1 天前
自动化工具ansible,以及playbook剧本
运维·自动化·ansible
深圳安锐科技有限公司1 天前
深圳安锐科技发布国内首款4G 索力仪!让斜拉桥索力自动化监测更精准高效
运维·安全·自动化·自动化监测·人工监测·桥梁监测·索力监测
猫头虎1 天前
猫头虎 AI工具分享:一个网页抓取、结构化数据提取、网页爬取、浏览器自动化操作工具:Hyperbrowser MCP
运维·人工智能·gpt·开源·自动化·文心一言·ai编程