我在Twisted中遇到一些問題,並運行一系列執行腳本並一個接一個地執行腳本並返回退出代碼的流程。扭曲的流程執行問題
爲了驗證這一點,我有創建五個測試腳本(test1.py,test2.py等),每個只需要在他們以下幾點:
#!/usr/bin/python
a = 1
b = 2
total = a + b
(在文件中,唯一的區別是數字a
和b
被設置爲(給腳本一些變化))。
然後我有以下腳本應該運行的五個測試腳本逐一然後打印他們的退出代碼:
from twisted.internet import glib2reactor
glib2reactor.install()
from dbus.mainloop.glib import DBusGMainLoop
DBusGMainLoop(set_as_default=True)
import os.path
from twisted.internet import defer, reactor
from twisted.internet.protocol import ProcessProtocol
from ubuntuone.platform.tools import SyncDaemonTool
scriptslocation = "/home/jono/Desktop"
class SubprocessReturnCodeProtocol(ProcessProtocol):
def connectionMade(self):
self.returnCodeDeferred = defer.Deferred()
def processEnded(self, reason):
self.returnCodeDeferred.callback(reason.value.exitCode)
def outReceived(self, data):
print data
def errReceived(self, data):
print data
class ScriptChecker():
def __init__(self):
print "init"
self.run_scripts()
@defer.inlineCallbacks
def run_scripts(self):
print "run scripts"
accoms = [ { "script" : os.path.join(scriptslocation, "test1.py") },
{ "script" : os.path.join(scriptslocation, "test2.py") },
{ "script" : os.path.join(scriptslocation, "test3.py") },
{ "script" : os.path.join(scriptslocation, "test4.py") },
{ "script" : os.path.join(scriptslocation, "test5.py") }]
for accom in accoms:
print "Running: " + str(accom["script"])
exitcode = yield self.run_a_subprocess([accom["script"]])
print "Exit code: " + str(exitcode)
def run_a_subprocess(self, command):
pprotocol = SubprocessReturnCodeProtocol()
reactor.spawnProcess(pprotocol, command[0], command, env=os.environ)
return pprotocol.returnCodeDeferred
if __name__ == '__main__':
s = ScriptChecker()
DBusGMainLoop(set_as_default=True)
reactor.run()
不幸的是我看到了一些非常奇怪的行爲。大多數情況下,腳本不會全部運行,並且會停留在其中一個腳本上,並且不會繼續,然後每隔一段時間它就會按預期運行所有腳本。
我是相當新的扭曲,不知道發生了什麼;有任何想法嗎?
該代碼似乎基本健全。我無法重現您所描述的問題:五個程序每次都能可靠運行(至少連續嘗試十次)。也許特定版本的gtk2或其他相關庫中的一個與錯誤行爲有牽連(也就是說,它可能是其中一個特定版本的錯誤,或者是這些錯誤中的多個特定版本之間的交互)。 – 2012-03-08 00:43:14
我也有難以重現的問題。 我盡了最大努力試圖獲得本地運行的東西,您可以在lp上看到:〜jml/+ junk/bacon。我已經運行了好幾次(在我的精確機器上),我看不到任何失敗。如果你能夠製作出最小的,可運行的並且共享你所看到的輸出結果,這可能會有所幫助。 – jml 2012-03-08 10:51:02