我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python接口自动化测试(一)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python接口自动化测试(一)

一.既然我们有这些的接口测试工具,为什么要做接口做自动化?

敏捷开发,接口一般数量很大,团队实现接口测试,版本控制。
2、功能太死板,有些接口完全无法实现(复杂的加密接口,签名接口等)
3、接口项目当中有多种不同协议的接口。
4、排错,定位接口问题不方便,结合抓包实现。
5、没有办法生成美观的报告。
6、多接口串联,数据库验证,日志监控。
7、有些公司做web自动化+接口自动化。

二、python+requests模块

requests第三方库,主要用于发送http请求,做接口自动化。

#安装pip install requests

三、接口自动化之requests全局观

请求
requests. get()发送get请求
requests. post()发送post请求
requests. delete()发送delete请求
requests .put()发送put请求
requests. request()最核心的方法
import requestsrep = requests.request();
响应
rep.text返回字符串的数据(文本格式)
rep.content返回字节格式的数据(图片、文件)
rep.json()返回字典格式的数据(json格式)
rep.status_code状态码
rep.reason返回状态信息
rep.cookies返回cookie信息
rep.encoding返回编码格式
rep.headers返回响应头信息

四、接口实战

请求方式:get post put delete
请求参数类型: 键值对,JSON格式,文件格式

unittest、pytest管理用例框架:

前提是要安装pytest

pip install pytest

pytest默认规则:
1.py文件必须以test _ 开头或者 _ test结尾。
2类名必须以 Test 开头
3.测试用例必须以 test_ 开头

注意:

