Merge pull request #243 from Beirdo/master

Small change to Schema model to allow generated specs to be picklable
This commit is contained in:
A 2020-07-20 14:53:01 +01:00 committed by GitHub
commit 1583454b56
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 6 additions and 2 deletions

View file

@ -67,8 +67,12 @@ class Schema(object):
self._source = _source self._source = _source
# Overriding object.__dict__ is a VERY bad idea as it totally breaks any
# possibility of pickling this object. Pickling marshalls via object.__dict__
# via default __getstate__ and __setstate__ methods. This is now renamed to
# keep the functionality for the validators, but keep pickling operational.
@property @property
def __dict__(self): def __newdict__(self):
return self._source or self.to_dict() return self._source or self.to_dict()
def to_dict(self): def to_dict(self):

View file

@ -86,7 +86,7 @@ class SchemaUnmarshallersFactory(object):
} }
if self.context is not None: if self.context is not None:
kwargs[self.CONTEXT_VALIDATION[self.context]] = True kwargs[self.CONTEXT_VALIDATION[self.context]] = True
return OAS30Validator(schema.__dict__, **kwargs) return OAS30Validator(schema.__newdict__, **kwargs)
def _get_format_checker(self): def _get_format_checker(self):
fc = deepcopy(oas30_format_checker) fc = deepcopy(oas30_format_checker)