@@ -179,6 +179,7 @@ def __init__(self):
179179 # In debug mode, if the execution of a callback or a step of a task
180180 # exceed this duration in seconds, the slow callback/task is logged.
181181 self .slow_callback_duration = 0.1
182+ self ._current_handle = None
182183
183184 def __repr__ (self ):
184185 return ('<%s running=%s closed=%s debug=%s>'
@@ -723,7 +724,13 @@ def create_datagram_endpoint(self, protocol_factory,
723724 logger .debug ("Datagram endpoint remote_addr=%r created: "
724725 "(%r, %r)" ,
725726 remote_addr , transport , protocol )
726- yield from waiter
727+
728+ try :
729+ yield from waiter
730+ except :
731+ transport .close ()
732+ raise
733+
727734 return transport , protocol
728735
729736 @coroutine
@@ -815,7 +822,13 @@ def connect_read_pipe(self, protocol_factory, pipe):
815822 protocol = protocol_factory ()
816823 waiter = futures .Future (loop = self )
817824 transport = self ._make_read_pipe_transport (pipe , protocol , waiter )
818- yield from waiter
825+
826+ try :
827+ yield from waiter
828+ except :
829+ transport .close ()
830+ raise
831+
819832 if self ._debug :
820833 logger .debug ('Read pipe %r connected: (%r, %r)' ,
821834 pipe .fileno (), transport , protocol )
@@ -826,7 +839,13 @@ def connect_write_pipe(self, protocol_factory, pipe):
826839 protocol = protocol_factory ()
827840 waiter = futures .Future (loop = self )
828841 transport = self ._make_write_pipe_transport (pipe , protocol , waiter )
829- yield from waiter
842+
843+ try :
844+ yield from waiter
845+ except :
846+ transport .close ()
847+ raise
848+
830849 if self ._debug :
831850 logger .debug ('Write pipe %r connected: (%r, %r)' ,
832851 pipe .fileno (), transport , protocol )
@@ -937,6 +956,10 @@ def default_exception_handler(self, context):
937956 else :
938957 exc_info = False
939958
959+ if (self ._current_handle is not None
960+ and self ._current_handle ._source_traceback ):
961+ context ['handle_traceback' ] = self ._current_handle ._source_traceback
962+
940963 log_lines = [message ]
941964 for key in sorted (context ):
942965 if key in {'message' , 'exception' }:
@@ -946,6 +969,10 @@ def default_exception_handler(self, context):
946969 tb = '' .join (traceback .format_list (value ))
947970 value = 'Object created at (most recent call last):\n '
948971 value += tb .rstrip ()
972+ elif key == 'handle_traceback' :
973+ tb = '' .join (traceback .format_list (value ))
974+ value = 'Handle created at (most recent call last):\n '
975+ value += tb .rstrip ()
949976 else :
950977 value = repr (value )
951978 log_lines .append ('{}: {}' .format (key , value ))
@@ -1103,12 +1130,16 @@ def _run_once(self):
11031130 if handle ._cancelled :
11041131 continue
11051132 if self ._debug :
1106- t0 = self .time ()
1107- handle ._run ()
1108- dt = self .time () - t0
1109- if dt >= self .slow_callback_duration :
1110- logger .warning ('Executing %s took %.3f seconds' ,
1111- _format_handle (handle ), dt )
1133+ try :
1134+ self ._current_handle = handle
1135+ t0 = self .time ()
1136+ handle ._run ()
1137+ dt = self .time () - t0
1138+ if dt >= self .slow_callback_duration :
1139+ logger .warning ('Executing %s took %.3f seconds' ,
1140+ _format_handle (handle ), dt )
1141+ finally :
1142+ self ._current_handle = None
11121143 else :
11131144 handle ._run ()
11141145 handle = None # Needed to break cycles when an exception occurs.
0 commit comments