课程地址
request
requests.post() data和json 的区别
postdata = {'jobId': '1',
'jobType': 'predict',
'targetClass': 'vm',
'targetId': 123}
requests.post('http://127.0.0.1:5000/api/getPredictInfo', json=postdata,
headers={'Content-Type': 'application/json'})
或者
requests.post('http://127.0.0.1:5000/api/getPredictInfo', data=json.dunps(postdata))
data传参表示表单传参:默认的请求头是Content-Type:application/x-www-formurlencoded,请求参数的格式:(k1=v1&k2=v2),参数是纯键值对的dict.,如: {key1:value1,key2:value2} data传参表示文本传参:默认的请求头:text/plain。参数:str类型 json传参表示json传参:默认的请求头:application/json,参数是dict类型 json是包括有键值对和列表的Dict类型
文件上传
postdata = {'midea':open('./test.jpg',"rb")}
requests.post('http://127.0.0.1:5000/api/getPredictInfo', files=postdata)
带cookie测试
rep= requests.get()
通过get请求获取到登陆的token,然后登陆测试
headers = {"Accept":"aplication/json,text/javascript,*/*;q=0.01",
"X-Requested-With":"XMLHttpRequest"}
rep = requests.post(url,data=data,headers=headers,cookies=rep.cookies)
同一个session中完成多个请求测试
可以将上面的requests.post ,requests.get 等换成
requests.session().request("post",xxx)
requests.session().request("get",xxx)
这样统一接口,requests.post 都是调用的requests.request()
pytest
1.模块名必须以test_或_test开头 2.测试类必须以Test开头,并且不能有init方法 3.测试方法必须以test_开头 4.Pytest有很多的强大的插件。pip install 安装
pytest-html 生成简易报告 pytest-xdist 多线程 pytest-orderding 控制测试用例的执行顺序 pytest-rerunfailures 失败用例重跑 pytest-base-url 基础路径的配置 allure-pytest 生成allure报告
命令行
pytest -vs
pytest -k “add” 执行所有测试用例名中含有“add”的用例
pytest - s 打印测试用例中print语句
pytest -v 增加打印细节
pytest - x 一旦发现失败用例,停止运行
pytest -maxfail=2 当测试遇到两条失败,立刻停止运行
pytest -m “标签名” 给测试用例加标签
pytest -n 多线程(需要安装pytest-xdist)
pytest --reruns=2 失败用例重跑2次
pytest --html='./report.html' 生成简易报告
配置文件
注意: 1.不管是命令行方式还是主函数的方式都会自动的读取这个配置文件 2.pytest.ini 文件可以改变pytest默认的测试用例的规则 3.这个文件一般是放在项目的根目录下
[pytest]
addopts = ‐vs
testpaths = ./testcases
python_files = test_*.py
python_classes = Test*
python_functions = test_*
base_url = http://127.0.0.1/
markers =
smoke:冒烟测试
usermanage:用户管理
冒烟和用户管理要在用例上面加上装饰器:
@pytest.mark.smoke
@pytest.mark.usermanage
在执行时需要使用:
-m 分组名 or 分组名
Pytest用例执行顺序默认:是从上到下的顺序 可以通过如下标记改变测试用例的执行顺序@pytest.mark.run(order=1)
Pytest前后置条件
在所有类,所有用例之前或之后
def setup_class(self):
print("在类之前的操作")
def teardown_class(self):
print("在类之后的操作")
def setup(self):
print("在所有用例之前的前置操作")
def teardown(self):
print("在所有用例之后的后置操作")
希望在部分用例之前或之后执行。使用Fixture Fixture装饰器完整结构如下:
@pytest.fixture(scope="作用域",autouser="自动执行",params="数据驱
动",ids="参数别名",name="fixture别名")
scope :标记fixture的作用域
function :函数级别(可以手动,也可以自动)class :类级别(一般是自动)module :模块级别(一般是自动)package/session :会话级别(一般是自动):明天封装框架用法。
autouser=True 自动执行 params 数据驱动 name 表示fixture的别名,当使用了name起别名之后,那么原来的fixture的名称就失效了。
部分前置的用例,测试用例直接把前置函数的函数名传入
import pytest
@pytest.fixture()
def conn_database():
print("连接数据")
yield
print("关闭")
class TestALL:
def test_A(self):
print("test A")
def test_B(self,conn_database):
print("test B")
def test_C(self):
print("test C")
if __name__ == '__main__':
pytest.main(['-vs'])
优化 一般情况下fixture会和conftest.py文件一起使用。
conftest.py是专门用于存放fixture的,是固定名称
conftest.py文件的方法使用时不需要导包
conftest.py文件可以有多个
将上面的conn_database函数放入新建的conftest.py文件中
@pytest.fixture(scope="session",autouse=True)
def claer_yaml():
YamlUtil().clear_yaml()
claer_yaml 函数自动执行,不需要当作参数传入
生成allure报告
1,下载安装 2,pip install allure-pytest 3,addopts = ‐vs --allurdir ./temp # 生成的json 文件的保存路径 4,通过json 生成报告os.system("allure generate temp -o report") 生成到report目录中
数据驱动的测试
import pytest
class TestApi:
@pytest.mark.parametrize("args",["a","b","c"])
def test_api(self,args):
print(args)
if __name__ == '__main__':
pytest.main(['test_2.py'])
postman
接口关联
data:image/s3,"s3://crabby-images/f9f82/f9f824fa305030d38489d3ba836ad3d6dcfc7661" alt="在这里插入图片描述" 其他接口需要用到上面接口的返回值,如下操作 data:image/s3,"s3://crabby-images/ccd77/ccd77402a5705efa42be200d606ac375a167d6b3" alt="在这里插入图片描述"
环境切换
data:image/s3,"s3://crabby-images/aec7e/aec7e7f119614d16eb9340842d1ea26910ed906f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5438e/5438ed67f0fb779cc2b410ca9bac16586197c85e" alt="在这里插入图片描述"
动态传参
{{$timestamp}} 生成当前时间的时间戳 {{$randomInt}} 生成0-1000之间的随机数(很少用) {{$guid}} 生成速记GUID字符串
自定义动态参数 data:image/s3,"s3://crabby-images/bef97/bef9753174d4e1a05e1f96ad6694af3795020167" alt="在这里插入图片描述" 请求的时候通过{{time}} 引用 data:image/s3,"s3://crabby-images/9ec0b/9ec0babaaae93f47b6d27ffc13baab68f9f8030f" alt="在这里插入图片描述"
业务闭环(增删改查)
利用全局变量,然后删改查直接引用全局变量 data:image/s3,"s3://crabby-images/87f3c/87f3c5ef0aa7e1ea0d04be515ec1d7cf54878d32" alt="在这里插入图片描述"
断言
在Pre-request-Script 模块中 data:image/s3,"s3://crabby-images/d4b96/d4b965c5d72adfd8de5f0f24ceddfb26a74a01df" alt="在这里插入图片描述"
状态断言
data:image/s3,"s3://crabby-images/edb4c/edb4c3c8ef661d2fbfd6569dc1abd1e3b0180618" alt="在这里插入图片描述"
业务断言
data:image/s3,"s3://crabby-images/79e41/79e41883807b95703a46ed5ba212bac98768e588" alt="在这里插入图片描述"
在tests页签里面不能通过{{}}方式获取全局变量,只能通过以下方式获取 data:image/s3,"s3://crabby-images/cfd10/cfd10165a2611c789aed83b9ddfd9141c1ff20da" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/424a7/424a7ce5c6d81ce69424f956f50939dec78826e6" alt="在这里插入图片描述" 完全相同的断言,可以作为全局断言,不用在每个脚本中重复 data:image/s3,"s3://crabby-images/a1ca6/a1ca6b7945ce6b6eb18c402b09e12f54d87feb1d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/74417/74417e9b1f42c5446519b576bc7b053d441da4a3" alt="在这里插入图片描述"
文件上传
data:image/s3,"s3://crabby-images/b9806/b9806693f016cf8f8d2d70d21d48090cb9e73d5d" alt="在这里插入图片描述"
批量测试
一次测试多个脚本 data:image/s3,"s3://crabby-images/a2465/a2465140282e661a1d669f53757c7f351877e9c4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/65b88/65b8877c842dfc0f4d7c7519d8e4804c3c9223c3" alt="在这里插入图片描述"
文件上传批量测试接口报错
postman软件更改设置 Settings ->General ->Location 1,打开 Allow reading files outside working drectory 2,把要上传测试的文件复制到默认目录下(postman会在默认目录下读取文件)
数据驱动测试
一般CSV或者JSON文件 data:image/s3,"s3://crabby-images/6f8cb/6f8cb1f4ac6ea48f0b26a1ab82c506273007cd8e" alt="在这里插入图片描述" 批量测试的时候,遇到返回的结果一样,可能是之前Params 中参数值写死了,需要改成按照变量获取 data:image/s3,"s3://crabby-images/d000d/d000d1db55382b4845cbb7a1e56eedf401092898" alt="在这里插入图片描述" 取文件中变量的值,采用data.变量名 不是之前的global.
带请求头的测试
需要用到抓包工具Telerik Fiddler
data:image/s3,"s3://crabby-images/b7bb5/b7bb571f16dcd16037985cdd36673dcc89eb1ca4" alt="在这里插入图片描述" 复制到Headers 中,删除掉一些地址,不必要的信息
Cookie 鉴权测试
Cookie是一小段的文本信息,在客户端第一次请求服务端的时候生成 第一次请求时在请求头 是没有Cookie 的,在响应头 的set-cookie 中生成Cookie 并返回传给客户端,以后请求的时候会在请求头 中带上Cookie
postman 会自动保存Cookie
postman 的 Mock Server服务器
使用场景:前后端分离,后端接口没有完成,但是前端已经完成,前端的业务流程依赖于后端的接口
data:image/s3,"s3://crabby-images/8a191/8a191e8f5d547d30d8471bc958f86c72825379ba" alt="在这里插入图片描述" 相当于可以自己创建一个后端接口,用来测试前端,可以自定义返回信息
接口测试加密解密
加密解密测试网站 Pre-Script-Request 中写代码加密文档之后设置成全局变量测试
Newman
到处postman 中的测试用例,全局变量,环境变量,数据文件 data:image/s3,"s3://crabby-images/eaa6b/eaa6bb548833b9f370437384520d7cb03ee3d211" alt="在这里插入图片描述" NewMan安装
newman run 接口脚本.json -e 环境变量.json -r html --reporter-html-export test.html
参数详解
RobotFrameWork
安装 Robot Framework
pip install robotframework
安装GUI界面
pip install –i https://pypi.douban.com/simple robotframework-ride
自定义关键字
data:image/s3,"s3://crabby-images/36ce5/36ce512e61bcc193df85eb8bde363aa2c206ee5c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4a7a7/4a7a77f340e16db4d9e654de125a7cb876339bc2" alt="在这里插入图片描述" 右键新建的文件 data:image/s3,"s3://crabby-images/1de16/1de16c28e8f1ce996b6d764172ea10912efd201d" alt="在这里插入图片描述" 刚创建的还不能被使用,必须在套件中导入资源文件 data:image/s3,"s3://crabby-images/e49d9/e49d9cf46580d3ae422b23ab28b40186e271e080" alt="在这里插入图片描述"
常用库
扩展库 1)web自动化库–Selenium
pip install –i https://pypi.douban.com/simple robotframework- seleniumlibrary
2)api自动化库–requests
pip install -i https://pypi.python.org/pypi/robotframework-requests
3)app自动胡库
pip install robotframework-AppiumLibrary
|