1、用例编写规则html
1.unittest提供了test cases、test suites、test fixtures、test runner相关的类,让测试更加明确、方便、可控。使用unittest编写用例,必须遵照如下规则:python
(1)测试文件必须先import unittestsession
(2)测试类必须继承unittest.TestCase框架
(3)测试方法必须以“test_”开头函数
(4)测试类必需要有unittest.main()方法post
2.pytest是python的第三方测试框架,是基于unittest的扩展框架,比unittest更简洁,更高效。使用pytest编写用例,必须遵照如下规则:测试
(1)测试文件名必须以“test_”开头或者"_test"结尾(如:test_ab.py)ui
(2)测试方法必须以“test_”开头。url
(3)测试类命名以"Test"开头。spa
总结: unittest :用例格式--复杂,不能兼容pytest用例;
pytest: 用例格式--简单,能够兼容unittest用例;
2、用例前置和后置
1.unittest提供了setUp/tearDown,只能针对全部用例。
2.pytest提供了模块级、函数级、类级、方法级的setup/teardown,比unittest的setUp/tearDown更灵活。
模块级(setup_module/teardown_module)开始于模块始末,全局的
函数级(setup_function/teardown_function)只对函数用例生效(不在类中)
类级(setup_class/teardown_class)只在类中先后运行一次(在类中)
方法级(setup_method/teardown_method)开始于方法始末(在类中)
类里面的(setup/teardown)运行在调用方法的先后
pytest还能够在函数前加@pytest.fixture()装饰器,在测试用例中使用fixture函数。fixture的使用范围能够是function,module,class,session。
firture相对于setup和teardown来讲有如下几点优点:
命名方式灵活,不局限于setup和teardown这几个命名
conftest.py 配置里能够实现数据共享,不须要import就能自动找到一些配置,可供多个py文件调用。
scope="module" 能够实现多个.py跨文件共享前置
scope="session" 以实现多个.py跨文件使用一个session来完成多个用例
用yield来唤醒teardown的执行
3、断言
1.unittest提供了assertEqual、assertIn、assertTrue、assertFalse。
2.pytest直接使用assert 表达式。
4、报告
1.unittest使用HTMLTestRunnerNew库。
2.pytest有pytest-HTML、allure插件。
5、失败重跑
一、unittest无此功能。
二、pytest支持用例执行失败重跑,pytest-rerunfailures插件。
6、参数化
一、unittest需依赖ddt库,
二、pytest直接使用 @pytest.mark.parametrize 装饰器。
7、用例分类执行
一、unittest默认执行所有的用例,能够经过加载testsuite执行部门模块用例;
二、pytest能够经过 @pytest.mark 来标记测试用例,执行命令加上参数“-m”便可运行标记的用例。