[Twisted-Python] How to find out if exceptions are being raised in your errBack?
Steve Steiner (listsin)
listsin at integrateddevcorp.com
Wed Oct 14 05:43:41 MDT 2009
On Oct 14, 2009, at 2:07 AM, Glyph Lefkowitz wrote:
> On Tue, Oct 13, 2009 at 8:02 PM, Steve Steiner (listsin) <listsin at integrateddevcorp.com
> > wrote:
> I've been hunting down a problem that I've finally found the cause of
> and I'd like to know what's the Twisted way to catch this "error
> within the code handling the error" type of error.
>
> The right way to catch this is to write tests for your code and run
> them before deploying it to production :).
Yes, we're working on it but it's a large code base and we started
with exactly zero tests. While that leaves infinite room for
improvement, it's a little overwhelming. Oh well, at least we know
where to concentrate first ;-0.
> Trial will helpfully fail tests which cause exceptions to be logged,
> so you don't need to write any special extra test to make sure that
> nothing is blowing up; just test your error-handling case, and if it
> blows up you will see it.
We've just been using nose; is that something Trial handles specially
for Twisted?
> Basically, in one branch of the errBack, there was a typo. A simple
> typo that caused an unhandled NameError exception, but only once in a
> few thousand runs.
>
> If it's a NameError, you also could have used Pyflakes to catch it :).
That's in our list of 'things to put in the commit pre-hook' as well.
I'm not sure pyflakes would have caught this one, though because it's
a legitimate instance variable, it's just not set to something usable
before this particular error condition comes up.
> The exception got caught and "displayed" by Twisted, but it wasn't
> going anyplace anyone was looking (buried under zillions of lines of
> logging) and the app continues on as if nothing went wrong.
>
> The real lesson here is that you should be paying attention to
> logged tracebacks.
>
> There are many ways to do this. Many operations teams running
> Twisted servers will trawl the logs with regular expressions. Not
> my preferred way of doing it, but I'm not really an ops person :).
I'm not much on the ops end either but I guess I'm learning...
> If you want to handle logged exceptions specially, for example to
> put them in a separate file, or to e-mail them to somebody, consider
> writing a log observer that checks for the isError key and does
> something special there. You can find out more about writing log
> observers here: <http://twistedmatrix.com/projects/core/documentation/howto/logging.html
> >.
This is an area of Twisted I haven't explored at all since the code's
all using the standard Python logging.
That's the thing about Twisted; sometimes it's hard to know whether
the stuff that has been built into standard Python since Twisted
'rolled their own' is a superset, a subset, or a completely different
beast. Logging is a good case in point. Since we're using Python's
logging everywhere, I wasn't even sure whether there would be an
advantage to learning Twisted's similar system. Twisted's trial is
another example; we've just been using nose. Seems like there's
always some little extra that makes the Twisted stuff worth knowing.
> What is the best way to handle programming errors like this in
> deferreds so they don't slip by, unnoticed?
>
> I'm answering a question you didn't ask, about logged errors,
> because I think it's the one you meant to ask. The answer to the
> question you are actually asking here, i.e. "how do I handle errors
> in an errback", is quite simple: add another errback. This is sort
> of like asking how to handle exceptions in an 'except:' block in
> Python. For example, if you want to catch errors from this code:
>
> try:
> foo()
> except:
> oops()
>
> you could modify it to look like this:
>
> try:
> foo()
> except:
> try:
> oops()
> except:
> handleOopsOops()
>
> which is what adding another errback is like. But, as I said: I
> don't think this is what you want, since it will only let you handle
> un-handled errors in Deferreds (not unhandled errors in, for
> example, protocols) and you will have to attach your error-handling
> callbacks everywhere (not to mention trying to guess a sane return
> value for the error-handler-error-handler.
Right, I started thinking down that infinitely nested slippery slope
and figured there must be a better way. I think the logging question
you answered that I didn't ask was the one I meant ;-).
Thanks again for another enlightening answer.
S
-------------- next part --------------
An HTML attachment was scrubbed...
URL: </pipermail/twisted-python/attachments/20091014/e86d131c/attachment.html>
More information about the Twisted-Python
mailing list