From 80412e7051b781bd2ac433a6d1b6cc679253e811 Mon Sep 17 00:00:00 2001 From: Arnav Garg Date: Thu, 15 Sep 2022 15:14:08 -0500 Subject: [PATCH] Added custom serializer for to enable picking of thread.lock --- ludwig/hyperopt/syncer.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/ludwig/hyperopt/syncer.py b/ludwig/hyperopt/syncer.py index 1340b810808..276a417363b 100644 --- a/ludwig/hyperopt/syncer.py +++ b/ludwig/hyperopt/syncer.py @@ -8,7 +8,7 @@ class RemoteSyncer(_BackgroundSyncer): - def __init__(self, backend: Backend, sync_period: float = 300.0): + def __init__(self, sync_period: float = 300.0, backend: Backend = None): super().__init__(sync_period=sync_period) self.backend = backend @@ -32,3 +32,9 @@ def _delete_command(self, uri: str) -> Tuple[Callable, Dict]: delete_at_uri, dict(uri=uri), ) + + # Custom deserialization needed since we can't pickle thread.lock objects + def __reduce__(self): + deserializer = RemoteSyncer + serialized_data = (self.sync_period, self.backend) + return deserializer, serialized_data