2014-04-22 09:54:16 +04:00
|
|
|
from PIL import Image
|
|
|
|
|
2019-07-06 23:40:53 +03:00
|
|
|
from .helper import PillowTestCase
|
|
|
|
|
2014-04-22 09:54:16 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
class TestPickle(PillowTestCase):
|
2015-01-30 15:00:46 +03:00
|
|
|
def helper_pickle_file(self, pickle, protocol=0, mode=None):
|
2014-09-15 09:59:28 +04:00
|
|
|
# Arrange
|
2019-06-13 18:54:46 +03:00
|
|
|
im = Image.open("Tests/images/hopper.jpg")
|
|
|
|
filename = self.tempfile("temp.pkl")
|
2015-01-30 15:00:46 +03:00
|
|
|
if mode:
|
|
|
|
im = im.convert(mode)
|
2014-06-10 13:10:47 +04:00
|
|
|
|
|
|
|
# Act
|
2019-06-13 18:54:46 +03:00
|
|
|
with open(filename, "wb") as f:
|
2014-06-10 13:10:47 +04:00
|
|
|
pickle.dump(im, f, protocol)
|
2019-06-13 18:54:46 +03:00
|
|
|
with open(filename, "rb") as f:
|
2014-06-10 13:10:47 +04:00
|
|
|
loaded_im = pickle.load(f)
|
|
|
|
|
|
|
|
# Assert
|
|
|
|
self.assertEqual(im, loaded_im)
|
|
|
|
|
2019-06-13 18:54:46 +03:00
|
|
|
def helper_pickle_string(
|
|
|
|
self, pickle, protocol=0, test_file="Tests/images/hopper.jpg", mode=None
|
|
|
|
):
|
2015-12-10 01:23:58 +03:00
|
|
|
im = Image.open(test_file)
|
2015-01-30 15:00:46 +03:00
|
|
|
if mode:
|
|
|
|
im = im.convert(mode)
|
2014-06-10 13:10:47 +04:00
|
|
|
|
|
|
|
# Act
|
|
|
|
dumped_string = pickle.dumps(im, protocol)
|
|
|
|
loaded_im = pickle.loads(dumped_string)
|
|
|
|
|
|
|
|
# Assert
|
|
|
|
self.assertEqual(im, loaded_im)
|
|
|
|
|
|
|
|
def test_pickle_image(self):
|
|
|
|
# Arrange
|
|
|
|
import pickle
|
|
|
|
|
|
|
|
# Act / Assert
|
|
|
|
for protocol in range(0, pickle.HIGHEST_PROTOCOL + 1):
|
|
|
|
self.helper_pickle_string(pickle, protocol)
|
|
|
|
self.helper_pickle_file(pickle, protocol)
|
|
|
|
|
|
|
|
def test_cpickle_image(self):
|
|
|
|
# Arrange
|
|
|
|
try:
|
|
|
|
import cPickle
|
|
|
|
except ImportError:
|
|
|
|
return
|
|
|
|
|
|
|
|
# Act / Assert
|
|
|
|
for protocol in range(0, cPickle.HIGHEST_PROTOCOL + 1):
|
|
|
|
self.helper_pickle_string(cPickle, protocol)
|
|
|
|
self.helper_pickle_file(cPickle, protocol)
|
|
|
|
|
|
|
|
def test_pickle_p_mode(self):
|
|
|
|
# Arrange
|
|
|
|
import pickle
|
|
|
|
|
|
|
|
# Act / Assert
|
2015-04-24 11:24:52 +03:00
|
|
|
for test_file in [
|
2019-06-13 18:54:46 +03:00
|
|
|
"Tests/images/test-card.png",
|
|
|
|
"Tests/images/zero_bb.png",
|
|
|
|
"Tests/images/zero_bb_scale2.png",
|
|
|
|
"Tests/images/non_zero_bb.png",
|
|
|
|
"Tests/images/non_zero_bb_scale2.png",
|
|
|
|
"Tests/images/p_trns_single.png",
|
|
|
|
"Tests/images/pil123p.png",
|
|
|
|
"Tests/images/itxt_chunks.png",
|
2014-06-10 13:10:47 +04:00
|
|
|
]:
|
2015-09-29 08:36:07 +03:00
|
|
|
for protocol in range(0, pickle.HIGHEST_PROTOCOL + 1):
|
2019-06-13 18:54:46 +03:00
|
|
|
self.helper_pickle_string(
|
|
|
|
pickle, protocol=protocol, test_file=test_file
|
|
|
|
)
|
2014-06-10 13:10:47 +04:00
|
|
|
|
2019-05-11 07:01:23 +03:00
|
|
|
def test_pickle_pa_mode(self):
|
|
|
|
# Arrange
|
|
|
|
import pickle
|
|
|
|
|
|
|
|
# Act / Assert
|
|
|
|
for protocol in range(0, pickle.HIGHEST_PROTOCOL + 1):
|
|
|
|
self.helper_pickle_string(pickle, protocol, mode="PA")
|
|
|
|
self.helper_pickle_file(pickle, protocol, mode="PA")
|
|
|
|
|
2015-01-30 15:00:46 +03:00
|
|
|
def test_pickle_l_mode(self):
|
|
|
|
# Arrange
|
|
|
|
import pickle
|
|
|
|
|
|
|
|
# Act / Assert
|
|
|
|
for protocol in range(0, pickle.HIGHEST_PROTOCOL + 1):
|
|
|
|
self.helper_pickle_string(pickle, protocol, mode="L")
|
|
|
|
self.helper_pickle_file(pickle, protocol, mode="L")
|
|
|
|
|
2019-05-11 07:01:23 +03:00
|
|
|
def test_pickle_la_mode_with_palette(self):
|
|
|
|
# Arrange
|
|
|
|
import pickle
|
2019-06-13 18:54:46 +03:00
|
|
|
|
|
|
|
im = Image.open("Tests/images/hopper.jpg")
|
|
|
|
filename = self.tempfile("temp.pkl")
|
2019-05-11 07:01:23 +03:00
|
|
|
im = im.convert("PA")
|
|
|
|
|
|
|
|
# Act / Assert
|
|
|
|
for protocol in range(0, pickle.HIGHEST_PROTOCOL + 1):
|
|
|
|
im.mode = "LA"
|
2019-06-13 18:54:46 +03:00
|
|
|
with open(filename, "wb") as f:
|
2019-05-11 07:01:23 +03:00
|
|
|
pickle.dump(im, f, protocol)
|
2019-06-13 18:54:46 +03:00
|
|
|
with open(filename, "rb") as f:
|
2019-05-11 07:01:23 +03:00
|
|
|
loaded_im = pickle.load(f)
|
|
|
|
|
|
|
|
im.mode = "PA"
|
|
|
|
self.assertEqual(im, loaded_im)
|
|
|
|
|
2015-01-30 15:00:46 +03:00
|
|
|
def test_cpickle_l_mode(self):
|
|
|
|
# Arrange
|
|
|
|
try:
|
|
|
|
import cPickle
|
|
|
|
except ImportError:
|
|
|
|
return
|
|
|
|
|
|
|
|
# Act / Assert
|
|
|
|
for protocol in range(0, cPickle.HIGHEST_PROTOCOL + 1):
|
|
|
|
self.helper_pickle_string(cPickle, protocol, mode="L")
|
|
|
|
self.helper_pickle_file(cPickle, protocol, mode="L")
|