您的位置:首页技术文章
文章详情页

Python基于Hypothesis测试库生成测试数据

【字号: 日期:2022-07-27 09:25:55浏览:21作者:猪猪

Hypothesis是Python的一个高级测试库。它允许编写测试用例时参数化,然后生成使测试失败的简单易懂的测试数据。可以用更少的工作在代码中发现更多的bug。

安装

pip install hypothesis

如何设计测试数据

通过介绍也许你还不了解它是干嘛的,没关系!我们举个例子。

首先,我有一个需要测试的函数:

def add(a, b):'''实现加法运算'''return a + b

测试代码是这样的:

import unittestclass AddTest(unittest.TestCase): def test_case1(self): c = add(1, 2) self.assertEqual(c, 3) def test_case2(self): c = add(0, 2) self.assertEqual(c, 2) def test_case3(self): c = add(-2, 2) self.assertEqual(c, 0)if __name__ == ’__main__’: unittest.main()

为了更全面的验证的 add() 函数,我必须设计足够多的 测试数据, 同样也需要很多条用例!

当然,为了测试足够多的数据,我们也可以将代码改称这样。

import unittestfrom random import randintclass AddTest(unittest.TestCase): def test_case(self): for i in range(10): a = randint(-32768, 32767) b = randint(-32768, 32767) print('a->', a) print('b->', b) c1 = a + b c2 = add(a, b) self.assertEqual(c1, c2)if __name__ == ’__main__’: unittest.main()

通过调用 randint() 函数生成随机数。循环10次(也可以是100次,1000次),用更少的代码做更多的测试,测试的数据越多,发现bug的可能性越大。

测试结果如下:

> python test_hypothesis_demo.py

a-> 11503b-> -784a-> -31548b-> 13057a-> 22033b-> 3618a-> -32249b-> 28025a-> -15429b-> 31055a-> 16095b-> 13445a-> -31536b-> 14606a-> 18655b-> -18039a-> 17923b-> -12079a-> -9256b-> -26440.------------------------Ran 1 test in 0.002s

OK

用 hypothesis生成测试数据

上面的测试数据很难随机到 边界值,除非我手动设计数据,而且用for循环也不是太好的设计。是时候让hypothesis登场了。

import unittestfrom hypothesis import given, settingsimport hypothesis.strategies as stclass AddTest(unittest.TestCase): @settings(max_examples=10) @given(a=st.integers(), b=st.integers()) def test_case(self, a, b): print('a->', a) print('b->', b) c1 = a + b c2 = add(a, b) self.assertEqual(c1, c2)if __name__ == ’__main__’: unittest.main()

通过@given() 装饰测试用例,调用strategies 模块下面的 integers() 方法生成随机的测试数。在@setting()装饰器中通过max_examples用来控制随机数的个数。

运行结果如下:

> python test_hypothesis_demo.py

a-> 0 b-> 0 a-> 5980 b-> -3607224505277606703a-> 324106882b-> 23975a-> 23272b-> 4917 a-> 107b-> -155 a-> -4500b-> -8303a-> 2683 b-> 4384 a-> 27b-> -81a-> -122472823694675410551869872440384533757 b-> -89a-> 19075b-> 4362 .-------------------------------------------------Ran 1 test in 0.032s

hypothesis 生成的数据会更具有 测试价值,对吧? hypothesis 还可以生成更多类型的测试数据。例如 email格式和text格式。

email-> 0@A.comtext->email-> ^H@R70-s0Xke.Sb-UBn08.VzT--dz000I0o00r00s--EJY.e.Ov.aRaMcO text-> -email-> 6a#@T.HKttext-> ↕email-> ’/YAw/jnIZ!0fS+A@E7UJ.expErttext-> +�email-> *xh*-#t5$0-L8O&r10XnXU-**+e%0xy-@k.O.e.lEasetext-> #�����/���+�)�▲�email-> 2U!N0+|*%~@T.q-NX-0-0gWl.x.Lvtext->email-> &i/o!F*@xuW--03.p00-t0Y-0Z0.MW.K-000-n-sB0rR-0L.Y.y2u.NXptL0bgG-0U.XN--FLw351Etext-> �0▲-���email-> oK*-@p.ZiPtext-> ☺email-> /@mOL.Y-Q.j.p.d-3Mzi.i.Utv-M.yachtstext-> (email-> 4ql$y2%N4h@c.veRSIcheruNGtext->

这些数据看上去就具有很高的测试价值。好吧!测试一定明白我在说什么。

问题来了,我们可以将 hypothesis 生成的数据应用到 Web或接口自动化测试中么?

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好吧啦网。

标签: Python 编程
相关文章: