Raise better error if token is pickled (resolves #2833) (#3267)

This commit is contained in:
Ines Montani 2019-02-13 11:27:04 +01:00 committed by GitHub
parent 2f45bd94c0
commit 2d0c3c73f4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 21 additions and 1 deletions

View File

@ -303,7 +303,11 @@ class Errors(object):
E109 = ("Model for component '{name}' not initialized. Did you forget to load " E109 = ("Model for component '{name}' not initialized. Did you forget to load "
"a model, or forget to call begin_training()?") "a model, or forget to call begin_training()?")
E110 = ("Invalid displaCy render wrapper. Expected callable, got: {obj}") E110 = ("Invalid displaCy render wrapper. Expected callable, got: {obj}")
E111 = ("Pickling a token is not supported, because tokens are only views "
"of the parent Doc and can't exist on their own. A pickled token "
"would always have to include its Doc and Vocab, which has "
"practically no advantage over pickling the parent Doc directly. "
"So instead of pickling the token, pickle the Doc it belongs to.")
@add_codes @add_codes
class TempErrors(object): class TempErrors(object):

View File

@ -0,0 +1,13 @@
# coding: utf-8
from __future__ import unicode_literals
import pytest
from spacy.tokens import Doc
from spacy.compat import pickle
def test_issue2833(en_vocab):
"""Test that a custom error is raised if a token is pickled."""
doc = Doc(en_vocab, words=["Hello", "world"])
with pytest.raises(NotImplementedError):
pickle.dumps(doc[0])

View File

@ -115,6 +115,9 @@ cdef class Token:
else: else:
raise ValueError(Errors.E041.format(op=op)) raise ValueError(Errors.E041.format(op=op))
def __reduce__(self):
raise NotImplementedError(Errors.E111)
@property @property
def _(self): def _(self):
return Underscore(Underscore.token_extensions, self, return Underscore(Underscore.token_extensions, self,