1、get请求通过params传递参数。
2、post请求通过json或者data传参。他们的区别是什么?data数据报文: dict字典类型,那么默认情况下请求头: application/x-www-form-urlencoded,表示以form表单的方式传参,格式: a=1&b=2&c=3数据报文: str类型,那么默认情况下: text/plain(如果是字典格式需要转换成str格式传参)json数据报文:不管是dict还是str类型,默认都是application/json ,格式: ({"a":1,"b".2)data = {"tag": {"id": 134, "name": "广东人"}}rep = requests.post(url=url, data=json.dumps(data))json.dumps(data)序列化把字典格式的数据转换成str格式.json.loads(data)反序列化把str格式转换成字典格式总结:data只能传递简单的只有键值对的dict或者是str格式。json一般只能传dict格式(简单和嵌套都可以)
#3、文件传参files,且一定要opendata={     "media":open(r"E:\shu.png","rb")}rep = requests.post(url=url, files=data)
#  以下代码运行不起来,但是写法没错import pytestimport requestsclass TestSendRequest:    access_token=""    def test_get_token(self):        # 发送get请求        url = "https://api.weixin.qq.com/cgi-bin/token"        data = {            "grant_type": "client_credential",            "appid": "自己找素材",            "secret": "自己找素材"        }        rep = requests.get(url=url, params=data)        print(rep.json())        TestSendRequest.access_token = rep.json()["access_token"]    def test_edit_flag(self):        # 发送post请求(data和json只需要传一个,data和json的区别)        url = "https://api.weixin.qq.com/cgi-bin/token/tags/update?access_token=" + TestSendRequest.access_token + ""        data = {"tag": {"id": 134, "name": "广东人"}}        rep = requests.post(url=url, json=data)        print(rep.json())if __name__ == '__main__':    #-vs 打印调试信息    pytest.main(['-vs'])

cookie鉴权: 网页的接口基本上都要做cookie鉴权。(不常用)
给了token和请求头,但是请求还是fail,需要做cookie鉴权

import reimport pytestimport requestsclass TestSendRequest:    cks=""        #需要带请求头的接口以及需要cookie关 联的接口如何测试?    def test_start(self):        url = "http://47.107.116.139/phpwind/"        rep=requests.get(url=url)        print (rep.text)        #通过正则表达式获取鉴权码        TestSendRequest.csrf_token= re.search( 'name="csrf_token" value="(.*?)"', rep.text)[1]        print(TestSendRequest.csrf_token)        TestSendRequest.cks=rep.cookies    #请求需要带请求头的接口    def test_login(self) :        url = "http://47.107.116.139/phpwind/index.php?m=u&c=login&a=dorun"        data = {            "username" : "msxy",            "password" :"msxy",            "csrf_token": TestSendRequest.csrf_token,            "backurl": "http://47. 107.116.139/ phpwind/",            "invite": ""        }        headers = {            "Accept": "application/json,text/ javascript, / ; q=0.01",            "X一Requested-With" : "XMLHttpRequest"        }        rep = requests. post (url=url, data=data , headers=headers,cookies=TestSendRequest.cks )        print (rep.json() )if __name__ == '__main__':    #-vs 打印调试信息    pytest.main(['-vs'])

通过session实现cookie鉴权(常用)

import reimport pytestimport requestsclass TestSendRequest:csrf_token=""    session = requests.session()        #需要带请求头的接口以及需要cookie关 联的接口如何测试?    def test_start(self):        url = "http://47.107.116.139/phpwind/"        rep=requests.get(url=url)        print (rep.text)        #通过正则表达式获取鉴权码        TestSendRequest.csrf_token= re.search( 'name="csrf_token" value="(.*?)"', rep.text)[1]        print(TestSendRequest.csrf_token    #请求需要带请求头的接口    def test_login(self) :        url = "http://47.107.116.139/phpwind/index.php?m=u&c=login&a=dorun"        data = {            "username" : "msxy",            "password" :"msxy",            "csrf_token": TestSendRequest.csrf_token,            "backurl": "http://47. 107.116.139/ phpwind/",            "invite": ""        }        headers = {            "Accept": "application/json,text/ javascript, / ; q=0.01",            "X一Requested-With" : "XMLHttpRequest"        }        rep = TestSendRequest.session.post (url=url, data=data , headers=headers)        print (rep.json() )if __name__ == '__main__':    #-vs 打印调试信息    pytest.main(['-vs'])

接口自动化测试框架封装

第一步 统一请求方式

rep=requests.request(请求方式,地址,参数…)

def test_get_token(self):        # 发送get请求        url = "https://api.weixin.qq.com/cgi-bin/token"        data = {            "grant_type": "client_credential",            "appid": "wx6b11b3efd1cdc290",            "secret": "106a9c6157c4db5f602991873819529d"        }        rep = requests.request("get",url=url, params=data)        print(rep.json())        TestSendRequest.access_token = rep.json()["access_token"]

Pytest全局观

它可以和所有的自动化测试工具selenium、requests、appium结合实现web自动化、接口自动化以及app自动化;
2、跳过用例、失败用例重跑;
3、结合allure生成美观的测试报告;
4、和Jenkins持续集成;
5、有很多的强大插件。

1、常用操作(一)

项目的在根目录下创建requirements.txt文件
注意(#是我自己为了方便看代码的解释,复制请删除)

#pytest框架pytest#生产html测试报告pytest-html#多线程运行pytest-xdist#改变测试用例的执行顺序pytest-ordering#失败用例重跑pytest-rerunfailures#生产allure测试报告allure-pytest
#在命令窗口使用 安装这个文件里面的插件pip install -r requirements.txt 

2、常用操作(二)运行方式

在根目录下创建python.ini文件

#提示这是pytest文件[pytest]#执行方法,-m "smoke" 只执行冒烟用例,要想执行其他用例  删除-m以及后面的addopts = -vs -m "smoke"#文件路径testpaths = ./ui#文件以test_开头python_files = test_*.py#类名以Test开头python_classes = Test*#用例以test_开头python_functions = test_*#对用例进行分组 在用例上@pytest.mark.smoke,就执行加了这样的用例markers =    smoke:maoyan

若没有建立python.ini文件
在主程序中输出结果如下表达:

if __name__ == '__main__':    '''    v   输出更加详细的运行信息    -s  输出调试信息    -n  多线程运行    --reruns数字  失败用例重跑    --html='报告的路径'    '''    #写了pytest.ini    pytest.main()    # pytest.main(['-vs','-n=2'])    # pytest.main(['-vs','--reruns=2'])    # pytest.main(['-vs','--html=./report.html'])    

3、常用操作(三)前置后置

setUp()/tearDown() 在每个用例之前/之后执行一次
setUp_class()/tearDown_class() 在每个之前/之后执行一次

实现部分的前置

部分前置:
@pytest.fixture(scope=“作用域”,params=“数据驱动”,autouse=“自动执行”,ids=“自定义参数名”,name=“重命名”)
作用域: function(默认)、classmodulepackage/session

import requestsimport reimport pytest#部分前置@pytest.fixture(scope="function")def conn_database():    print("连接数据库")    #可以通过yield唤醒teardown的功能,就是返回,yield和return都有返回数据的意思#但是yield返回多次及多个数据,return只返回一次且return后面的代码不执行    yield    print("关闭数据库")```class Test:    def test_edit_flag(self,conn_database):        url=''        data={"tag":{"id":134,"name":"小李"}}        rep=Test.session.request('post',url,json=data

一般情况下:
@pytest.fixture()conftest.py文件一起使用
conftest.py文件
1.conftest.py:文件是单独存放**@pytest.fixture()**的方法,可以实现多个py文件共享前置配置
2.conftest.py:不需要导入直接使用,可以直接使用
3.conftest.py:可以有多个,也可以有多个不同层级

import pytest@pytest.fixture(scope="function")def conn_database():    print("连接数据库")    yield    print("关闭数据库")

4、接口自动化测试框架封装(接口关联封装)

创建 common 文件夹,创建 yaml_util.py 文件

import osimport yamlclass YamlUtil:    #读取extract.yml文件    def read_extract_yaml(self,key):        with open(os.getcwd()+"./extract.yml",mode="r",encoding="utf-8") as f:            value=yaml.load(stream=f,Loader=yaml.FullLoader)            return value[key]    #写入extract.yml文件    def read_extract_yaml(self,data):        with open(os.getcwd()+"./extract.yml",mode="w",encoding="utf-8") as f:            yaml.dump(data=data,stream=f,allow_unicode=True)    #清除extract.yml文件    def clearn_extract_yaml(self):        with open(os.getcwd()+"./extract.yml",mode="w",encoding="utf-8") as f:            f.truncate()

创建extract.yml文件
3、创建conftest.py文件

import pytestfrom common.yaml_util import YamlUtil#autouse  自动执行,无需调用#scope 作用域(session)@pytest.fixture(scope="session",autouse=True)def clearn_Yaml():    YamlUtil().clearn_extract_yaml()

5、pytest断言

# result ==>{"errcode": 0,"message":"数据返回成功"}result = rep.json()# 第一种assert result['errcode'] == 0#第二种assert 'errcode' in rep.json()#比较多个或者用andassert 'errcode' in rep.json()assert 'message' in rep.json()assert 'errcode' in rep.json() and 1==1

6、allure-pytest生成allure测试报告

6.1、官网下载allure:

https://github.com/allure-framework/allure2/releases
下载 .zip 的包,放到没有中文的路径下,然后把E:\allure-2.13.7\bin配置到环境变量的path里面哦

6.2、重启pycharm 通过:allure --version验证(若没有打开pycharm,则跳过)

6.3、执行命令

(1)在temp目录下生成临时的json文件的报告,在pytest.ini文件下写 - -alluredir ./temp
在当前目录下创建temp目录

[pytest]#执行方法addopts = -vs --alluredir ./temp#文件路径testpaths = ./ui#文件以test_开头python_files = test_*.py#类名以Test开头python_classes = Test*#用例以test_开头python_functions = test_*

(2)通过临时的json文件生成allure报告(在reports目录下),在all.py文件写
os.system(“allure generate temp -o reports --clean”)
在当前目录下创建 reports目录

import pytestif __name__ == '__main__':    pytest.main()    os.system("allure generate temp -o reports --clean")

6.4、allure报告的定制

来源地址:https://blog.csdn.net/qq_44895262/article/details/126559695

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python接口自动化测试(一)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python-接口自动化(一)

一、python语言特点1、易于学习:python有相对较少的关键字,结构简单,有一个明确定义的语法,学起来比较简单; 2、易于阅读:python代码定义的更清晰; 3、易于维护:python的成功在于它的源代码是相当容易维护的; 4、一个
2023-01-31

Python接口测试自动化的示例代码

本篇内容主要讲解“Python接口测试自动化的示例代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python接口测试自动化的示例代码”吧!1、接口请求python 特别是 python 3.
2023-06-16

Python+Requests+PyTest+Excel+Allure 接口自动化测试实战

本文主要介绍了Python+Requests+PyTest+Excel+Allure 接口自动化测试实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-02-23

python接口测试(一)

基于Jenkins接口测试# coding = utf-8import httplibhttp_client = Nonehttp_client = httplib.HTTPConnection('localhost' , 8080 , t
2023-01-31

如何用Postman做接口自动化测试

前言什么是自动化测试把人对软件的测试行为转化为由机器执行测试行为的一种实践。例如GUI自动化测试,模拟人去操作软件界面,把人从简单重复的劳动中解放出来本质是用代码去测试另一段代码,属于一种软件开发工作,已经开发完成的用例还必须随着被测试对象
2023-06-04

Postman中怎么进行接口测试和自动化测试

在Postman中进行接口测试和自动化测试可以按照以下步骤进行:创建一个新的Postman集合:在Postman中,创建一个新的集合来组织你的测试用例。集合可以包含多个请求,你可以按照不同的功能或模块进行组织。添加测试用例:在集合中添加测试
Postman中怎么进行接口测试和自动化测试
2024-03-13

如何进行Postman自动化接口测试

如何进行Postman自动化接口测试,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。背景描述有一个项目要使用postman进行接口测试,接口所需参数有:appid: 应用标识;s
2023-06-21

自动化性能测试在PHP接口优化中的应用(PHP接口优化中自动化性能测试的运用)

自动化性能测试在PHP接口优化中发挥着至关重要的作用,有助于识别和解决性能瓶颈,提升接口性能和用户体验。通过性能基准测试、负载测试、压力测试、性能分析、持续集成、性能优化、用户体验监控和维护更新等应用,自动化性能测试成为PHP接口优化不可或缺的工具,确保接口在不断变化的环境中保持最佳性能。
自动化性能测试在PHP接口优化中的应用(PHP接口优化中自动化性能测试的运用)
2024-04-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录