一、基本用法:
1.测试框架做了什么:
(1).测试发现
a.创建test_开头的文件
b.创建Test开头的类
c.创建test_开头的函数或方法
pytest中以每一个函数或方法作为一个用例
pytest主要以名字区分普通函数(方法)、用例
pytest的启动方式:在给定的项目中执行pytest命令即可
pytest输出用例的收集、执行、汇总信息
(2)断言:
内容判断机制,如果判断失败,则抛出异常
对于测试框架:
没有异常,则判断为通过
存在异常,判定为测试失败
(3).测试结果说明:
|--------|---------|-----------------|
| 缩写 | 单词 | 含义 |
| . | passed | 通过 |
| F | failed | 失败(用例执行时报错) |
| E | error | 出错(fixture执行报错) |
| s | skipped | 跳过 |
| X | xpassed | 预期外的通过 |
| x | xfailed | 预期内的失败 |
二、高级用法:
1.mark:
标记是为了用例之间彼此不同,实现用例的筛选
标记的使用步骤:
a.注册标记
b.贴上标记
c.筛选标记
**除了自己注册的标记之外,pytest还内置了一些标记:**跳过、预期失败、参数化、调用fixture
**第三方插件也会内置一些标记:**执行顺序、执行依赖、失败重试
2.fixture:
自动的在用例之前、之后完成、用于测试环境的构建和销毁
使用生成器实现前置、后置的分离
**a.fixture作用范围:**支持5级范围
**b.同一范围内的用例:**共享fixture
c.conftst.py创建全局范围的fixture
3.hook:
钩子:当pytest在合适的时机运行,进入、退出pytest核心内部
目的:改变pytest原有的处理方式和运行模式
一、pytest单元测试框架:
(1).什么是单元测试框架:
单元测试是指在开发中针对软件的最小单位进行正确性的检查测试
(2).单元测试框架:
java:junit和testing
python:unittest和pytest
(3).单元测试框架主要做什么:
a.测试发现:从多个文件里面找到测试用例
b.测试执行:按照一定的顺序和规则去执行,并生成结果
c.测试判断:通过断言判断预期结果和实际结果的差异
d.测试报告:统计测试进度,耗时,通过率以及生成测试报告
二、单元测试和自动化测试框架有什么关系:
(1).什么是自动化测试框架:
它就是自动化测试组长针对一个项目开发的一个代码框架,这个框架封装了很多的基础模块,报告模块等等
(2).作用:
1.提高测试效率,降低自动化用例的维护成本
2.减少人工干预,提高测试的准确性,增加代码的重用性
3.核心思想是让不懂代码的人也能够通过这个框架去实现自动化测试
(3).pytest单元测试框架和自动化测试框架的关系:
pytest单元测试框架:只是自动化测试框架中的组成部分之一
pom设计模式:只是自动化测试框架中的组成部分之一
数据驱动
关键字驱动
全局配置文件的封装
日志监控
selenium,requests二次封装
断言
报告邮件
三、Pytest简介:
1.pytest是一个非常成熟的python的单元框架,比unittest更灵活,容易上手
2.pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自动化
3.pytest可以实现测试用例的跳过以及reruns失败用例重试
4.pytest可以和allure生成非常美观的测试报告
5.pytest可以和Jenkins持续集成
6.pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作
pytest-xdist:测试用例分布式执行,多CPU分发
pytest-ordering:用于改变测试用例的执行顺序
pytest-rerunfailures:用例失败后重跑
pytest-html:生成html格式的自动化测试报告
allure-pytest用于生成美观的测试报告
四、使用pytest,默认的测试用例的规则以及基础应用
1.块名必须以test开头或者test结尾
2.测试类必须以Test开头,并且不能有init方法
3.测试方法必须以test开头
五、pytest测试用例的运行方式
1.主函数模式:
python
(1)运行所有:pytest.main()
(2)指定模块:pytest.main(['-vs','test_login.py'])
(3)指定目录:pytest.main(['-vs','./interface_testcase'])
(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成
pytest.main(['-vs','/interface_testcase/test_interface.py::test_04_func'])
pytest.main(['-vs','/interface_testcase/test_interface.py::TestInterface::test_03_zhiliao'])
2.命令行模式
bash
(1)运行所有:pytest
(2)指定模块:pytest -vs test_login.py
(3)指定目录:pytest -vs ./interface testcase
(4)指定目录:pytest -vs ./interface_testcase/test_interface.py::test_04_func
参数详解:
bash
-s:表示输出详细信息,包括打印print的信息
-v:表示输出更详细的信息
-n:表示支持多线程或者分布式运行测试用例
--reruns NUM:失败用例重跑
-x:表示只需要一个用例报错,那么测试停止
--maxfail=2:出现两个用例失败就停止
-k:根据测试用例的部分字符串指定测试用例
--html:生成指定的html文件测试报告
3.通过读取pytest.ini全局配置文件执行:
bash
pytest.ini这个文件它是pytest单元测试框架的核心配置文件。
1.位置:一般放在项目的根目录
2.编码:必须是ANSI,可以使用notpad++修改编码格式
3.作用:改变pytest默认的行为
4.运行的规则;不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件[pytest]
addopts = -vs #命令行的参数,用空格分隔
testpaths = ./testcase #测试用例的路径
python_files = test_*.py #模块名的规则
python_classes = Test* #类名的规则
python_functions = test #方法名的规则
markers =
smoke:冒烟用例
usermanage:用户管理模块
productmanage:商品管理模块
六、pytest执行测试用例的顺序是怎样的呢
pytest默认从上到下
改变默认的执行顺序:使用mark标记
python
@pytest.mark.run(order=3)
七、如何分组执行(冒烟,分模块执行,分接口和web执行)
pytest -m "smoke"
pytest -m"smoke or usemanage or productmanage"
八、pytest跳过测试用例
python
无条件跳过
@pytest.mark.skip(reason)
条件跳过
@pytest.mark.skip(condition,reason)
九、Pytest框架实现一些前后置的处理:
1.setup/teardown/setup_class/teardown_class
python
class Test01:
def setup_class(self):
print("在每个类执行前的初始化工作,比如创建日志对象,创建数据库的链接")
def setup(self):
print("在每个测试用例之前初始化的代码,比如打开浏览器,加载网页")
def teardown(self):
print("在每个测试用例之后的代码,比如关闭浏览器")
def teardown_class(self):
print("在每个类执行后的扫尾工作,比如销毁日志对象,关闭数据库的链接")