test_pickle.py 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import unittest
  2. from billiard.serialization import pickle
  3. class RegularException(Exception):
  4. pass
  5. class ArgOverrideException(Exception):
  6. def __init__(self, message, status_code=10):
  7. self.status_code = status_code
  8. Exception.__init__(self, message, status_code)
  9. class TestPickle(unittest.TestCase):
  10. def test_pickle_regular_exception(self):
  11. e = None
  12. try:
  13. raise RegularException("RegularException raised")
  14. except RegularException, e:
  15. pass
  16. pickled = pickle.dumps({"exception": e})
  17. unpickled = pickle.loads(pickled)
  18. exception = unpickled.get("exception")
  19. self.assertTrue(exception)
  20. self.assertTrue(isinstance(exception, RegularException))
  21. self.assertEquals(exception.args, ("RegularException raised", ))
  22. def test_pickle_arg_override_exception(self):
  23. e = None
  24. try:
  25. raise ArgOverrideException("ArgOverrideException raised",
  26. status_code=100)
  27. except ArgOverrideException, e:
  28. pass
  29. pickled = pickle.dumps({"exception": e})
  30. unpickled = pickle.loads(pickled)
  31. exception = unpickled.get("exception")
  32. self.assertTrue(exception)
  33. self.assertTrue(isinstance(exception, ArgOverrideException))
  34. self.assertEquals(exception.args, ("ArgOverrideException raised",
  35. 100))
  36. self.assertEquals(exception.status_code, 100)