[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r20502: {torctl} Fix an exception crash on stream closing and kill a WARN. (torctl/trunk/python/TorCtl)



Author: mikeperry
Date: 2009-09-08 15:31:53 -0400 (Tue, 08 Sep 2009)
New Revision: 20502

Modified:
   torctl/trunk/python/TorCtl/PathSupport.py
   torctl/trunk/python/TorCtl/SQLSupport.py
Log:

Fix an exception crash on stream closing and kill a WARN.



Modified: torctl/trunk/python/TorCtl/PathSupport.py
===================================================================
--- torctl/trunk/python/TorCtl/PathSupport.py	2009-09-08 19:29:04 UTC (rev 20501)
+++ torctl/trunk/python/TorCtl/PathSupport.py	2009-09-08 19:31:53 UTC (rev 20502)
@@ -1395,7 +1395,11 @@
     """ Close all open streams """
     for strm in self.streams.itervalues():
       if not strm.ignored:
-        self.c.close_stream(strm.strm_id, reason)
+        try:
+          self.c.close_stream(strm.strm_id, reason)
+        except TorCtl.ErrorReply, e:
+          # This can happen. Streams can timeout before this call.
+          plog("NOTICE", "Error closing stream "+str(strm.strm_id)+": "+str(e))
 
   def close_all_circuits(self):
     """ Close all open circuits """

Modified: torctl/trunk/python/TorCtl/SQLSupport.py
===================================================================
--- torctl/trunk/python/TorCtl/SQLSupport.py	2009-09-08 19:29:04 UTC (rev 20501)
+++ torctl/trunk/python/TorCtl/SQLSupport.py	2009-09-08 19:31:53 UTC (rev 20502)
@@ -931,7 +931,9 @@
       return
 
     strm = Stream.query.filter_by(strm_id = s.strm_id).first()
-    if self.track_parent and s.strm_id not in self.parent_handler.streams:
+    if self.track_parent and \
+      (s.strm_id not in self.parent_handler.streams or \
+           self.parent_handler.streams[s.strm_id].ignored):
       if strm:
         tc_session.delete(strm)
         tc_session.commit()