python 单元测试

测试代码位置:

你可以将测试用例定义与被测试代码置于同一个模块中(例如“widget.py”),但是将测试代码放置在单独的模块中(如“widgettests.py”)会有一些优势:

  • 测试模块可以从命令行单独执行
  • 测试代码可以方便地从发布代码中分离
  • 少了在缺乏充足理由的情况下为适应被测试代码而更改测试代码的诱惑
  • 相对于被测试代码,测试代码不应该被频繁的修改
  • 被测试代码可以更方法的进行重构
  • 既然C语言代码的测试应该置于单独的模块,那何不保持这个一致性呢?
  • 如果测试策略改变,也无需修改被测试源代码

交互式运行测试:

我们编写测试的主要目的是运行它们并检查我们的软件是否工作正常。测试框架使用“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

你可能感兴趣的:(python)