From 384a061e214012bbdd3cab8bad19b04b736ddd4b Mon Sep 17 00:00:00 2001 From: Christopher Wecht Date: Mon, 1 Apr 2019 18:17:39 +0200 Subject: [PATCH] Pickleable rosbag exceptions (#1210 revisited). (#1652) * test_rosbag/test_bag.py: test, if rosbag exception can be pickled * rosbag/bag.py: rosbag exceptions can now be unpickled * pep8 --- test/test_rosbag/test/test_bag.py | 14 ++++++++++++++ tools/rosbag/src/rosbag/bag.py | 8 ++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/test/test_rosbag/test/test_bag.py b/test/test_rosbag/test/test_bag.py index 12cf9af4fc..c3a384e6a5 100755 --- a/test/test_rosbag/test/test_bag.py +++ b/test/test_rosbag/test/test_bag.py @@ -432,6 +432,20 @@ def _print_bag_records(self, fn): print(bag._OP_CODES.get(op, op)) + # #1209 + def test_rosbag_exceptions_are_pickleable(self): + #bag_exception = rosbag.ROSBagException("msg string") + def test(bag_exception): + import pickle + pickle_str = pickle.dumps(bag_exception) + unpickled = pickle.loads(pickle_str) + self.assertTrue(bag_exception.value == unpickled.value) + test(bag.ROSBagException("msg string")) + test(bag.ROSBagFormatException("msg string 2")) + test(bag.ROSBagUnindexedException()) + test(bag.ROSBagEncryptNotSupportedException("msg string 3")) + test(bag.ROSBagEncryptException("msg string 4")) + if __name__ == '__main__': import rostest PKG='rosbag' diff --git a/tools/rosbag/src/rosbag/bag.py b/tools/rosbag/src/rosbag/bag.py index 989297dc60..9db5a39b32 100644 --- a/tools/rosbag/src/rosbag/bag.py +++ b/tools/rosbag/src/rosbag/bag.py @@ -75,8 +75,11 @@ class ROSBagException(Exception): """ Base class for exceptions in rosbag. """ - def __init__(self, value): + def __init__(self, value=None): self.value = value + #fix for #1209. needed in Python 2.7. + # For details: https://stackoverflow.com/questions/41808912/cannot-unpickle-exception-subclass + self.args = (value,) def __str__(self): return self.value @@ -92,7 +95,8 @@ class ROSBagUnindexedException(ROSBagException): """ Exception for unindexed bags. """ - def __init__(self): + def __init__(self, *args): + #*args needed for #1209 ROSBagException.__init__(self, 'Unindexed bag') class Compression: