在第一节的时候,讲过,关于pytest执行的参数命令,比如执行用例的时候加上-s
参数,就能显示打印内容。-x
遇到错误时停止测试 ,–maxfail=1
出现1个失败就终止测试,等等运行条件
if __name__ == '__main__':
pytest.main(["-s -x", "./","--maxfail=1"])
如此多的运行参数,无论是从阅读还是配置都增加了难度。为了让项目运行方式便于管理,pytest专门提供了pytest.ini
文件,可以轻松解决上述问题。
pytest.ini 是一个固定文件,也就是说名称不能更改,而且必须存放在项目根目录下。
cmd下使用 pytest -h 命令查看pytest.ini的设置选项
C:\Users\xxx> pytest -h
usage: pytest [options] [file_or_dir] [file_or_dir] [...]
positional arguments:
file_or_dir
general:
-k EXPRESSION only run tests which match the given substring expression. An expression is a python evaluatable
expression where all names are substring-matched against test names and their parent classes.
Example: -k 'test_method or test_other' matches all test functions and classes whose name
contains 'test_method' or 'test_other', while -k 'not test_method' matches those that don't
contain 'test_method' in their names. -k 'not test_method and not test_other' will eliminate the
matches. Additionally keywords are matched to classes and functions containing extra names in
their 'extra_keyword_matches' set, as well as functions which have names assigned directly to
them. The matching is case-insensitive.
-m MARKEXPR only run tests matching given mark expression.
For example: -m 'mark1 and not mark2'.
--markers show markers (builtin, plugin and per-project ones).
-x, --exitfirst exit instantly on first error or failed test.
--fixtures, --funcargs
show available fixtures, sorted by plugin appearance (fixtures with leading '_' are only shown
with '-v')
--fixtures-per-test show fixtures per test
--pdb start the interactive Python debugger on errors or KeyboardInterrupt.
--pdbcls=modulename:classname
start a custom interactive Python debugger on errors. For example:
--pdbcls=IPython.terminal.debugger:TerminalPdb
--trace Immediately break when running each test.
--capture=method per-test capturing method: one of fd|sys|no|tee-sys.
-s shortcut for --capture=no.
--runxfail report the results of xfail tests as if they were not marked
--lf, --last-failed rerun only the tests that failed at the last run (or all if none failed)
--ff, --failed-first run all tests, but run the last failures first.
This may re-order tests and thus lead to repeated fixture setup/teardown.
--nf, --new-first run tests from new files first, then the rest of the tests sorted by file mtime
--cache-show=[CACHESHOW]
show cache contents, don't perform collection or tests. Optional argument: glob (default: '*').
--cache-clear remove all cache contents at start of test run.
--lfnf={all,none}, --last-failed-no-failures={all,none}
which tests to run with no previously (known) failures.
--sw, --stepwise exit on test failure and continue from last failing test next time
--sw-skip, --stepwise-skip
... ...
... ...
addopts
addopts
就可以专门解决开篇讲的问题。addopts 参数可以更改默认命令行选项,这个当我们在 cmd 输入一堆指令去执行用例的时候,就可以用该参数代替了,省去重复性的敲命令工作
[pytest]
addopts = -s -x --maxfail=1
文章开头的运行代码则可以调整为:
if __name__ == '__main__':
pytest.main(["./"])
addopts只是他的一种用法,还有其他一些经典用法。
testpaths
指定运行的测试用例目录。 如果需要执行多个目录下的,则需要在各个目录中间加入空格。例如运行path1 和 path2 路径下的所有用例:
[pytest]
testpaths = path1 path2
norecursedirs
指定不运行的测试用例目录,和testpaths
的效果正好相反,如果是多个目录则用空格隔开。
[pytest]
norecursedirs = logs .pytest_cache __pycache__ setting
marks
在之前讲mark 标记测试用例
一节的时候,就提到,为了解决使用@pytest.mark.xxx
会出现warning的情况,需要在pytest.ini文件对定义的mark进行解释
[pytest]
markers =
IOS: run in ios
Android: run in Android
smokeTest: smokeTest case
log_cli
控制日志文件的输出级别,log_cli=True
输出较为详细日志,包括运行路径。log_cli=False
, 输出粗略日志。建议使用log_cli=True
[pytest]
log_cli=True