Pytest 框架可以用来做 系统测试 的自动化, 它的特点有

  • 用 Python 编写测试用例,简便易用
  • 可以用 文件系统目录层次 对应 手工测试用例 层次结构
  • 灵活的 初始化清除 机制
  • 可以灵活挑选测试用例执行
  • 利用第三方插件,可以生成不错的报表

----------------------------------------------------------------------------------------------

安装

pip install pytest

我们还需要产生测试报表,所以要安装一个第三方插件 pytest-html ,执行如下命令安装

pip install pytest-html

-----------------------------------------------------------------------------------------

快速上手

pytest 如何知道你哪些代码是自动化的测试用例?

官方文档 给出了 pytest 寻找 测试项 的 具体规则

  • 如果未指定命令行参数,则从 testpath(如果已配置)或当前目录开始收集。如果命令行参数, 指定了 目录、文件名 或 node id 的任何组合,则按参数来找
  • 寻找过程会递归到目录中,除非它们匹配上 norecursedirs。
  • 在这些目录中,搜索由其测试包名称导入的 test_*.py 或 *_test.py 文件。
  • 从这些文件中,收集如下测试项:test为前缀 的 函数Test为前缀的 类 里面的 test为前缀的方法

-----------------------------------------------------------------------------------------

测试用例代码

首先,我们编写的测试用例代码文件, 必须以 test_ 开头,或者以 _test 结尾

比如,我们创建一个 文件名为 test_错误登录.py ,放在目录 autotestcases登录 下面。

其中 autotest 是 我们创建的 自动化项目根目录

class Test_错误密码:    def test_C001001(self):        print('用例C001001')        assert 1 == 1            def test_C001002(self):        print('用例C001002')        assert 2 == 2            def test_C001003(self):        print('用例C001003')        assert 3 == 2如果我们把测试用例存放在类中, 类名必须以 Test 为前缀的 类 ,用例对应的方法必须以 test 为前缀的方法。pytest 中用例的检查点 直接用 Python 的 assert 断言。assert 后面的表达式结果 为 True ,就是 检查点 通过,结果为False ,就是检查点 不通过。

运行测试

执行测试非常简单,打开命令行窗口,进入自动化项目根目录(我们这里就是 autotest),执行命令程序 pytest 即可




pentestbox下载 pentest框架下载_用例


显示找到3个测试项,2个执行通过,1个不通过。

通过的用例 是用一个绿色小点表示, 不通过的用例用一个红色的F表示

并且会在后面显示具体不通过的用例 和不通过的检查点 代码细节。

大家可以发现,用例代码中有些打印语句没有显示出内容。

因为pytest 会 截获print打印的内容。

如果我们希望 显示测试代码中print的内容,因为这些打印语句在调试代码时很有用,可以加上命令行参数 -s

如下

pytest -s

如果我们希望得到更详细的执行信息,包括每个测试类、测试函数的名字,可以加上参数 -v,这个参数可以和 -s 合并为 -sv

如下

pytest -sv

执行 pytest 时, 如果命令行没有指定目标目录 或者 文件, 它会自动搜索当前目录下所有符合条件的文件、类、函数。

所以上面,就找到了3个测试方法,对应3个用例。

我们目前 项目根目录 中 只有一个cases 目录用例存放测试用例, 将来还会有其他目录,比如:

lib目录存放库代码、cfg目录存放配置数据 等等。

为了防止 pytest 到其他目录中找测试用例项,执行测试时,我们可以在命令行加上目标目录 cases ,就是这样

pytest cases

--------------------------------------------------------------------------------------------------------------

产生报告

前面在安装pytest,我们也安装了 pytest-html 插件,这个插件就是用来产生测试报告的。

要产生报告,在命令行加上 参数 --html=report.html --self-contained-html ,如下

pytest cases --html=report.html --self-contained-html

这样就会产生名为 report.html 的测试报告文件,可以在浏览器中打开

但是这个工具有个bug,导致测试目录、文件、类名 中,如果有中文,显示为乱码

可以这样修复:

  • 打开该插件对应的代码文件,通常在解释器目录下:site-packagespytest_htmlplugin.py
  • 找到如下代码 class TestResult: def __init__(self, outcome, report, logfile, config): self.test_id = report.nodeid.encode("utf-8").decode("unicode_escape") 改为 class TestResult: def __init__(self, outcome, report, logfile, config): # 白月黑羽修改方法,解决乱码问题 # self.test_id = report.nodeid.encode("utf-8").decode("unicode_escape") self.test_id = report.nodeid

然后再次运行,就可以发现中文乱码问题已经解决了。