self.partial = partial
self.expected = expected
+ def __reduce__(self):
+ return type(self), (self.partial, self.expected)
+
class LimitOverrunError(Exception):
"""Reached the buffer limit while looking for a separator.
super().__init__(message)
self.consumed = consumed
+ def __reduce__(self):
+ return type(self), (self.args[0], self.consumed)
+
@coroutine
def open_connection(host=None, port=None, *,
import gc
import os
import queue
+import pickle
import socket
import sys
import threading
stream._transport.__repr__.return_value = "<Transport>"
self.assertEqual("<StreamReader t=<Transport>>", repr(stream))
+ def test_IncompleteReadError_pickleable(self):
+ e = asyncio.IncompleteReadError(b'abc', 10)
+ for proto in range(pickle.HIGHEST_PROTOCOL + 1):
+ with self.subTest(pickle_protocol=proto):
+ e2 = pickle.loads(pickle.dumps(e, protocol=proto))
+ self.assertEqual(str(e), str(e2))
+ self.assertEqual(e.partial, e2.partial)
+ self.assertEqual(e.expected, e2.expected)
+
+ def test_LimitOverrunError_pickleable(self):
+ e = asyncio.LimitOverrunError('message', 10)
+ for proto in range(pickle.HIGHEST_PROTOCOL + 1):
+ with self.subTest(pickle_protocol=proto):
+ e2 = pickle.loads(pickle.dumps(e, protocol=proto))
+ self.assertEqual(str(e), str(e2))
+ self.assertEqual(e.consumed, e2.consumed)
+
if __name__ == '__main__':
unittest.main()