Exception traceback est masqué si pas relancé immédiatement

J'ai un morceau de code similaire à ceci:

import sys

def func1():
    func2()

def func2():
    raise Exception('test error')

def main():
    err = None

    try:
        func1()
    except:
        err = sys.exc_info()[1]
        pass

    # some extra processing, involving checking err details (if err is not None)

    # need to re-raise err so caller can do its own handling
    if err:
        raise err

if __name__ == '__main__':
    main()

Quand func2 soulève une exception, je reçois la suite de l'exī:

Traceback (most recent call last):
  File "err_test.py", line 25, in <module>
    main()
  File "err_test.py", line 22, in main
    raise err
Exception: test error

D'ici, je ne vois pas où l'exception est à venir à partir de. L'original de trace est perdue.

Comment puis-je préserver original assurer la traçabilité et de la relancer? Je veux voir quelque chose de similaire à ceci:

Traceback (most recent call last):
  File "err_test.py", line 26, in <module>
    main()
  File "err_test.py", line 13, in main
    func1()
  File "err_test.py", line 4, in func1
    func2()
  File "err_test.py", line 7, in func2
    raise Exception('test error')
Exception: test error
InformationsquelleAutor parxier | 2011-01-28