小程序三方平台开发: 解析小程序开发的未来趋势和机遇
646
2022-11-13
pytest基本用法简介
这篇文章主要介绍了pytest基本用法简介,帮助大家更好的利用python进行自动化测试,感兴趣的朋友可以了解下
目录 1、安装pytest,打开dos窗口输入:
2、通过pycharm工具-
3、创建pytest测试用例步骤
4、pytest-函数级别初始化-销毁的方法
5、pytest-类级别初始化-销毁的方法
6、pytest配置文件
7、pytest-html生成测试报告
8、pytest-order测试运行顺序
9、pytest-rerunfailures失败重试
10、pytest-断言
11、参数化
1、安装pytest,打开dos窗口输入:
pip install pytest
2、通过pycharm工具-
3、创建pytest测试用例步骤
# 定义测试类class TestDivide: # 定义测试方法 def test_divide_01(self): result = divide(1,1) print(result)
问题:右键运行没有pytest运行的方式的处理步骤 第一步:检查文件名和文件所在目录是否合法,对应第一点 第二步:修改默认运行方式为pytest 第三步:删除历史运行记录
4、pytest-函数级别初始化-销毁的方法
class TestDemo: # 不想去调用初始化的动作的方法,让pytest自动识别接口之后自己进行内部调用 def setup(self): "每个方法在运行之前都会自动调用setup,执行setup下方的代码" def teardown(self): "每个方法在运行之后都会自动调用teardown,执行teardown下方的代码"# 仅做参考了解即可def setup_method(self)/def teardown_method(self)在后续写代码的过程中,如果测试类中存在多个测试方法,且每个测试方法在运行之前都有共同的操作。则可以使用方法级别的初始化方法来简化代码
5、pytest-类级别初始化-销毁的方法
# 定义测试类 class TestDeme: # 在整个测试类运行之前自动调用的代码 def setup_class(self): print("整个测试类在运行之前会自动调用的代码,优先级会高于方法级别初始化方法调用")# 在整个测试运行完成之后会自动调用的代码 def teardown_class(self): print("整个测试类在运行完成之后的会调用的代码,优先级会低于
6、pytest配置文件
1.在工程的根目录下直接创建的pytest.ini文件,文件名固定不能修改 2.pytest.ini文件需要修改为GBK编码格式
[pytest]# 添加命令行参数addopts = -s# 文件搜索路径,要执行的测试用例所在目录testpaths = ./TestCase# 文件名称,要执行的测试用例的文件名过滤条件python_files = test_*.py# 类名称,要执行测试用例类的名称过滤条件python_classes = Test*# 方法名称,要执行测试用例方法过滤条件python_functions = test_*
3.打开pycharm-terminal控制台输入pytest即可
7、pytest-html生成测试报告
安装pytest-html第三方模块
pip install pytest-html
在pytest.ini配置文件中添加对应的配置
[pytest]# 添加命令行参数addopts = -s --html=report/report.html
1.右键使用pytest运行单个测试用例的使用pytest.ini的配置文件对运行的条件一样的有控制 2.pytest.ini文件一般都会直接放在工程的根目录之下
8、pytest-order测试运行顺序
1、-pytest-ordering的第三方模块: pip install pytest-ordering 2、指定顺序的方式: 记得导包 给测试方法指定顺序 给测试类指定顺序
# 使用正整数排序,值越小运行优先级越高@pytest.mark.run(order=101)class TestDivide: @pytest.mark.run(order=3) def test_divide_one(self): # self.print_start_time() result = divide(1, 1) print("我是第一个测试方法,但是我想第三个运行") # print("end-time={}".format(time.time())) @pytest.mark.run(order=1) def test_divide_two(self): # self.print_start_time() result = divide(1, 1) print("我是第二个测试方法,但是我想第一个运行") # print("end-time={}".format(time.strftime("%Y%m%d%H%M%S"))) @pytest.mark.run(order=2) def test_divide_three(self): # self.print_start_time() result = divide(1, 1) print("我是第三个测试方法,但是我想第二个运行") # print("end-time={}".format(time.strftime("%Y%m%d%H%M%S")))
9、pytest-rerunfailures失败重试
1、安装pytest-rerunfailures的第三模块 2、修改pytest.ini的配置文件
[pytest]addopts = -s --reruns 3 # --rerun表示要失败重试,3表示重试最大次数
10、pytest-断言
pytest提供assert断言的方法assert 后可以写任意的表达式.判断assert后续的代码运行之后的结果是否为真,如果为真则通过,如果不为则失败# 根据文本判断元素是否存在try:is_suc= self.driver.find_element_by_xpath("//*[text()='{}']".format("会员折扣"))except Exception as e:is_suc = Falseassert is_suc
11、参数化
class TestDemo: @pytest.mark.parametrize(("divide_no", "divide_no_2", "expect"), [(1, 1, 1), (1, 1, 1), (10, 10, 1)]) def test_six(self, divide_no, divide_no_2, expect): """ :param divide_no:除数 :param divide_no_2: 被除数 :param expect: 期望结果 :return: """ result = divide(divide_no, divide_no_2) assert expect == result # 测试数据统一使用标注的列表嵌套元组的格式 : [(),()] @pytest.mark.parametrize((定义所有的参数的名称,需要带上引号),具体每一组测试数据)
以上就是pytest基本用法简介的详细内容,更多关于pytest基本用法的资料请关注"软件测试pytest"其它相关文章!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~