UnitTest 框架 - 信号处理

unittest 的 -c/--catch 命令行选项以及 catchbreak 参数可在测试运行期间更高效地处理 control-C。启用 catch break 行为后,control-C 将允许当前正在运行的测试完成,然后测试运行将结束并报告迄今为止的所有结果。第二个 control-c 将以通常的方式引发 KeyboardInterrupt。

如果调用 unittest 处理程序但未安装 signal.SIGINT 处理程序,则它将调用默认处理程序。这通常是替换已安装处理程序并委托给它的代码的预期行为。对于需要禁用 unittest control-c 处理的单个测试,可以使用 removeHandler() 装饰器。

以下实用函数在测试框架内启用 control-c 处理功能 −

unittest.installHandler()

安装 control-c 处理程序。收到 signal.SIGINT 时,所有已注册的结果都会调用 TestResult.stop()。

unittest.registerResult(result)

注册 TestResult 对象以进行 control-c 处理。注册结果会存储对它的弱引用,因此不会阻止结果被垃圾回收。

unittest.removeResult(result)

删除已注册的结果。一旦结果被移除,TestResult.stop() 将不再响应 control-c 而在该结果对象上调用。

unittest.removeHandler(function = None)

当不带参数调用时,此函数将移除已安装的 control-c 处理程序。此函数还可用作测试装饰器,在执行测试时临时移除处理程序。

GUI 测试运行器

安装 unittest 模块是为了以交互方式发现和运行测试。此实用程序(Python 脚本"inittestgui.py")使用 Tkinter 模块,该模块是 TK 图形工具包的 Python 端口。它提供了一个易于使用的 GUI 来发现和运行测试。

Python unittestgui.py

运行测试

单击"发现测试"按钮。出现一个小对话框,您可以在其中选择要从中运行测试的目录和模块。

发现测试

最后,单击开始按钮。将从所选路径和模块名称中发现测试,结果窗格将显示结果。

结果窗格

为了查看单个测试的详细信息,请选择并单击结果框中的测试 −

单个测试详细信息

如果您在 Python 安装中找不到此实用程序,可以从项目页面 http://pyunit.sourceforge.net/ 获取它。

类似地,基于 wxpython 工具包的实用程序也在那里可用。