首页
学习
活动
专区
工具
TVP
发布

PyTest入门

Pytest是我首选的Python测试库。它使简单的测试非常容易编写,它拥有许多高级的功能 (和众多插件),有助于更高级的测试方案。

为了演示基本功能,我打算使用py.test演示在测试驱动风格下解决cryptopals challenges的第一集合的第一题。

注意︰

我要去做的第一个的挑战和也许涉及到第二个。如果你想自己测试,可以在阅读这篇文章的其余部分之前这样做。

安装和第一个测试

安装︰

注意

我使用 Python 3.5,并且所有的操作在virtualenv。如果你没有安装Python,或不知道如何使用 pip 和virtualenv ,看看Python部落影音学堂中<0基础1小时入门Python>的第一课。

第一个挑战要求我们把一个十六进制编码的字符串转化为Base64编码。我先编写测试,代表所面临的挑战。 py.test默认检查以test_*.py命名的文件名,在文件内部查找以test_打头的方法或函数,并执行它们。 所以我创建文件test_set1.py︰

我没弄错吧?

是的,我并没有写任何代码︰ 第一个挑战超级简单,Python可以使用bytes.fromhex将十六进制编码的字符串解析成bytestring,并且base64模块中有base64 encoding编码。

然而,这只是演示了Pytest的简单部分,测试的只是以test_打头的函数或方法,仅仅使用了简单的assert语句,而不是一系列断言方法(assertEqual, assertNotEqual, assertAlmostEqual)。

接下来是更真实的测试情况

来看一个更完整的示例,第二个挑战是要实现一个函数,异或两个固定长度的缓冲区。我会先写以下测试用例︰

运行测试:

如所料,出现错误——测试程序试图导入cryptopals模块,然而我并未创建这个模块。这个错误看起来不同于失败的测试,因为这发生在pytest调用”collection”阶段,pytest遍历你的文件,寻找测试模块(命名为test_whatever.py的文件)和测试方法(def test_whatever())。更多关于pytest如何发现测试用例(以及如何自定义测试),请参见

conventions for Python test discovery。

现在我主要来演示什么是失败的测试。在cryptopals.py中:

不出所料,失败了:

(我使用-q即—quiet,简化输出。)

我喜欢这种高亮显示测试失败行的方式,并且显示了断言语句运行的值。

一旦我写了正确的代码(在这里忽略继续挑战的精神吧),应该会看到以下输出:

尝试更高级的pytest:参数化测试函数

对于最后一个例子,来看一下pytest稍微复杂的应用。我想写更多的测试来检查我的fixed_xor函数作用于不同长度的bytestrings。这个挑战只是说此函数应该使用两个相同长度的缓冲区,,但并没有指定当两个缓冲区长度不同时会发生什么。所以,我决定这种情况下结果应该是长度最短的bytestring(主要是因为这使函数写起来简单些)。

为了正确的验证,我测试以下几种不同场景:bs1长度小于 bs2即len(bs2)

这是使用pytest高级功能的常见模式:使用装饰器注释或修改测试函数。这里装饰器让我可以指定要传递给测试函数的参数列表;然后测试函数会为每个参数集运行一次。注意在运行测试时,会发生什么:

test_chanllenge2_mismatching_lengths并不是作为一个单一的测试显示,我们看到五个测试——对应于每个示例。因为每组参数显示为单独的情况,如果我特意加入一个失败的例子,将只看到那个失败,并能明确知道是什么:

pytest还有许多细节— — 有不同的方式可以方便地管理setup/teardow场景,在不同的测试模块之间共享资源,多种选择用于组织和生成测试代码,进行分组和标记测试的方式,等等。它使编写测试代码轻松、 愉快。我希望你去看看 !

英文原文:https://jacobian.org/writing/getting-started-with-pytest/

译者:flqzdzxx

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180817A0A2NU00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券