##// END OF EJS Templates
don't protect AsyncResult.metadata while result is still pending...
MinRK -
Show More
@@ -83,7 +83,7 b' class AsyncResult(object):'
83 self._tracker = tracker
83 self._tracker = tracker
84 self._ready = False
84 self._ready = False
85 self._success = None
85 self._success = None
86 self._metadata = None
86 self._metadata = [ self._client.metadata.get(id) for id in self.msg_ids ]
87 if len(msg_ids) == 1:
87 if len(msg_ids) == 1:
88 self._single_result = not isinstance(targets, (list, tuple))
88 self._single_result = not isinstance(targets, (list, tuple))
89 else:
89 else:
@@ -126,6 +126,10 b' class AsyncResult(object):'
126 else:
126 else:
127 raise error.TimeoutError("Result not ready.")
127 raise error.TimeoutError("Result not ready.")
128
128
129 def _check_ready(self):
130 if not self.ready():
131 raise error.TimeoutError("Result not ready.")
132
129 def ready(self):
133 def ready(self):
130 """Return whether the call has completed."""
134 """Return whether the call has completed."""
131 if not self._ready:
135 if not self._ready:
@@ -157,9 +161,8 b' class AsyncResult(object):'
157 else:
161 else:
158 self._success = True
162 self._success = True
159 finally:
163 finally:
160 self._metadata = map(self._client.metadata.get, self.msg_ids)
161 self._wait_for_outputs(10)
162
164
165 self._wait_for_outputs(10)
163
166
164
167
165 def successful(self):
168 def successful(self):
@@ -192,14 +195,13 b' class AsyncResult(object):'
192
195
193 @property
196 @property
194 def result(self):
197 def result(self):
195 """result property wrapper for `get(timeout=0)`."""
198 """result property wrapper for `get(timeout=-1)`."""
196 return self.get()
199 return self.get()
197
200
198 # abbreviated alias:
201 # abbreviated alias:
199 r = result
202 r = result
200
203
201 @property
204 @property
202 @check_ready
203 def metadata(self):
205 def metadata(self):
204 """property for accessing execution metadata."""
206 """property for accessing execution metadata."""
205 if self._single_result:
207 if self._single_result:
@@ -238,15 +240,17 b' class AsyncResult(object):'
238 # dict-access
240 # dict-access
239 #-------------------------------------
241 #-------------------------------------
240
242
241 @check_ready
242 def __getitem__(self, key):
243 def __getitem__(self, key):
243 """getitem returns result value(s) if keyed by int/slice, or metadata if key is str.
244 """getitem returns result value(s) if keyed by int/slice, or metadata if key is str.
244 """
245 """
245 if isinstance(key, int):
246 if isinstance(key, int):
247 self._check_ready()
246 return error.collect_exceptions([self._result[key]], self._fname)[0]
248 return error.collect_exceptions([self._result[key]], self._fname)[0]
247 elif isinstance(key, slice):
249 elif isinstance(key, slice):
250 self._check_ready()
248 return error.collect_exceptions(self._result[key], self._fname)
251 return error.collect_exceptions(self._result[key], self._fname)
249 elif isinstance(key, basestring):
252 elif isinstance(key, basestring):
253 # metadata proxy *does not* require that results are done
250 values = [ md[key] for md in self._metadata ]
254 values = [ md[key] for md in self._metadata ]
251 if self._single_result:
255 if self._single_result:
252 return values[0]
256 return values[0]
General Comments 0
You need to be logged in to leave comments. Login now