你可以将测试用例定义与被测试代码置于同一个模块中(例如“widget.py”),但是将测试代码放置在单独的模块中(如“widgettests.py”)会有一些优势:
交互式运行测试:
我们编写测试的主要目的是运行它们并检查我们的软件是否工作正常。测试框架使用“TestRunner”类来为运行测试提供环境。最常用的TestRunner是TextTestRunner
,它可以以文字方式运行测试并报告结果:
runner = unittest.TextTestRunner() runner.run(widgetTestSuite)
TextTestRunner
默认将输出发送到sys.stderr
,但是你可以通过向它的构造器传递一个不同的类似文件(file-object)对象来改变默认方式。
如需在Python解释器会话中运行测试,这样使用TextTestRunner
是一个理想的方法。
命令行运行测试:
unittest
模块包含一个main
方法,可以方便地将测试模块转变为可以运行测试的脚本。main
使用unittest.TestLoader
类来自动查找和加载模块内测试用例。
因此,如果你之前已经使用test*
惯例对测试方法进行命名,那么你就可以将以下代码插入测试模块的结尾:
if __name__ == "__main__": unittest.main()
这样,当你从命令行执行你的测试模块时,其所包含的所有测试都将被运行。使用“-h”选项运行模块可以查看所有可用的选项。
如需从命令行运行任意测试,你可以将unittest
模块作为脚本运行,并将所需执行的测试套件中的测试用例名称作为参数传递给此脚本:
% python unittest.py widgettests.WidgetTestSuite
or
% python unittest.py widgettests.makeWidgetTestSuite
你还可以在命令行指明特定的测试(方法)来执行。如要运行“listtests”模块中的TestCase
类的子类 'ListTestCase
'(参见发布软件包中的“examples”子目录),你可以执行以下命令:
% python unittest.py listtests.ListTestCase.testAppend
“testAppend”是测试用例实例将要执行的测试方法的名称。你可以执行以下代码来创建ListTestCase
类实例并执行其所包含的所有“test*”测试方法:
% python unittest.py listtests.ListTestCase
原文:http://blog.csdn.net/jiyucn/article/details/2106637