现在的软件开发过程中,测试往往关系到一个项目的成败。所以,我们非常有必要学习如何测试自己所编写的代码。那么,python能够在这方面做些什么呢?
首先,我们编写一个自己的类文件。
例1. widget.py
- class Widget:
- def __init__(self,size=(40,40)):
- self._size=size
- def getSize(self):
- return self._size
- def resize(self,width,height):
- self._size=(width,height)
- def dispose(self):
- pass
采用手工方式进行单元测试:
- #-*-coding:UTF-8-*-
- #python的测试模块
- from widget import Widget
- class TestWidget:
- def testSize(self):
- expectedSize=(40,40)
- widget=Widget()
- if widget.getSize()==expectedSize:
- print "test [Widget]:getSize works perfected!"
- else:
- print "test [Widget]:getSize doesn't work!"
- #测试
- if __name__=='__main__':
- myTest=TestWidget()
- myTest.testSize()
手工编写的这种测试方法存在很多问题:
1.测试程序的写法没有一定的规范可以遵循,十个程序员可能写出完全不同的测试程序来
2.每个程序员如果都有自己不同的测试类的方法,光维护这些被测试的类都够麻烦了,更不用说维护测试类。
3.测试用的代码可能比程序本身还多,大大加大了程序员的工作量。
所以,基于以上几点,python推出了它自己的一个框架来帮助我们完成这些功能——PyUnit
使用python的PyUnit测试框架:
- #-*-coding:UTF-8-*-
- from widget import Widget
- import unittest
- class WidgetTestCase(unittest.TestCase):
- def setUp(self):
- self.widget=Widget()
- def tearDown(self):
- self.widget=None
- def testSize(self):
- self.assertEqual(self.widget.getSize(),(40,40))
- #构造测试集
- def suite():
- suite=unittest.TestSuite()
- suite.addTest(WidgetTestCase("testSize"))
- return suite
- #测试
- if __name__=="__main__":
- unittest.main(defaultTest='suite')
在采用这个单元测试框架后,使得所有python程序员都可以使用同样的单元测试方法,测试过程成为了一个有序的行为。这就是这个框架所带来的最大的好处。