5

我是 python 新手,正在尝试建立一个功能测试环境。测试环境应通过 DBus 接收信号并对其进行评估。DBus 信号使用 GLib MainLoop。我有以下封装循环的类:

class SignalLoop(threading.Thread):
    def __init__(self):
        threading.Thread.__init__(self)
        self.__l = gobject.MainLoop()        
    def run(self):
        self.__l.run()
    def quit(self):
        self.__l.quit() 

在进行 DBus 处理的模块中,我尝试了:

class __ModuleInitializer:
    def __init__(self):
        print('Module was initialized')
        gobject.threads_init()
        sl = SignalLoop()
        sl.start()

    def __del__(self):
        print('Module was deinitialized')
        sl.quit()

__module_init = __ModuleInitializer()

我还尝试了以下方法:

  • setUp/tearDownModule() 对我不起作用 - 至少在 python 2.5.2 中
  • __init__() 和 __del__() 方法并将所有测试用例放在一个类中。__del__() 永远不会被调用,并且此解决方案不会随大量测试用例扩展。

当我运行代码时,sl.qui() 永远不会被执行,我不知道为什么。从控制台运行时,我必须杀死我的 main,因为它永远不会返回。然而,这对 PyDev 测试运行器来说不是问题。

有什么钩子可以用来破坏测试环境吗?我希望能够同时运行一个测试和几个测试,因此不能将其“破解”到方法本身中。

你能帮我么?

4

3 回答 3

5

在设置和拆卸方法期间,我不会启动和停止主循环。相反,发出您的异步请求(或其他),然后通过迭代运行主循环迭代,直到您的结果到达。

例子:

make_asynchronous_request()
main_context = GLib.MainContext.default()
while main_context.pending():
    main_context.iteration(False)
assert(result_is_ok())
于 2012-12-06T16:03:05.827 回答
3

我使用 ptomato 的答案创建了一个对我有用的答案。差异可能是由于某些python版本。就我而言,有效的代码是:

make_asynchronous_request()
main_context = GLib.MainLoop.get_context()
while main_context.pending():
    main_context.iteration(False)
assert(result_is_ok())
于 2013-04-19T13:38:05.483 回答
0

我认为您应该将SignalLoop类​​定义为daemon线程。这将允许程序在完成后关闭,即使信号循环线程仍在运行。当程序关闭时,该__module_init对象将被垃圾回收并__del__调用其函数。

http://docs.python.org/2.6/library/threading.html#threading.Thread.daemon上的文档daemon

于 2012-12-05T19:09:20.613 回答