Pytest07-配置

7.配置

7.1 pytest配置文件概念

    pytest常见的非测试文件,如下所示:

  • 1.pytest.ini:pytest的主配置文件,可以改变pytest的默认行为,其中有很多可配置的选项
  • 2.conftest.py:本地的插件库,其中的hook函数和fixture将作用于该文件所在的目录及其子目录
  • 3.__init__:每个测试子目录可能都包含该文件,代表一个包,常用于解决命名冲突

    pytest.ini示例如下所示:

[pytest]
addopts = -rsxX -L --tb=short --strict
xfail_stric = true
...

7.1.1 使用pytest --help查看ini文件选项

>>> pytest --help
[pytest] ini-options in the first pytest.ini|tox.ini|setup.cfg file found:

  markers (linelist):       markers for test functions
  empty_parameter_set_mark (string): default marker for empty parametersets
  norecursedirs (args):     directory patterns to avoid for recursion
  testpaths (args):         directories to search for tests when no files or directories are given in
  usefixtures (args):       list of default fixtures to be used with this project
  python_files (args):      glob-style file patterns for Python test module discovery
  python_classes (args):    prefixes or glob names for Python test class discovery
  python_functions (args):  prefixes or glob names for Python test function and method discovery

7.1.2 插件可以添加ini文件选项

    除前面列出的选项,利用插件和conftest.py文件还可以添加新的选项。新增的选项也可以使用pytest --help查看。

7.2 更改默认命令行选项

    如果某一些选项经常,又不想每次重复输入,这时则可以修改pytest.ini文件的addopts设置,如下所示:

[pytest]
addopts = -rsxX -L --tb=short --strict

7.3 注册标记来防止拼写错误

    自定义标记可以简化测试工作,让我们可以使用指定的标记运行某个子集,但标记很容易拼错。默认情况下,并不会引起程序错误,pytest会以为是创建的另外一个新的标记。为避免这种情况,可以在pytest.ini中注册标记。如下所示:

[pytest]
markers =
   smoke: Run the smoke test function
   get:   Run the get test function

    标记做好之后,可以通过pytest --markers来查看,如下所示:

>>> pytest --markers

@pytest.mark.smoke: Run the smoke test function
@pytest.mark.get:   Run the get test function

    没有注册的标记不会出现在--markers列表中。如果使用--strict选项,遇到拼写错误的标记或未标记的标记就会报错。

7.4 指定pytest的最低版本号

    minversion选项可以指定运行测试用例的pytest的最低版本。示例如下所示:

[pytest]
minversion = 5.2

7.5 指定pytest忽略某些目录

    pytest在默认情况,会搜索指定目录及其子目录。如果想跳过某些目录,可以使用norecursedirs选项。

norecursedirs的默认设置是.* build dist CVS _darcs {arch}和*.egg

    示例如下所示:

[pytest]
norecursedirs = .* build dist CVS _darcs \{arch\} *.egg

7.6 指定测试目录

    norecursedirs指定哪些目录不用访问,而 testpaths 则指定了pytest去哪里搜索运行测试, testpaths是一系列相对于根目录的路径,用于限定测试用例的搜索范围,只有在pytest未指定文件目录参数或测试用例标识符时,该选项才会启用。如下所示:

[pytest]
testpaths = test

7.7 更改测试搜索的规则

    pytest根据一定的规则搜索并运行测试,一个标准的测试搜索规则如下所示:

  • 1.从一个或多个目录开始查找,如果未指定,则默认为当前目录
  • 2.在该目录及其子目录中查找测试模块,测试模块是以test_.py或_test.py的文件
  • 3.在测试模块中搜索以test_开头的函数名或Test开头的类,且过滤掉包含__init__()的类

1.python_classes

    通常,pytest的测试搜索规则是寻找以Test*开头的测试类,而且这个类不能包含__init__()方法。但如果没有按照这个格式对类进行命名(如 < something > Test),该怎么办?针对这种情况,可以使用python_classes来解决这个问题。如下所示:

[pytest]
python_classes = *Test Test* *Suite

2.python_files

    与python_classes类似,python_files是更改搜索测试模块的规则,如下所示:

[pytest]
python_files = test_* *_test check_*

3.python_functions

    与前面两个类似,python_functions是更改搜索测试函数规则,如下所示:

[pytest]
python_functions = test_* *_test check_*

7.8 禁用XPASS

    设置xfail_strict = True 可以将那些被标记@pytest.mark.xfail但实际运行通过的测试用例也被报告为测试失败。设置如下所示:

[pytest]
xfail_strict = True

7.9 避免文件冲突

    在讲解Python的模块和包时,为了避免命名冲突,可以使用模块和包。在测试过程中,同样也可以同样的解决思路。

你可能感兴趣的:(Pytest07-配置)