diff options
author | Leonard Richardson <leonardr@segfault.org> | 2021-12-17 12:54:14 -0500 |
---|---|---|
committer | Leonard Richardson <leonardr@segfault.org> | 2021-12-17 12:54:14 -0500 |
commit | 854fd52ad616d8e9c0860bba2eb4ddd93eb2dc79 (patch) | |
tree | 419c15e1c024ea09fc71efbc6d56014ae099fe52 /bs4/tests/test_lxml.py | |
parent | ad52722cc6b55ce414d395e9a0860cee57c0ab2d (diff) |
Fix a crash when pickling a BeautifulSoup object that has no
tree builder. [bug=1934003]
Diffstat (limited to 'bs4/tests/test_lxml.py')
-rw-r--r-- | bs4/tests/test_lxml.py | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/bs4/tests/test_lxml.py b/bs4/tests/test_lxml.py index 41319d1..396ca0e 100644 --- a/bs4/tests/test_lxml.py +++ b/bs4/tests/test_lxml.py @@ -1,5 +1,6 @@ """Tests to ensure that the lxml tree builder generates good trees.""" +import pickle import re import warnings @@ -185,3 +186,14 @@ class TestLXMLXMLTreeBuilder(SoupTest, XMLTreeBuilderSmokeTest): assert soup.find('prefix:tag2').name == 'tag2' assert soup.find('prefix:tag3').name == 'tag3' assert soup.subtag.find('prefix:tag3').name == 'tag3' + + def test_pickle_removes_builder(self): + # The lxml TreeBuilder is not picklable, so it won't be + # preserved in a pickle/unpickle operation. + + soup = self.soup("<a>some markup</a>") + assert isinstance(soup.builder, self.default_builder) + pickled = pickle.dumps(soup) + unpickled = pickle.loads(pickled) + assert "some markup" == unpickled.a.string + assert unpickled.builder is None |