Merge from master
11
.coveragerc
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
# .coveragerc to control coverage.py
|
||||||
|
|
||||||
|
[report]
|
||||||
|
# Regexes for lines to exclude from consideration
|
||||||
|
exclude_lines =
|
||||||
|
# Have to re-enable the standard pragma:
|
||||||
|
pragma: no cover
|
||||||
|
|
||||||
|
# Don't complain if non-runnable code isn't run:
|
||||||
|
if 0:
|
||||||
|
if __name__ == .__main__.:
|
19
.travis.yml
|
@ -14,7 +14,8 @@ python:
|
||||||
install:
|
install:
|
||||||
- "sudo apt-get -qq install libfreetype6-dev liblcms2-dev python-qt4 ghostscript libffi-dev cmake"
|
- "sudo apt-get -qq install libfreetype6-dev liblcms2-dev python-qt4 ghostscript libffi-dev cmake"
|
||||||
- "pip install cffi"
|
- "pip install cffi"
|
||||||
- "pip install coveralls"
|
- "pip install coveralls nose"
|
||||||
|
- if [ "$TRAVIS_PYTHON_VERSION" == "2.6" ]; then pip install unittest2; fi
|
||||||
|
|
||||||
# webp
|
# webp
|
||||||
- pushd depends && ./install_webp.sh && popd
|
- pushd depends && ./install_webp.sh && popd
|
||||||
|
@ -28,18 +29,18 @@ script:
|
||||||
- python setup.py build_ext --inplace
|
- python setup.py build_ext --inplace
|
||||||
|
|
||||||
# Don't cover PyPy: it fails intermittently and is x5.8 slower (#640)
|
# Don't cover PyPy: it fails intermittently and is x5.8 slower (#640)
|
||||||
- if [ "$TRAVIS_PYTHON_VERSION" == "pypy" ]; then python selftest.py; fi
|
- if [ "$TRAVIS_PYTHON_VERSION" == "pypy" ]; then time python selftest.py; fi
|
||||||
- if [ "$TRAVIS_PYTHON_VERSION" == "pypy" ]; then python Tests/run.py; fi
|
- if [ "$TRAVIS_PYTHON_VERSION" == "pypy" ]; then time nosetests Tests/test_*.py; fi
|
||||||
|
|
||||||
# Cover the others
|
# Cover the others
|
||||||
- if [ "$TRAVIS_PYTHON_VERSION" != "pypy" ]; then coverage run --append --include=PIL/* selftest.py; fi
|
- if [ "$TRAVIS_PYTHON_VERSION" != "pypy" ]; then time coverage run --append --include=PIL/* selftest.py; fi
|
||||||
- if [ "$TRAVIS_PYTHON_VERSION" != "pypy" ]; then python Tests/run.py --coverage; fi
|
- if [ "$TRAVIS_PYTHON_VERSION" != "pypy" ]; then time coverage run --append --include=PIL/* -m nose Tests/test_*.py; fi
|
||||||
|
|
||||||
after_success:
|
after_success:
|
||||||
- coverage report
|
- coverage report
|
||||||
- coveralls
|
- coveralls
|
||||||
- pip install pep8 pyflakes
|
- pip install pep8 pyflakes
|
||||||
- pep8 PIL/*.py
|
- pep8 --statistics --count PIL/*.py
|
||||||
- pyflakes PIL/*.py
|
- pep8 --statistics --count Tests/*.py
|
||||||
- pep8 Tests/*.py
|
- pyflakes PIL/*.py | tee >(wc -l)
|
||||||
- pyflakes Tests/*.py
|
- pyflakes Tests/*.py | tee >(wc -l)
|
||||||
|
|
15
CHANGES.rst
|
@ -3,6 +3,19 @@ Changelog (Pillow)
|
||||||
|
|
||||||
2.5.0 (unreleased)
|
2.5.0 (unreleased)
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
|
- Use unittest for tests
|
||||||
|
[hugovk]
|
||||||
|
|
||||||
|
- ImageCms fixes
|
||||||
|
[hugovk]
|
||||||
|
|
||||||
|
- Added more ImageDraw tests
|
||||||
|
[hugovk]
|
||||||
|
|
||||||
|
- Added tests for Spider files
|
||||||
|
[hugovk]
|
||||||
|
|
||||||
- Use libtiff to write any compressed tiff files
|
- Use libtiff to write any compressed tiff files
|
||||||
[wiredfool]
|
[wiredfool]
|
||||||
|
|
||||||
|
@ -431,7 +444,7 @@ Changelog (Pillow)
|
||||||
- Add Python 3 support. (Pillow >= 2.0.0 supports Python 2.6, 2.7, 3.2, 3.3. Pillow < 2.0.0 supports Python 2.4, 2.5, 2.6, 2.7.)
|
- Add Python 3 support. (Pillow >= 2.0.0 supports Python 2.6, 2.7, 3.2, 3.3. Pillow < 2.0.0 supports Python 2.4, 2.5, 2.6, 2.7.)
|
||||||
[fluggo]
|
[fluggo]
|
||||||
|
|
||||||
- Add PyPy support (experimental, please see: https://github.com/python-imaging/Pillow/issues/67)
|
- Add PyPy support (experimental, please see: https://github.com/python-pillow/Pillow/issues/67)
|
||||||
|
|
||||||
- Add WebP support.
|
- Add WebP support.
|
||||||
[lqs]
|
[lqs]
|
||||||
|
|
|
@ -1529,7 +1529,7 @@ class Image:
|
||||||
clockwise around its centre.
|
clockwise around its centre.
|
||||||
|
|
||||||
:param angle: In degrees counter clockwise.
|
:param angle: In degrees counter clockwise.
|
||||||
:param filter: An optional resampling filter. This can be
|
:param resample: An optional resampling filter. This can be
|
||||||
one of :py:attr:`PIL.Image.NEAREST` (use nearest neighbour),
|
one of :py:attr:`PIL.Image.NEAREST` (use nearest neighbour),
|
||||||
:py:attr:`PIL.Image.BILINEAR` (linear interpolation in a 2x2
|
:py:attr:`PIL.Image.BILINEAR` (linear interpolation in a 2x2
|
||||||
environment), or :py:attr:`PIL.Image.BICUBIC`
|
environment), or :py:attr:`PIL.Image.BICUBIC`
|
||||||
|
@ -1551,7 +1551,6 @@ class Image:
|
||||||
-math.sin(angle), math.cos(angle), 0.0
|
-math.sin(angle), math.cos(angle), 0.0
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
def transform(x, y, matrix=matrix):
|
def transform(x, y, matrix=matrix):
|
||||||
(a, b, c, d, e, f) = matrix
|
(a, b, c, d, e, f) = matrix
|
||||||
return a*x + b*y + c, d*x + e*y + f
|
return a*x + b*y + c, d*x + e*y + f
|
||||||
|
|
317
PIL/ImageCms.py
|
@ -1,19 +1,19 @@
|
||||||
#
|
"""
|
||||||
# The Python Imaging Library.
|
The Python Imaging Library.
|
||||||
# $Id$
|
$Id$
|
||||||
#
|
|
||||||
# optional color managment support, based on Kevin Cazabon's PyCMS
|
Optional color managment support, based on Kevin Cazabon's PyCMS
|
||||||
# library.
|
library.
|
||||||
#
|
|
||||||
# History:
|
History:
|
||||||
# 2009-03-08 fl Added to PIL.
|
2009-03-08 fl Added to PIL.
|
||||||
#
|
|
||||||
# Copyright (C) 2002-2003 Kevin Cazabon
|
Copyright (C) 2002-2003 Kevin Cazabon
|
||||||
# Copyright (c) 2009 by Fredrik Lundh
|
Copyright (c) 2009 by Fredrik Lundh
|
||||||
#
|
|
||||||
# See the README file for information on usage and redistribution. See
|
See the README file for information on usage and redistribution. See
|
||||||
# below for the original description.
|
below for the original description.
|
||||||
#
|
"""
|
||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
|
@ -66,7 +66,8 @@ pyCMS
|
||||||
|
|
||||||
Added try/except statements arount type() checks of
|
Added try/except statements arount type() checks of
|
||||||
potential CObjects... Python won't let you use type()
|
potential CObjects... Python won't let you use type()
|
||||||
on them, and raises a TypeError (stupid, if you ask me!)
|
on them, and raises a TypeError (stupid, if you ask
|
||||||
|
me!)
|
||||||
|
|
||||||
Added buildProofTransformFromOpenProfiles() function.
|
Added buildProofTransformFromOpenProfiles() function.
|
||||||
Additional fixes in DLL, see DLL code for details.
|
Additional fixes in DLL, see DLL code for details.
|
||||||
|
@ -89,8 +90,8 @@ try:
|
||||||
except ImportError as ex:
|
except ImportError as ex:
|
||||||
# Allow error import for doc purposes, but error out when accessing
|
# Allow error import for doc purposes, but error out when accessing
|
||||||
# anything in core.
|
# anything in core.
|
||||||
from _util import deferred_error
|
from _util import import_err
|
||||||
_imagingcms = deferred_error(ex)
|
_imagingcms = import_err(ex)
|
||||||
from PIL._util import isStringType
|
from PIL._util import isStringType
|
||||||
|
|
||||||
core = _imagingcms
|
core = _imagingcms
|
||||||
|
@ -113,9 +114,11 @@ DIRECTION_PROOF = 2
|
||||||
FLAGS = {
|
FLAGS = {
|
||||||
"MATRIXINPUT": 1,
|
"MATRIXINPUT": 1,
|
||||||
"MATRIXOUTPUT": 2,
|
"MATRIXOUTPUT": 2,
|
||||||
"MATRIXONLY": (1|2),
|
"MATRIXONLY": (1 | 2),
|
||||||
"NOWHITEONWHITEFIXUP": 4, # Don't hot fix scum dot
|
"NOWHITEONWHITEFIXUP": 4, # Don't hot fix scum dot
|
||||||
"NOPRELINEARIZATION": 16, # Don't create prelinearization tables on precalculated transforms (internal use)
|
# Don't create prelinearization tables on precalculated transforms
|
||||||
|
# (internal use):
|
||||||
|
"NOPRELINEARIZATION": 16,
|
||||||
"GUESSDEVICECLASS": 32, # Guess device class (for transform2devicelink)
|
"GUESSDEVICECLASS": 32, # Guess device class (for transform2devicelink)
|
||||||
"NOTCACHE": 64, # Inhibit 1-pixel cache
|
"NOTCACHE": 64, # Inhibit 1-pixel cache
|
||||||
"NOTPRECALC": 256,
|
"NOTPRECALC": 256,
|
||||||
|
@ -136,6 +139,7 @@ for flag in FLAGS.values():
|
||||||
if isinstance(flag, int):
|
if isinstance(flag, int):
|
||||||
_MAX_FLAG = _MAX_FLAG | flag
|
_MAX_FLAG = _MAX_FLAG | flag
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------.
|
# --------------------------------------------------------------------.
|
||||||
# Experimental PIL-level API
|
# Experimental PIL-level API
|
||||||
# --------------------------------------------------------------------.
|
# --------------------------------------------------------------------.
|
||||||
|
@ -159,20 +163,22 @@ class ImageCmsProfile:
|
||||||
self.profile = profile
|
self.profile = profile
|
||||||
self.filename = filename
|
self.filename = filename
|
||||||
if profile:
|
if profile:
|
||||||
self.product_name = None #profile.product_name
|
self.product_name = None # profile.product_name
|
||||||
self.product_info = None #profile.product_info
|
self.product_info = None # profile.product_info
|
||||||
else:
|
else:
|
||||||
self.product_name = None
|
self.product_name = None
|
||||||
self.product_info = None
|
self.product_info = None
|
||||||
|
|
||||||
|
|
||||||
class ImageCmsTransform(Image.ImagePointHandler):
|
class ImageCmsTransform(Image.ImagePointHandler):
|
||||||
|
|
||||||
"""Transform. This can be used with the procedural API, or with the
|
"""Transform. This can be used with the procedural API, or with the
|
||||||
standard Image.point() method.
|
standard Image.point() method.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, input, output, input_mode, output_mode,
|
def __init__(self, input, output, input_mode, output_mode,
|
||||||
intent=INTENT_PERCEPTUAL,
|
intent=INTENT_PERCEPTUAL, proof=None,
|
||||||
proof=None, proof_intent=INTENT_ABSOLUTE_COLORIMETRIC, flags=0):
|
proof_intent=INTENT_ABSOLUTE_COLORIMETRIC, flags=0):
|
||||||
if proof is None:
|
if proof is None:
|
||||||
self.transform = core.buildTransform(
|
self.transform = core.buildTransform(
|
||||||
input.profile, output.profile,
|
input.profile, output.profile,
|
||||||
|
@ -198,16 +204,17 @@ class ImageCmsTransform(Image.ImagePointHandler):
|
||||||
im.load()
|
im.load()
|
||||||
if imOut is None:
|
if imOut is None:
|
||||||
imOut = Image.new(self.output_mode, im.size, None)
|
imOut = Image.new(self.output_mode, im.size, None)
|
||||||
result = self.transform.apply(im.im.id, imOut.im.id)
|
self.transform.apply(im.im.id, imOut.im.id)
|
||||||
return imOut
|
return imOut
|
||||||
|
|
||||||
def apply_in_place(self, im):
|
def apply_in_place(self, im):
|
||||||
im.load()
|
im.load()
|
||||||
if im.mode != self.output_mode:
|
if im.mode != self.output_mode:
|
||||||
raise ValueError("mode mismatch") # wrong output mode
|
raise ValueError("mode mismatch") # wrong output mode
|
||||||
result = self.transform.apply(im.im.id, im.im.id)
|
self.transform.apply(im.im.id, im.im.id)
|
||||||
return im
|
return im
|
||||||
|
|
||||||
|
|
||||||
def get_display_profile(handle=None):
|
def get_display_profile(handle=None):
|
||||||
""" (experimental) Fetches the profile for the current display device.
|
""" (experimental) Fetches the profile for the current display device.
|
||||||
:returns: None if the profile is not known.
|
:returns: None if the profile is not known.
|
||||||
|
@ -229,15 +236,21 @@ def get_display_profile(handle=None):
|
||||||
profile = get()
|
profile = get()
|
||||||
return ImageCmsProfile(profile)
|
return ImageCmsProfile(profile)
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------.
|
# --------------------------------------------------------------------.
|
||||||
# pyCMS compatible layer
|
# pyCMS compatible layer
|
||||||
# --------------------------------------------------------------------.
|
# --------------------------------------------------------------------.
|
||||||
|
|
||||||
class PyCMSError(Exception):
|
class PyCMSError(Exception):
|
||||||
""" (pyCMS) Exception class. This is used for all errors in the pyCMS API. """
|
|
||||||
|
""" (pyCMS) Exception class.
|
||||||
|
This is used for all errors in the pyCMS API. """
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def profileToProfile(im, inputProfile, outputProfile, renderingIntent=INTENT_PERCEPTUAL, outputMode=None, inPlace=0, flags=0):
|
|
||||||
|
def profileToProfile(
|
||||||
|
im, inputProfile, outputProfile, renderingIntent=INTENT_PERCEPTUAL,
|
||||||
|
outputMode=None, inPlace=0, flags=0):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Applies an ICC transformation to a given image, mapping from
|
(pyCMS) Applies an ICC transformation to a given image, mapping from
|
||||||
inputProfile to outputProfile.
|
inputProfile to outputProfile.
|
||||||
|
@ -259,40 +272,45 @@ def profileToProfile(im, inputProfile, outputProfile, renderingIntent=INTENT_PER
|
||||||
profiles, the input profile must handle RGB data, and the output
|
profiles, the input profile must handle RGB data, and the output
|
||||||
profile must handle CMYK data.
|
profile must handle CMYK data.
|
||||||
|
|
||||||
:param im: An open PIL image object (i.e. Image.new(...) or Image.open(...), etc.)
|
:param im: An open PIL image object (i.e. Image.new(...) or
|
||||||
:param inputProfile: String, as a valid filename path to the ICC input profile
|
Image.open(...), etc.)
|
||||||
you wish to use for this image, or a profile object
|
:param inputProfile: String, as a valid filename path to the ICC input
|
||||||
|
profile you wish to use for this image, or a profile object
|
||||||
:param outputProfile: String, as a valid filename path to the ICC output
|
:param outputProfile: String, as a valid filename path to the ICC output
|
||||||
profile you wish to use for this image, or a profile object
|
profile you wish to use for this image, or a profile object
|
||||||
:param renderingIntent: Integer (0-3) specifying the rendering intent you wish
|
:param renderingIntent: Integer (0-3) specifying the rendering intent you
|
||||||
to use for the transform
|
wish to use for the transform
|
||||||
|
|
||||||
INTENT_PERCEPTUAL = 0 (DEFAULT) (ImageCms.INTENT_PERCEPTUAL)
|
INTENT_PERCEPTUAL = 0 (DEFAULT) (ImageCms.INTENT_PERCEPTUAL)
|
||||||
INTENT_RELATIVE_COLORIMETRIC = 1 (ImageCms.INTENT_RELATIVE_COLORIMETRIC)
|
INTENT_RELATIVE_COLORIMETRIC = 1 (ImageCms.INTENT_RELATIVE_COLORIMETRIC)
|
||||||
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
||||||
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
||||||
|
|
||||||
see the pyCMS documentation for details on rendering intents and what they do.
|
see the pyCMS documentation for details on rendering intents and what
|
||||||
:param outputMode: A valid PIL mode for the output image (i.e. "RGB", "CMYK",
|
they do.
|
||||||
etc.). Note: if rendering the image "inPlace", outputMode MUST be the
|
:param outputMode: A valid PIL mode for the output image (i.e. "RGB",
|
||||||
same mode as the input, or omitted completely. If omitted, the outputMode
|
"CMYK", etc.). Note: if rendering the image "inPlace", outputMode
|
||||||
will be the same as the mode of the input image (im.mode)
|
MUST be the same mode as the input, or omitted completely. If
|
||||||
:param inPlace: Boolean (1 = True, None or 0 = False). If True, the original
|
omitted, the outputMode will be the same as the mode of the input
|
||||||
image is modified in-place, and None is returned. If False (default), a
|
image (im.mode)
|
||||||
new Image object is returned with the transform applied.
|
:param inPlace: Boolean (1 = True, None or 0 = False). If True, the
|
||||||
|
original image is modified in-place, and None is returned. If False
|
||||||
|
(default), a new Image object is returned with the transform applied.
|
||||||
:param flags: Integer (0-...) specifying additional flags
|
:param flags: Integer (0-...) specifying additional flags
|
||||||
:returns: Either None or a new PIL image object, depending on value of inPlace
|
:returns: Either None or a new PIL image object, depending on value of
|
||||||
|
inPlace
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if outputMode is None:
|
if outputMode is None:
|
||||||
outputMode = im.mode
|
outputMode = im.mode
|
||||||
|
|
||||||
if not isinstance(renderingIntent, int) or not (0 <= renderingIntent <=3):
|
if not isinstance(renderingIntent, int) or not (0 <= renderingIntent <= 3):
|
||||||
raise PyCMSError("renderingIntent must be an integer between 0 and 3")
|
raise PyCMSError("renderingIntent must be an integer between 0 and 3")
|
||||||
|
|
||||||
if not isinstance(flags, int) or not (0 <= flags <= _MAX_FLAG):
|
if not isinstance(flags, int) or not (0 <= flags <= _MAX_FLAG):
|
||||||
raise PyCMSError("flags must be an integer between 0 and %s" + _MAX_FLAG)
|
raise PyCMSError(
|
||||||
|
"flags must be an integer between 0 and %s" + _MAX_FLAG)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if not isinstance(inputProfile, ImageCmsProfile):
|
if not isinstance(inputProfile, ImageCmsProfile):
|
||||||
|
@ -300,7 +318,8 @@ def profileToProfile(im, inputProfile, outputProfile, renderingIntent=INTENT_PER
|
||||||
if not isinstance(outputProfile, ImageCmsProfile):
|
if not isinstance(outputProfile, ImageCmsProfile):
|
||||||
outputProfile = ImageCmsProfile(outputProfile)
|
outputProfile = ImageCmsProfile(outputProfile)
|
||||||
transform = ImageCmsTransform(
|
transform = ImageCmsTransform(
|
||||||
inputProfile, outputProfile, im.mode, outputMode, renderingIntent, flags=flags
|
inputProfile, outputProfile, im.mode, outputMode,
|
||||||
|
renderingIntent, flags=flags
|
||||||
)
|
)
|
||||||
if inPlace:
|
if inPlace:
|
||||||
transform.apply_in_place(im)
|
transform.apply_in_place(im)
|
||||||
|
@ -323,8 +342,8 @@ def getOpenProfile(profileFilename):
|
||||||
If profileFilename is not a vaild filename for an ICC profile, a PyCMSError
|
If profileFilename is not a vaild filename for an ICC profile, a PyCMSError
|
||||||
will be raised.
|
will be raised.
|
||||||
|
|
||||||
:param profileFilename: String, as a valid filename path to the ICC profile you
|
:param profileFilename: String, as a valid filename path to the ICC profile
|
||||||
wish to open, or a file-like object.
|
you wish to open, or a file-like object.
|
||||||
:returns: A CmsProfile class object.
|
:returns: A CmsProfile class object.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
@ -334,7 +353,10 @@ def getOpenProfile(profileFilename):
|
||||||
except (IOError, TypeError, ValueError) as v:
|
except (IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
def buildTransform(inputProfile, outputProfile, inMode, outMode, renderingIntent=INTENT_PERCEPTUAL, flags=0):
|
|
||||||
|
def buildTransform(
|
||||||
|
inputProfile, outputProfile, inMode, outMode,
|
||||||
|
renderingIntent=INTENT_PERCEPTUAL, flags=0):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Builds an ICC transform mapping from the inputProfile to the
|
(pyCMS) Builds an ICC transform mapping from the inputProfile to the
|
||||||
outputProfile. Use applyTransform to apply the transform to a given
|
outputProfile. Use applyTransform to apply the transform to a given
|
||||||
|
@ -367,14 +389,14 @@ def buildTransform(inputProfile, outputProfile, inMode, outMode, renderingIntent
|
||||||
manually overridden if you really want to, but I don't know of any
|
manually overridden if you really want to, but I don't know of any
|
||||||
time that would be of use, or would even work).
|
time that would be of use, or would even work).
|
||||||
|
|
||||||
:param inputProfile: String, as a valid filename path to the ICC input profile
|
:param inputProfile: String, as a valid filename path to the ICC input
|
||||||
you wish to use for this transform, or a profile object
|
profile you wish to use for this transform, or a profile object
|
||||||
:param outputProfile: String, as a valid filename path to the ICC output
|
:param outputProfile: String, as a valid filename path to the ICC output
|
||||||
profile you wish to use for this transform, or a profile object
|
profile you wish to use for this transform, or a profile object
|
||||||
:param inMode: String, as a valid PIL mode that the appropriate profile also
|
:param inMode: String, as a valid PIL mode that the appropriate profile
|
||||||
supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
also supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
||||||
:param outMode: String, as a valid PIL mode that the appropriate profile also
|
:param outMode: String, as a valid PIL mode that the appropriate profile
|
||||||
supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
also supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
||||||
:param renderingIntent: Integer (0-3) specifying the rendering intent you
|
:param renderingIntent: Integer (0-3) specifying the rendering intent you
|
||||||
wish to use for the transform
|
wish to use for the transform
|
||||||
|
|
||||||
|
@ -383,28 +405,37 @@ def buildTransform(inputProfile, outputProfile, inMode, outMode, renderingIntent
|
||||||
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
||||||
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
||||||
|
|
||||||
see the pyCMS documentation for details on rendering intents and what they do.
|
see the pyCMS documentation for details on rendering intents and what
|
||||||
|
they do.
|
||||||
:param flags: Integer (0-...) specifying additional flags
|
:param flags: Integer (0-...) specifying additional flags
|
||||||
:returns: A CmsTransform class object.
|
:returns: A CmsTransform class object.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if not isinstance(renderingIntent, int) or not (0 <= renderingIntent <=3):
|
if not isinstance(renderingIntent, int) or not (0 <= renderingIntent <= 3):
|
||||||
raise PyCMSError("renderingIntent must be an integer between 0 and 3")
|
raise PyCMSError("renderingIntent must be an integer between 0 and 3")
|
||||||
|
|
||||||
if not isinstance(flags, int) or not (0 <= flags <= _MAX_FLAG):
|
if not isinstance(flags, int) or not (0 <= flags <= _MAX_FLAG):
|
||||||
raise PyCMSError("flags must be an integer between 0 and %s" + _MAX_FLAG)
|
raise PyCMSError(
|
||||||
|
"flags must be an integer between 0 and %s" + _MAX_FLAG)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if not isinstance(inputProfile, ImageCmsProfile):
|
if not isinstance(inputProfile, ImageCmsProfile):
|
||||||
inputProfile = ImageCmsProfile(inputProfile)
|
inputProfile = ImageCmsProfile(inputProfile)
|
||||||
if not isinstance(outputProfile, ImageCmsProfile):
|
if not isinstance(outputProfile, ImageCmsProfile):
|
||||||
outputProfile = ImageCmsProfile(outputProfile)
|
outputProfile = ImageCmsProfile(outputProfile)
|
||||||
return ImageCmsTransform(inputProfile, outputProfile, inMode, outMode, renderingIntent, flags=flags)
|
return ImageCmsTransform(
|
||||||
|
inputProfile, outputProfile, inMode, outMode,
|
||||||
|
renderingIntent, flags=flags)
|
||||||
except (IOError, TypeError, ValueError) as v:
|
except (IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
def buildProofTransform(inputProfile, outputProfile, proofProfile, inMode, outMode, renderingIntent=INTENT_PERCEPTUAL, proofRenderingIntent=INTENT_ABSOLUTE_COLORIMETRIC, flags=FLAGS["SOFTPROOFING"]):
|
|
||||||
|
def buildProofTransform(
|
||||||
|
inputProfile, outputProfile, proofProfile, inMode, outMode,
|
||||||
|
renderingIntent=INTENT_PERCEPTUAL,
|
||||||
|
proofRenderingIntent=INTENT_ABSOLUTE_COLORIMETRIC,
|
||||||
|
flags=FLAGS["SOFTPROOFING"]):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Builds an ICC transform mapping from the inputProfile to the
|
(pyCMS) Builds an ICC transform mapping from the inputProfile to the
|
||||||
outputProfile, but tries to simulate the result that would be
|
outputProfile, but tries to simulate the result that would be
|
||||||
|
@ -443,17 +474,17 @@ def buildProofTransform(inputProfile, outputProfile, proofProfile, inMode, outMo
|
||||||
when the simulated device has a much wider gamut than the output
|
when the simulated device has a much wider gamut than the output
|
||||||
device, you may obtain marginal results.
|
device, you may obtain marginal results.
|
||||||
|
|
||||||
:param inputProfile: String, as a valid filename path to the ICC input profile
|
:param inputProfile: String, as a valid filename path to the ICC input
|
||||||
you wish to use for this transform, or a profile object
|
profile you wish to use for this transform, or a profile object
|
||||||
:param outputProfile: String, as a valid filename path to the ICC output
|
:param outputProfile: String, as a valid filename path to the ICC output
|
||||||
(monitor, usually) profile you wish to use for this transform, or a
|
(monitor, usually) profile you wish to use for this transform, or a
|
||||||
profile object
|
profile object
|
||||||
:param proofProfile: String, as a valid filename path to the ICC proof profile
|
:param proofProfile: String, as a valid filename path to the ICC proof
|
||||||
you wish to use for this transform, or a profile object
|
profile you wish to use for this transform, or a profile object
|
||||||
:param inMode: String, as a valid PIL mode that the appropriate profile also
|
:param inMode: String, as a valid PIL mode that the appropriate profile
|
||||||
supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
also supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
||||||
:param outMode: String, as a valid PIL mode that the appropriate profile also
|
:param outMode: String, as a valid PIL mode that the appropriate profile
|
||||||
supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
also supports (i.e. "RGB", "RGBA", "CMYK", etc.)
|
||||||
:param renderingIntent: Integer (0-3) specifying the rendering intent you
|
:param renderingIntent: Integer (0-3) specifying the rendering intent you
|
||||||
wish to use for the input->proof (simulated) transform
|
wish to use for the input->proof (simulated) transform
|
||||||
|
|
||||||
|
@ -462,7 +493,8 @@ def buildProofTransform(inputProfile, outputProfile, proofProfile, inMode, outMo
|
||||||
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
||||||
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
||||||
|
|
||||||
see the pyCMS documentation for details on rendering intents and what they do.
|
see the pyCMS documentation for details on rendering intents and what
|
||||||
|
they do.
|
||||||
:param proofRenderingIntent: Integer (0-3) specifying the rendering intent you
|
:param proofRenderingIntent: Integer (0-3) specifying the rendering intent you
|
||||||
wish to use for proof->output transform
|
wish to use for proof->output transform
|
||||||
|
|
||||||
|
@ -471,17 +503,19 @@ def buildProofTransform(inputProfile, outputProfile, proofProfile, inMode, outMo
|
||||||
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
||||||
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
||||||
|
|
||||||
see the pyCMS documentation for details on rendering intents and what they do.
|
see the pyCMS documentation for details on rendering intents and what
|
||||||
|
they do.
|
||||||
:param flags: Integer (0-...) specifying additional flags
|
:param flags: Integer (0-...) specifying additional flags
|
||||||
:returns: A CmsTransform class object.
|
:returns: A CmsTransform class object.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if not isinstance(renderingIntent, int) or not (0 <= renderingIntent <=3):
|
if not isinstance(renderingIntent, int) or not (0 <= renderingIntent <= 3):
|
||||||
raise PyCMSError("renderingIntent must be an integer between 0 and 3")
|
raise PyCMSError("renderingIntent must be an integer between 0 and 3")
|
||||||
|
|
||||||
if not isinstance(flags, int) or not (0 <= flags <= _MAX_FLAG):
|
if not isinstance(flags, int) or not (0 <= flags <= _MAX_FLAG):
|
||||||
raise PyCMSError("flags must be an integer between 0 and %s" + _MAX_FLAG)
|
raise PyCMSError(
|
||||||
|
"flags must be an integer between 0 and %s" + _MAX_FLAG)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if not isinstance(inputProfile, ImageCmsProfile):
|
if not isinstance(inputProfile, ImageCmsProfile):
|
||||||
|
@ -490,13 +524,16 @@ def buildProofTransform(inputProfile, outputProfile, proofProfile, inMode, outMo
|
||||||
outputProfile = ImageCmsProfile(outputProfile)
|
outputProfile = ImageCmsProfile(outputProfile)
|
||||||
if not isinstance(proofProfile, ImageCmsProfile):
|
if not isinstance(proofProfile, ImageCmsProfile):
|
||||||
proofProfile = ImageCmsProfile(proofProfile)
|
proofProfile = ImageCmsProfile(proofProfile)
|
||||||
return ImageCmsTransform(inputProfile, outputProfile, inMode, outMode, renderingIntent, proofProfile, proofRenderingIntent, flags)
|
return ImageCmsTransform(
|
||||||
|
inputProfile, outputProfile, inMode, outMode, renderingIntent,
|
||||||
|
proofProfile, proofRenderingIntent, flags)
|
||||||
except (IOError, TypeError, ValueError) as v:
|
except (IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
buildTransformFromOpenProfiles = buildTransform
|
buildTransformFromOpenProfiles = buildTransform
|
||||||
buildProofTransformFromOpenProfiles = buildProofTransform
|
buildProofTransformFromOpenProfiles = buildProofTransform
|
||||||
|
|
||||||
|
|
||||||
def applyTransform(im, transform, inPlace=0):
|
def applyTransform(im, transform, inPlace=0):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Applies a transform to a given image.
|
(pyCMS) Applies a transform to a given image.
|
||||||
|
@ -514,8 +551,8 @@ def applyTransform(im, transform, inPlace=0):
|
||||||
is raised.
|
is raised.
|
||||||
|
|
||||||
This function applies a pre-calculated transform (from
|
This function applies a pre-calculated transform (from
|
||||||
ImageCms.buildTransform() or ImageCms.buildTransformFromOpenProfiles()) to an
|
ImageCms.buildTransform() or ImageCms.buildTransformFromOpenProfiles())
|
||||||
image. The transform can be used for multiple images, saving
|
to an image. The transform can be used for multiple images, saving
|
||||||
considerable calcuation time if doing the same conversion multiple times.
|
considerable calcuation time if doing the same conversion multiple times.
|
||||||
|
|
||||||
If you want to modify im in-place instead of receiving a new image as
|
If you want to modify im in-place instead of receiving a new image as
|
||||||
|
@ -528,10 +565,12 @@ def applyTransform(im, transform, inPlace=0):
|
||||||
:param im: A PIL Image object, and im.mode must be the same as the inMode
|
:param im: A PIL Image object, and im.mode must be the same as the inMode
|
||||||
supported by the transform.
|
supported by the transform.
|
||||||
:param transform: A valid CmsTransform class object
|
:param transform: A valid CmsTransform class object
|
||||||
:param inPlace: Bool (1 == True, 0 or None == False). If True, im is modified
|
:param inPlace: Bool (1 == True, 0 or None == False). If True, im is
|
||||||
in place and None is returned, if False, a new Image object with the
|
modified in place and None is returned, if False, a new Image object
|
||||||
transform applied is returned (and im is not changed). The default is False.
|
with the transform applied is returned (and im is not changed). The
|
||||||
:returns: Either None, or a new PIL Image object, depending on the value of inPlace
|
default is False.
|
||||||
|
:returns: Either None, or a new PIL Image object, depending on the value of
|
||||||
|
inPlace
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -546,6 +585,7 @@ def applyTransform(im, transform, inPlace=0):
|
||||||
|
|
||||||
return imOut
|
return imOut
|
||||||
|
|
||||||
|
|
||||||
def createProfile(colorSpace, colorTemp=-1):
|
def createProfile(colorSpace, colorTemp=-1):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Creates a profile.
|
(pyCMS) Creates a profile.
|
||||||
|
@ -562,30 +602,36 @@ def createProfile(colorSpace, colorTemp=-1):
|
||||||
ImageCms.buildTransformFromOpenProfiles() to create a transform to apply
|
ImageCms.buildTransformFromOpenProfiles() to create a transform to apply
|
||||||
to images.
|
to images.
|
||||||
|
|
||||||
:param colorSpace: String, the color space of the profile you wish to create.
|
:param colorSpace: String, the color space of the profile you wish to
|
||||||
|
create.
|
||||||
Currently only "LAB", "XYZ", and "sRGB" are supported.
|
Currently only "LAB", "XYZ", and "sRGB" are supported.
|
||||||
:param colorTemp: Positive integer for the white point for the profile, in
|
:param colorTemp: Positive integer for the white point for the profile, in
|
||||||
degrees Kelvin (i.e. 5000, 6500, 9600, etc.). The default is for D50
|
degrees Kelvin (i.e. 5000, 6500, 9600, etc.). The default is for D50
|
||||||
illuminant if omitted (5000k). colorTemp is ONLY applied to LAB profiles,
|
illuminant if omitted (5000k). colorTemp is ONLY applied to LAB
|
||||||
and is ignored for XYZ and sRGB.
|
profiles, and is ignored for XYZ and sRGB.
|
||||||
:returns: A CmsProfile class object
|
:returns: A CmsProfile class object
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if colorSpace not in ["LAB", "XYZ", "sRGB"]:
|
if colorSpace not in ["LAB", "XYZ", "sRGB"]:
|
||||||
raise PyCMSError("Color space not supported for on-the-fly profile creation (%s)" % colorSpace)
|
raise PyCMSError(
|
||||||
|
"Color space not supported for on-the-fly profile creation (%s)"
|
||||||
|
% colorSpace)
|
||||||
|
|
||||||
if colorSpace == "LAB":
|
if colorSpace == "LAB":
|
||||||
try:
|
try:
|
||||||
colorTemp = float(colorTemp)
|
colorTemp = float(colorTemp)
|
||||||
except:
|
except:
|
||||||
raise PyCMSError("Color temperature must be numeric, \"%s\" not valid" % colorTemp)
|
raise PyCMSError(
|
||||||
|
"Color temperature must be numeric, \"%s\" not valid"
|
||||||
|
% colorTemp)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
return core.createProfile(colorSpace, colorTemp)
|
return core.createProfile(colorSpace, colorTemp)
|
||||||
except (TypeError, ValueError) as v:
|
except (TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def getProfileName(profile):
|
def getProfileName(profile):
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -600,10 +646,10 @@ def getProfileName(profile):
|
||||||
profile was originally created. Sometimes this tag also contains
|
profile was originally created. Sometimes this tag also contains
|
||||||
additional information supplied by the creator.
|
additional information supplied by the creator.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: A string containing the internal name of the profile as stored in an
|
:returns: A string containing the internal name of the profile as stored
|
||||||
ICC tag.
|
in an ICC tag.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -619,7 +665,7 @@ def getProfileName(profile):
|
||||||
manufacturer = profile.profile.product_manufacturer
|
manufacturer = profile.profile.product_manufacturer
|
||||||
|
|
||||||
if not (model or manufacturer):
|
if not (model or manufacturer):
|
||||||
return profile.profile.product_description+"\n"
|
return profile.profile.product_description + "\n"
|
||||||
if not manufacturer or len(model) > 30:
|
if not manufacturer or len(model) > 30:
|
||||||
return model + "\n"
|
return model + "\n"
|
||||||
return "%s - %s\n" % (model, manufacturer)
|
return "%s - %s\n" % (model, manufacturer)
|
||||||
|
@ -627,6 +673,7 @@ def getProfileName(profile):
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def getProfileInfo(profile):
|
def getProfileInfo(profile):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Gets the internal product information for the given profile.
|
(pyCMS) Gets the internal product information for the given profile.
|
||||||
|
@ -641,10 +688,10 @@ def getProfileInfo(profile):
|
||||||
info tag. This often contains details about the profile, and how it
|
info tag. This often contains details about the profile, and how it
|
||||||
was created, as supplied by the creator.
|
was created, as supplied by the creator.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: A string containing the internal profile information stored in an ICC
|
:returns: A string containing the internal profile information stored in
|
||||||
tag.
|
an ICC tag.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -652,7 +699,8 @@ def getProfileInfo(profile):
|
||||||
if not isinstance(profile, ImageCmsProfile):
|
if not isinstance(profile, ImageCmsProfile):
|
||||||
profile = ImageCmsProfile(profile)
|
profile = ImageCmsProfile(profile)
|
||||||
# add an extra newline to preserve pyCMS compatibility
|
# add an extra newline to preserve pyCMS compatibility
|
||||||
# Python, not C. the white point bits weren't working well, so skipping.
|
# Python, not C. the white point bits weren't working well,
|
||||||
|
# so skipping.
|
||||||
# // info was description \r\n\r\n copyright \r\n\r\n K007 tag \r\n\r\n whitepoint
|
# // info was description \r\n\r\n copyright \r\n\r\n K007 tag \r\n\r\n whitepoint
|
||||||
description = profile.profile.product_description
|
description = profile.profile.product_description
|
||||||
cpright = profile.profile.product_copyright
|
cpright = profile.profile.product_copyright
|
||||||
|
@ -660,7 +708,7 @@ def getProfileInfo(profile):
|
||||||
for elt in (description, cpright):
|
for elt in (description, cpright):
|
||||||
if elt:
|
if elt:
|
||||||
arr.append(elt)
|
arr.append(elt)
|
||||||
return "\r\n\r\n".join(arr)+"\r\n\r\n"
|
return "\r\n\r\n".join(arr) + "\r\n\r\n"
|
||||||
|
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
@ -679,10 +727,10 @@ def getProfileCopyright(profile):
|
||||||
Use this function to obtain the information stored in the profile's
|
Use this function to obtain the information stored in the profile's
|
||||||
copyright tag.
|
copyright tag.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: A string containing the internal profile information stored in an ICC
|
:returns: A string containing the internal profile information stored in
|
||||||
tag.
|
an ICC tag.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
|
@ -693,6 +741,7 @@ def getProfileCopyright(profile):
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def getProfileManufacturer(profile):
|
def getProfileManufacturer(profile):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Gets the manufacturer for the given profile.
|
(pyCMS) Gets the manufacturer for the given profile.
|
||||||
|
@ -700,16 +749,16 @@ def getProfileManufacturer(profile):
|
||||||
If profile isn't a valid CmsProfile object or filename to a profile,
|
If profile isn't a valid CmsProfile object or filename to a profile,
|
||||||
a PyCMSError is raised.
|
a PyCMSError is raised.
|
||||||
|
|
||||||
If an error occurs while trying to obtain the manufacturer tag, a PyCMSError
|
If an error occurs while trying to obtain the manufacturer tag, a
|
||||||
is raised
|
PyCMSError is raised
|
||||||
|
|
||||||
Use this function to obtain the information stored in the profile's
|
Use this function to obtain the information stored in the profile's
|
||||||
manufacturer tag.
|
manufacturer tag.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: A string containing the internal profile information stored in an ICC
|
:returns: A string containing the internal profile information stored in
|
||||||
tag.
|
an ICC tag.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
|
@ -720,6 +769,7 @@ def getProfileManufacturer(profile):
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def getProfileModel(profile):
|
def getProfileModel(profile):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Gets the model for the given profile.
|
(pyCMS) Gets the model for the given profile.
|
||||||
|
@ -733,10 +783,10 @@ def getProfileModel(profile):
|
||||||
Use this function to obtain the information stored in the profile's
|
Use this function to obtain the information stored in the profile's
|
||||||
model tag.
|
model tag.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: A string containing the internal profile information stored in an ICC
|
:returns: A string containing the internal profile information stored in
|
||||||
tag.
|
an ICC tag.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -748,6 +798,7 @@ def getProfileModel(profile):
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def getProfileDescription(profile):
|
def getProfileDescription(profile):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Gets the description for the given profile.
|
(pyCMS) Gets the description for the given profile.
|
||||||
|
@ -761,10 +812,10 @@ def getProfileDescription(profile):
|
||||||
Use this function to obtain the information stored in the profile's
|
Use this function to obtain the information stored in the profile's
|
||||||
description tag.
|
description tag.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: A string containing the internal profile information stored in an ICC
|
:returns: A string containing the internal profile information stored in an
|
||||||
tag.
|
ICC tag.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -793,16 +844,18 @@ def getDefaultIntent(profile):
|
||||||
If you wish to use a different intent than returned, use
|
If you wish to use a different intent than returned, use
|
||||||
ImageCms.isIntentSupported() to verify it will work first.
|
ImageCms.isIntentSupported() to verify it will work first.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:returns: Integer 0-3 specifying the default rendering intent for this profile.
|
:returns: Integer 0-3 specifying the default rendering intent for this
|
||||||
|
profile.
|
||||||
|
|
||||||
INTENT_PERCEPTUAL = 0 (DEFAULT) (ImageCms.INTENT_PERCEPTUAL)
|
INTENT_PERCEPTUAL = 0 (DEFAULT) (ImageCms.INTENT_PERCEPTUAL)
|
||||||
INTENT_RELATIVE_COLORIMETRIC = 1 (ImageCms.INTENT_RELATIVE_COLORIMETRIC)
|
INTENT_RELATIVE_COLORIMETRIC = 1 (ImageCms.INTENT_RELATIVE_COLORIMETRIC)
|
||||||
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
||||||
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
||||||
|
|
||||||
see the pyCMS documentation for details on rendering intents and what they do.
|
see the pyCMS documentation for details on rendering intents and what
|
||||||
|
they do.
|
||||||
:exception PyCMSError:
|
:exception PyCMSError:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@ -813,6 +866,7 @@ def getDefaultIntent(profile):
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def isIntentSupported(profile, intent, direction):
|
def isIntentSupported(profile, intent, direction):
|
||||||
"""
|
"""
|
||||||
(pyCMS) Checks if a given intent is supported.
|
(pyCMS) Checks if a given intent is supported.
|
||||||
|
@ -828,17 +882,18 @@ def isIntentSupported(profile, intent, direction):
|
||||||
potential PyCMSError that will occur if they don't support the modes
|
potential PyCMSError that will occur if they don't support the modes
|
||||||
you select.
|
you select.
|
||||||
|
|
||||||
:param profile: EITHER a valid CmsProfile object, OR a string of the filename
|
:param profile: EITHER a valid CmsProfile object, OR a string of the
|
||||||
of an ICC profile.
|
filename of an ICC profile.
|
||||||
:param intent: Integer (0-3) specifying the rendering intent you wish to use
|
:param intent: Integer (0-3) specifying the rendering intent you wish to
|
||||||
with this profile
|
use with this profile
|
||||||
|
|
||||||
INTENT_PERCEPTUAL = 0 (DEFAULT) (ImageCms.INTENT_PERCEPTUAL)
|
INTENT_PERCEPTUAL = 0 (DEFAULT) (ImageCms.INTENT_PERCEPTUAL)
|
||||||
INTENT_RELATIVE_COLORIMETRIC = 1 (ImageCms.INTENT_RELATIVE_COLORIMETRIC)
|
INTENT_RELATIVE_COLORIMETRIC = 1 (ImageCms.INTENT_RELATIVE_COLORIMETRIC)
|
||||||
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
INTENT_SATURATION = 2 (ImageCms.INTENT_SATURATION)
|
||||||
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
INTENT_ABSOLUTE_COLORIMETRIC = 3 (ImageCms.INTENT_ABSOLUTE_COLORIMETRIC)
|
||||||
|
|
||||||
see the pyCMS documentation for details on rendering intents and what they do.
|
see the pyCMS documentation for details on rendering intents and what
|
||||||
|
they do.
|
||||||
:param direction: Integer specifing if the profile is to be used for input,
|
:param direction: Integer specifing if the profile is to be used for input,
|
||||||
output, or proof
|
output, or proof
|
||||||
|
|
||||||
|
@ -862,6 +917,7 @@ def isIntentSupported(profile, intent, direction):
|
||||||
except (AttributeError, IOError, TypeError, ValueError) as v:
|
except (AttributeError, IOError, TypeError, ValueError) as v:
|
||||||
raise PyCMSError(v)
|
raise PyCMSError(v)
|
||||||
|
|
||||||
|
|
||||||
def versions():
|
def versions():
|
||||||
"""
|
"""
|
||||||
(pyCMS) Fetches versions.
|
(pyCMS) Fetches versions.
|
||||||
|
@ -869,7 +925,8 @@ def versions():
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
return (
|
return (
|
||||||
VERSION, core.littlecms_version, sys.version.split()[0], Image.VERSION
|
VERSION, core.littlecms_version,
|
||||||
|
sys.version.split()[0], Image.VERSION
|
||||||
)
|
)
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
# --------------------------------------------------------------------
|
||||||
|
@ -880,14 +937,16 @@ if __name__ == "__main__":
|
||||||
from PIL import ImageCms
|
from PIL import ImageCms
|
||||||
print(__doc__)
|
print(__doc__)
|
||||||
|
|
||||||
for f in dir(pyCMS):
|
for f in dir(ImageCms):
|
||||||
print("="*80)
|
doc = None
|
||||||
print("%s" %f)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
exec ("doc = ImageCms.%s.__doc__" %(f))
|
exec("doc = %s.__doc__" % (f))
|
||||||
if "pyCMS" in doc:
|
if "pyCMS" in doc:
|
||||||
# so we don't get the __doc__ string for imported modules
|
# so we don't get the __doc__ string for imported modules
|
||||||
|
print("=" * 80)
|
||||||
|
print("%s" % f)
|
||||||
print(doc)
|
print(doc)
|
||||||
except AttributeError:
|
except (AttributeError, TypeError):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -15,11 +15,12 @@
|
||||||
|
|
||||||
__version__ = "0.1"
|
__version__ = "0.1"
|
||||||
|
|
||||||
from PIL import Image, ImageFile, _binary
|
from PIL import Image, ImageFile
|
||||||
import struct
|
import struct
|
||||||
import os
|
import os
|
||||||
import io
|
import io
|
||||||
|
|
||||||
|
|
||||||
def _parse_codestream(fp):
|
def _parse_codestream(fp):
|
||||||
"""Parse the JPEG 2000 codestream to extract the size and component
|
"""Parse the JPEG 2000 codestream to extract the size and component
|
||||||
count from the SIZ marker segment, returning a PIL (size, mode) tuple."""
|
count from the SIZ marker segment, returning a PIL (size, mode) tuple."""
|
||||||
|
@ -51,6 +52,7 @@ def _parse_codestream(fp):
|
||||||
|
|
||||||
return (size, mode)
|
return (size, mode)
|
||||||
|
|
||||||
|
|
||||||
def _parse_jp2_header(fp):
|
def _parse_jp2_header(fp):
|
||||||
"""Parse the JP2 header box to extract size, component count and
|
"""Parse the JP2 header box to extract size, component count and
|
||||||
color space information, returning a PIL (size, mode) tuple."""
|
color space information, returning a PIL (size, mode) tuple."""
|
||||||
|
@ -127,6 +129,7 @@ def _parse_jp2_header(fp):
|
||||||
|
|
||||||
return (size, mode)
|
return (size, mode)
|
||||||
|
|
||||||
|
|
||||||
##
|
##
|
||||||
# Image plugin for JPEG2000 images.
|
# Image plugin for JPEG2000 images.
|
||||||
|
|
||||||
|
@ -180,10 +183,12 @@ class Jpeg2KImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
ImageFile.ImageFile.load(self)
|
ImageFile.ImageFile.load(self)
|
||||||
|
|
||||||
|
|
||||||
def _accept(prefix):
|
def _accept(prefix):
|
||||||
return (prefix[:4] == b'\xff\x4f\xff\x51'
|
return (prefix[:4] == b'\xff\x4f\xff\x51'
|
||||||
or prefix[:12] == b'\x00\x00\x00\x0cjP \x0d\x0a\x87\x0a')
|
or prefix[:12] == b'\x00\x00\x00\x0cjP \x0d\x0a\x87\x0a')
|
||||||
|
|
||||||
|
|
||||||
# ------------------------------------------------------------
|
# ------------------------------------------------------------
|
||||||
# Save support
|
# Save support
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ This is an improved version of the OleFileIO module from [PIL](http://www.python
|
||||||
|
|
||||||
As far as I know, this module is now the most complete and robust Python implementation to read MS OLE2 files, portable on several operating systems. (please tell me if you know other similar Python modules)
|
As far as I know, this module is now the most complete and robust Python implementation to read MS OLE2 files, portable on several operating systems. (please tell me if you know other similar Python modules)
|
||||||
|
|
||||||
OleFileIO_PL can be used as an independent module or with PIL. The goal is to have it integrated into [Pillow](http://python-imaging.github.io/), the friendly fork of PIL.
|
OleFileIO_PL can be used as an independent module or with PIL. The goal is to have it integrated into [Pillow](http://python-pillow.github.io/), the friendly fork of PIL.
|
||||||
|
|
||||||
OleFileIO\_PL is mostly meant for developers. If you are looking for tools to analyze OLE files or to extract data, then please also check [python-oletools](http://www.decalage.info/python/oletools), which are built upon OleFileIO_PL.
|
OleFileIO\_PL is mostly meant for developers. If you are looking for tools to analyze OLE files or to extract data, then please also check [python-oletools](http://www.decalage.info/python/oletools), which are built upon OleFileIO_PL.
|
||||||
|
|
||||||
|
|
|
@ -36,17 +36,23 @@
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
from PIL import Image, ImageFile
|
from PIL import Image, ImageFile
|
||||||
import os, struct, sys
|
import os
|
||||||
|
import struct
|
||||||
|
import sys
|
||||||
|
|
||||||
|
|
||||||
def isInt(f):
|
def isInt(f):
|
||||||
try:
|
try:
|
||||||
i = int(f)
|
i = int(f)
|
||||||
if f-i == 0: return 1
|
if f-i == 0:
|
||||||
else: return 0
|
return 1
|
||||||
|
else:
|
||||||
|
return 0
|
||||||
except:
|
except:
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
iforms = [1,3,-11,-12,-21,-22]
|
iforms = [1, 3, -11, -12, -21, -22]
|
||||||
|
|
||||||
|
|
||||||
# There is no magic number to identify Spider files, so just check a
|
# There is no magic number to identify Spider files, so just check a
|
||||||
# series of header locations to see if they have reasonable values.
|
# series of header locations to see if they have reasonable values.
|
||||||
|
@ -56,30 +62,32 @@ iforms = [1,3,-11,-12,-21,-22]
|
||||||
def isSpiderHeader(t):
|
def isSpiderHeader(t):
|
||||||
h = (99,) + t # add 1 value so can use spider header index start=1
|
h = (99,) + t # add 1 value so can use spider header index start=1
|
||||||
# header values 1,2,5,12,13,22,23 should be integers
|
# header values 1,2,5,12,13,22,23 should be integers
|
||||||
for i in [1,2,5,12,13,22,23]:
|
for i in [1, 2, 5, 12, 13, 22, 23]:
|
||||||
if not isInt(h[i]): return 0
|
if not isInt(h[i]):
|
||||||
|
return 0
|
||||||
# check iform
|
# check iform
|
||||||
iform = int(h[5])
|
iform = int(h[5])
|
||||||
if not iform in iforms: return 0
|
if iform not in iforms:
|
||||||
|
return 0
|
||||||
# check other header values
|
# check other header values
|
||||||
labrec = int(h[13]) # no. records in file header
|
labrec = int(h[13]) # no. records in file header
|
||||||
labbyt = int(h[22]) # total no. of bytes in header
|
labbyt = int(h[22]) # total no. of bytes in header
|
||||||
lenbyt = int(h[23]) # record length in bytes
|
lenbyt = int(h[23]) # record length in bytes
|
||||||
#print "labrec = %d, labbyt = %d, lenbyt = %d" % (labrec,labbyt,lenbyt)
|
# print "labrec = %d, labbyt = %d, lenbyt = %d" % (labrec,labbyt,lenbyt)
|
||||||
if labbyt != (labrec * lenbyt): return 0
|
if labbyt != (labrec * lenbyt):
|
||||||
|
return 0
|
||||||
# looks like a valid header
|
# looks like a valid header
|
||||||
return labbyt
|
return labbyt
|
||||||
|
|
||||||
|
|
||||||
def isSpiderImage(filename):
|
def isSpiderImage(filename):
|
||||||
fp = open(filename,'rb')
|
fp = open(filename, 'rb')
|
||||||
f = fp.read(92) # read 23 * 4 bytes
|
f = fp.read(92) # read 23 * 4 bytes
|
||||||
fp.close()
|
fp.close()
|
||||||
bigendian = 1
|
t = struct.unpack('>23f', f) # try big-endian first
|
||||||
t = struct.unpack('>23f',f) # try big-endian first
|
|
||||||
hdrlen = isSpiderHeader(t)
|
hdrlen = isSpiderHeader(t)
|
||||||
if hdrlen == 0:
|
if hdrlen == 0:
|
||||||
bigendian = 0
|
t = struct.unpack('<23f', f) # little-endian
|
||||||
t = struct.unpack('<23f',f) # little-endian
|
|
||||||
hdrlen = isSpiderHeader(t)
|
hdrlen = isSpiderHeader(t)
|
||||||
return hdrlen
|
return hdrlen
|
||||||
|
|
||||||
|
@ -96,11 +104,11 @@ class SpiderImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
self.bigendian = 1
|
self.bigendian = 1
|
||||||
t = struct.unpack('>27f',f) # try big-endian first
|
t = struct.unpack('>27f', f) # try big-endian first
|
||||||
hdrlen = isSpiderHeader(t)
|
hdrlen = isSpiderHeader(t)
|
||||||
if hdrlen == 0:
|
if hdrlen == 0:
|
||||||
self.bigendian = 0
|
self.bigendian = 0
|
||||||
t = struct.unpack('<27f',f) # little-endian
|
t = struct.unpack('<27f', f) # little-endian
|
||||||
hdrlen = isSpiderHeader(t)
|
hdrlen = isSpiderHeader(t)
|
||||||
if hdrlen == 0:
|
if hdrlen == 0:
|
||||||
raise SyntaxError("not a valid Spider file")
|
raise SyntaxError("not a valid Spider file")
|
||||||
|
@ -141,7 +149,8 @@ class SpiderImageFile(ImageFile.ImageFile):
|
||||||
self.rawmode = "F;32F"
|
self.rawmode = "F;32F"
|
||||||
self.mode = "F"
|
self.mode = "F"
|
||||||
|
|
||||||
self.tile = [("raw", (0, 0) + self.size, offset,
|
self.tile = [
|
||||||
|
("raw", (0, 0) + self.size, offset,
|
||||||
(self.rawmode, 0, 1))]
|
(self.rawmode, 0, 1))]
|
||||||
self.__fp = self.fp # FIXME: hack
|
self.__fp = self.fp # FIXME: hack
|
||||||
|
|
||||||
|
@ -176,6 +185,7 @@ class SpiderImageFile(ImageFile.ImageFile):
|
||||||
from PIL import ImageTk
|
from PIL import ImageTk
|
||||||
return ImageTk.PhotoImage(self.convert2byte(), palette=256)
|
return ImageTk.PhotoImage(self.convert2byte(), palette=256)
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
# --------------------------------------------------------------------
|
||||||
# Image series
|
# Image series
|
||||||
|
|
||||||
|
@ -200,17 +210,19 @@ def loadImageSeries(filelist=None):
|
||||||
imglist.append(im)
|
imglist.append(im)
|
||||||
return imglist
|
return imglist
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
# --------------------------------------------------------------------
|
||||||
# For saving images in Spider format
|
# For saving images in Spider format
|
||||||
|
|
||||||
def makeSpiderHeader(im):
|
def makeSpiderHeader(im):
|
||||||
nsam,nrow = im.size
|
nsam, nrow = im.size
|
||||||
lenbyt = nsam * 4 # There are labrec records in the header
|
lenbyt = nsam * 4 # There are labrec records in the header
|
||||||
labrec = 1024 / lenbyt
|
labrec = 1024 / lenbyt
|
||||||
if 1024%lenbyt != 0: labrec += 1
|
if 1024 % lenbyt != 0:
|
||||||
|
labrec += 1
|
||||||
labbyt = labrec * lenbyt
|
labbyt = labrec * lenbyt
|
||||||
hdr = []
|
hdr = []
|
||||||
nvalues = labbyt / 4
|
nvalues = int(labbyt / 4)
|
||||||
for i in range(nvalues):
|
for i in range(nvalues):
|
||||||
hdr.append(0.0)
|
hdr.append(0.0)
|
||||||
|
|
||||||
|
@ -232,9 +244,10 @@ def makeSpiderHeader(im):
|
||||||
# pack binary data into a string
|
# pack binary data into a string
|
||||||
hdrstr = []
|
hdrstr = []
|
||||||
for v in hdr:
|
for v in hdr:
|
||||||
hdrstr.append(struct.pack('f',v))
|
hdrstr.append(struct.pack('f', v))
|
||||||
return hdrstr
|
return hdrstr
|
||||||
|
|
||||||
|
|
||||||
def _save(im, fp, filename):
|
def _save(im, fp, filename):
|
||||||
if im.mode[0] != "F":
|
if im.mode[0] != "F":
|
||||||
im = im.convert('F')
|
im = im.convert('F')
|
||||||
|
@ -250,11 +263,12 @@ def _save(im, fp, filename):
|
||||||
raise IOError("Unable to open %s for writing" % filename)
|
raise IOError("Unable to open %s for writing" % filename)
|
||||||
fp.writelines(hdr)
|
fp.writelines(hdr)
|
||||||
|
|
||||||
rawmode = "F;32NF" #32-bit native floating point
|
rawmode = "F;32NF" # 32-bit native floating point
|
||||||
ImageFile._save(im, fp, [("raw", (0,0)+im.size, 0, (rawmode,0,1))])
|
ImageFile._save(im, fp, [("raw", (0, 0)+im.size, 0, (rawmode, 0, 1))])
|
||||||
|
|
||||||
fp.close()
|
fp.close()
|
||||||
|
|
||||||
|
|
||||||
def _save_spider(im, fp, filename):
|
def _save_spider(im, fp, filename):
|
||||||
# get the filename extension and register it with Image
|
# get the filename extension and register it with Image
|
||||||
fn, ext = os.path.splitext(filename)
|
fn, ext = os.path.splitext(filename)
|
||||||
|
@ -292,5 +306,7 @@ if __name__ == "__main__":
|
||||||
if outfile != "":
|
if outfile != "":
|
||||||
# perform some image operation
|
# perform some image operation
|
||||||
im = im.transpose(Image.FLIP_LEFT_RIGHT)
|
im = im.transpose(Image.FLIP_LEFT_RIGHT)
|
||||||
print("saving a flipped version of %s as %s " % (os.path.basename(filename), outfile))
|
print(
|
||||||
|
"saving a flipped version of %s as %s " %
|
||||||
|
(os.path.basename(filename), outfile))
|
||||||
im.save(outfile, "SPIDER")
|
im.save(outfile, "SPIDER")
|
||||||
|
|
|
@ -859,7 +859,7 @@ class TiffImageFile(ImageFile.ImageFile):
|
||||||
# libtiff handles the fillmode for us, so 1;IR should
|
# libtiff handles the fillmode for us, so 1;IR should
|
||||||
# actually be 1;I. Including the R double reverses the
|
# actually be 1;I. Including the R double reverses the
|
||||||
# bits, so stripes of the image are reversed. See
|
# bits, so stripes of the image are reversed. See
|
||||||
# https://github.com/python-imaging/Pillow/issues/279
|
# https://github.com/python-pillow/Pillow/issues/279
|
||||||
if fillorder == 2:
|
if fillorder == 2:
|
||||||
key = (
|
key = (
|
||||||
self.tag.prefix, photo, format, 1,
|
self.tag.prefix, photo, format, 1,
|
||||||
|
|
|
@ -5,8 +5,8 @@ Pillow
|
||||||
|
|
||||||
Pillow is the "friendly" PIL fork by Alex Clark and Contributors. PIL is the Python Imaging Library by Fredrik Lundh and Contributors.
|
Pillow is the "friendly" PIL fork by Alex Clark and Contributors. PIL is the Python Imaging Library by Fredrik Lundh and Contributors.
|
||||||
|
|
||||||
.. image:: https://travis-ci.org/python-imaging/Pillow.svg?branch=master
|
.. image:: https://travis-ci.org/python-pillow/Pillow.svg?branch=master
|
||||||
:target: https://travis-ci.org/python-imaging/Pillow
|
:target: https://travis-ci.org/python-pillow/Pillow
|
||||||
:alt: Travis CI build status
|
:alt: Travis CI build status
|
||||||
|
|
||||||
.. image:: https://pypip.in/v/Pillow/badge.png
|
.. image:: https://pypip.in/v/Pillow/badge.png
|
||||||
|
@ -17,7 +17,7 @@ Pillow is the "friendly" PIL fork by Alex Clark and Contributors. PIL is the Pyt
|
||||||
:target: https://pypi.python.org/pypi/Pillow/
|
:target: https://pypi.python.org/pypi/Pillow/
|
||||||
:alt: Number of PyPI downloads
|
:alt: Number of PyPI downloads
|
||||||
|
|
||||||
.. image:: https://coveralls.io/repos/python-imaging/Pillow/badge.png?branch=master
|
.. image:: https://coveralls.io/repos/python-pillow/Pillow/badge.png?branch=master
|
||||||
:target: https://coveralls.io/r/python-imaging/Pillow?branch=master
|
:target: https://coveralls.io/r/python-pillow/Pillow?branch=master
|
||||||
|
|
||||||
The documentation is hosted at http://pillow.readthedocs.org/. It contains installation instructions, tutorials, reference, compatibility details, and more.
|
The documentation is hosted at http://pillow.readthedocs.org/. It contains installation instructions, tutorials, reference, compatibility details, and more.
|
||||||
|
|
341
Tests/helper.py
Normal file
|
@ -0,0 +1,341 @@
|
||||||
|
"""
|
||||||
|
Helper functions.
|
||||||
|
"""
|
||||||
|
from __future__ import print_function
|
||||||
|
import sys
|
||||||
|
|
||||||
|
if sys.version_info[:2] <= (2, 6):
|
||||||
|
import unittest2 as unittest
|
||||||
|
else:
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
|
||||||
|
def tearDownModule():
|
||||||
|
import glob
|
||||||
|
import os
|
||||||
|
import tempfile
|
||||||
|
temp_root = os.path.join(tempfile.gettempdir(), 'pillow-tests')
|
||||||
|
tempfiles = glob.glob(os.path.join(temp_root, "temp_*"))
|
||||||
|
if tempfiles:
|
||||||
|
print("===", "remaining temporary files")
|
||||||
|
for file in tempfiles:
|
||||||
|
print(file)
|
||||||
|
print("-"*68)
|
||||||
|
|
||||||
|
|
||||||
|
class PillowTestCase(unittest.TestCase):
|
||||||
|
|
||||||
|
currentResult = None # holds last result object passed to run method
|
||||||
|
_tempfiles = []
|
||||||
|
|
||||||
|
def run(self, result=None):
|
||||||
|
self.addCleanup(self.delete_tempfiles)
|
||||||
|
self.currentResult = result # remember result for use later
|
||||||
|
unittest.TestCase.run(self, result) # call superclass run method
|
||||||
|
|
||||||
|
def delete_tempfiles(self):
|
||||||
|
try:
|
||||||
|
ok = self.currentResult.wasSuccessful()
|
||||||
|
except AttributeError: # for nosetests
|
||||||
|
proxy = self.currentResult
|
||||||
|
ok = (len(proxy.errors) + len(proxy.failures) == 0)
|
||||||
|
|
||||||
|
if ok:
|
||||||
|
# only clean out tempfiles if test passed
|
||||||
|
import os
|
||||||
|
import os.path
|
||||||
|
import tempfile
|
||||||
|
for file in self._tempfiles:
|
||||||
|
try:
|
||||||
|
os.remove(file)
|
||||||
|
except OSError:
|
||||||
|
pass # report?
|
||||||
|
temp_root = os.path.join(tempfile.gettempdir(), 'pillow-tests')
|
||||||
|
try:
|
||||||
|
os.rmdir(temp_root)
|
||||||
|
except OSError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def assert_almost_equal(self, a, b, msg=None, eps=1e-6):
|
||||||
|
self.assertLess(
|
||||||
|
abs(a-b), eps,
|
||||||
|
msg or "got %r, expected %r" % (a, b))
|
||||||
|
|
||||||
|
def assert_deep_equal(self, a, b, msg=None):
|
||||||
|
try:
|
||||||
|
self.assertEqual(
|
||||||
|
len(a), len(b),
|
||||||
|
msg or "got length %s, expected %s" % (len(a), len(b)))
|
||||||
|
self.assertTrue(
|
||||||
|
all([x == y for x, y in zip(a, b)]),
|
||||||
|
msg or "got %s, expected %s" % (a, b))
|
||||||
|
except:
|
||||||
|
self.assertEqual(a, b, msg)
|
||||||
|
|
||||||
|
def assert_image(self, im, mode, size, msg=None):
|
||||||
|
if mode is not None:
|
||||||
|
self.assertEqual(
|
||||||
|
im.mode, mode,
|
||||||
|
msg or "got mode %r, expected %r" % (im.mode, mode))
|
||||||
|
|
||||||
|
if size is not None:
|
||||||
|
self.assertEqual(
|
||||||
|
im.size, size,
|
||||||
|
msg or "got size %r, expected %r" % (im.size, size))
|
||||||
|
|
||||||
|
def assert_image_equal(self, a, b, msg=None):
|
||||||
|
self.assertEqual(
|
||||||
|
a.mode, b.mode,
|
||||||
|
msg or "got mode %r, expected %r" % (a.mode, b.mode))
|
||||||
|
self.assertEqual(
|
||||||
|
a.size, b.size,
|
||||||
|
msg or "got size %r, expected %r" % (a.size, b.size))
|
||||||
|
self.assertEqual(
|
||||||
|
a.tobytes(), b.tobytes(),
|
||||||
|
msg or "got different content")
|
||||||
|
|
||||||
|
def assert_image_similar(self, a, b, epsilon, msg=None):
|
||||||
|
epsilon = float(epsilon)
|
||||||
|
self.assertEqual(
|
||||||
|
a.mode, b.mode,
|
||||||
|
msg or "got mode %r, expected %r" % (a.mode, b.mode))
|
||||||
|
self.assertEqual(
|
||||||
|
a.size, b.size,
|
||||||
|
msg or "got size %r, expected %r" % (a.size, b.size))
|
||||||
|
|
||||||
|
diff = 0
|
||||||
|
try:
|
||||||
|
ord(b'0')
|
||||||
|
for abyte, bbyte in zip(a.tobytes(), b.tobytes()):
|
||||||
|
diff += abs(ord(abyte)-ord(bbyte))
|
||||||
|
except:
|
||||||
|
for abyte, bbyte in zip(a.tobytes(), b.tobytes()):
|
||||||
|
diff += abs(abyte-bbyte)
|
||||||
|
ave_diff = float(diff)/(a.size[0]*a.size[1])
|
||||||
|
self.assertGreaterEqual(
|
||||||
|
epsilon, ave_diff,
|
||||||
|
msg or "average pixel value difference %.4f > epsilon %.4f" % (
|
||||||
|
ave_diff, epsilon))
|
||||||
|
|
||||||
|
def assert_warning(self, warn_class, func):
|
||||||
|
import warnings
|
||||||
|
|
||||||
|
result = None
|
||||||
|
with warnings.catch_warnings(record=True) as w:
|
||||||
|
# Cause all warnings to always be triggered.
|
||||||
|
warnings.simplefilter("always")
|
||||||
|
|
||||||
|
# Hopefully trigger a warning.
|
||||||
|
result = func()
|
||||||
|
|
||||||
|
# Verify some things.
|
||||||
|
self.assertGreaterEqual(len(w), 1)
|
||||||
|
found = False
|
||||||
|
for v in w:
|
||||||
|
if issubclass(v.category, warn_class):
|
||||||
|
found = True
|
||||||
|
break
|
||||||
|
self.assertTrue(found)
|
||||||
|
return result
|
||||||
|
|
||||||
|
def tempfile(self, template, *extra):
|
||||||
|
import os
|
||||||
|
import os.path
|
||||||
|
import sys
|
||||||
|
import tempfile
|
||||||
|
files = []
|
||||||
|
root = os.path.join(tempfile.gettempdir(), 'pillow-tests')
|
||||||
|
try:
|
||||||
|
os.mkdir(root)
|
||||||
|
except OSError:
|
||||||
|
pass
|
||||||
|
for temp in (template,) + extra:
|
||||||
|
assert temp[:5] in ("temp.", "temp_")
|
||||||
|
name = os.path.basename(sys.argv[0])
|
||||||
|
name = temp[:4] + os.path.splitext(name)[0][4:]
|
||||||
|
name = name + "_%d" % len(self._tempfiles) + temp[4:]
|
||||||
|
name = os.path.join(root, name)
|
||||||
|
files.append(name)
|
||||||
|
self._tempfiles.extend(files)
|
||||||
|
return files[0]
|
||||||
|
|
||||||
|
|
||||||
|
# # require that deprecation warnings are triggered
|
||||||
|
# import warnings
|
||||||
|
# warnings.simplefilter('default')
|
||||||
|
# # temporarily turn off resource warnings that warn about unclosed
|
||||||
|
# # files in the test scripts.
|
||||||
|
# try:
|
||||||
|
# warnings.filterwarnings("ignore", category=ResourceWarning)
|
||||||
|
# except NameError:
|
||||||
|
# # we expect a NameError on py2.x, since it doesn't have ResourceWarnings.
|
||||||
|
# pass
|
||||||
|
|
||||||
|
import sys
|
||||||
|
py3 = (sys.version_info >= (3, 0))
|
||||||
|
|
||||||
|
# # some test helpers
|
||||||
|
#
|
||||||
|
# _target = None
|
||||||
|
# _tempfiles = []
|
||||||
|
# _logfile = None
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# def success():
|
||||||
|
# import sys
|
||||||
|
# success.count += 1
|
||||||
|
# if _logfile:
|
||||||
|
# print(sys.argv[0], success.count, failure.count, file=_logfile)
|
||||||
|
# return True
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# def failure(msg=None, frame=None):
|
||||||
|
# import sys
|
||||||
|
# import linecache
|
||||||
|
# failure.count += 1
|
||||||
|
# if _target:
|
||||||
|
# if frame is None:
|
||||||
|
# frame = sys._getframe()
|
||||||
|
# while frame.f_globals.get("__name__") != _target.__name__:
|
||||||
|
# frame = frame.f_back
|
||||||
|
# location = (frame.f_code.co_filename, frame.f_lineno)
|
||||||
|
# prefix = "%s:%d: " % location
|
||||||
|
# line = linecache.getline(*location)
|
||||||
|
# print(prefix + line.strip() + " failed:")
|
||||||
|
# if msg:
|
||||||
|
# print("- " + msg)
|
||||||
|
# if _logfile:
|
||||||
|
# print(sys.argv[0], success.count, failure.count, file=_logfile)
|
||||||
|
# return False
|
||||||
|
#
|
||||||
|
# success.count = failure.count = 0
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
# helpers
|
||||||
|
|
||||||
|
def fromstring(data):
|
||||||
|
from io import BytesIO
|
||||||
|
from PIL import Image
|
||||||
|
return Image.open(BytesIO(data))
|
||||||
|
|
||||||
|
|
||||||
|
def tostring(im, format, **options):
|
||||||
|
from io import BytesIO
|
||||||
|
out = BytesIO()
|
||||||
|
im.save(out, format, **options)
|
||||||
|
return out.getvalue()
|
||||||
|
|
||||||
|
|
||||||
|
def lena(mode="RGB", cache={}):
|
||||||
|
from PIL import Image
|
||||||
|
im = None
|
||||||
|
# im = cache.get(mode)
|
||||||
|
if im is None:
|
||||||
|
if mode == "RGB":
|
||||||
|
im = Image.open("Images/lena.ppm")
|
||||||
|
elif mode == "F":
|
||||||
|
im = lena("L").convert(mode)
|
||||||
|
elif mode[:4] == "I;16":
|
||||||
|
im = lena("I").convert(mode)
|
||||||
|
else:
|
||||||
|
im = lena("RGB").convert(mode)
|
||||||
|
# cache[mode] = im
|
||||||
|
return im
|
||||||
|
|
||||||
|
|
||||||
|
# def assert_image_completely_equal(a, b, msg=None):
|
||||||
|
# if a != b:
|
||||||
|
# failure(msg or "images different")
|
||||||
|
# else:
|
||||||
|
# success()
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# # test runner
|
||||||
|
#
|
||||||
|
# def run():
|
||||||
|
# global _target, _tests, run
|
||||||
|
# import sys
|
||||||
|
# import traceback
|
||||||
|
# _target = sys.modules["__main__"]
|
||||||
|
# run = None # no need to run twice
|
||||||
|
# tests = []
|
||||||
|
# for name, value in list(vars(_target).items()):
|
||||||
|
# if name[:5] == "test_" and type(value) is type(success):
|
||||||
|
# tests.append((value.__code__.co_firstlineno, name, value))
|
||||||
|
# tests.sort() # sort by line
|
||||||
|
# for lineno, name, func in tests:
|
||||||
|
# try:
|
||||||
|
# _tests = []
|
||||||
|
# func()
|
||||||
|
# for func, args in _tests:
|
||||||
|
# func(*args)
|
||||||
|
# except:
|
||||||
|
# t, v, tb = sys.exc_info()
|
||||||
|
# tb = tb.tb_next
|
||||||
|
# if tb:
|
||||||
|
# failure(frame=tb.tb_frame)
|
||||||
|
# traceback.print_exception(t, v, tb)
|
||||||
|
# else:
|
||||||
|
# print("%s:%d: cannot call test function: %s" % (
|
||||||
|
# sys.argv[0], lineno, v))
|
||||||
|
# failure.count += 1
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# def yield_test(function, *args):
|
||||||
|
# # collect delayed/generated tests
|
||||||
|
# _tests.append((function, args))
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# def skip(msg=None):
|
||||||
|
# import os
|
||||||
|
# print("skip")
|
||||||
|
# os._exit(0) # don't run exit handlers
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# def ignore(pattern):
|
||||||
|
# """Tells the driver to ignore messages matching the pattern, for the
|
||||||
|
# duration of the current test."""
|
||||||
|
# print('ignore: %s' % pattern)
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# def _setup():
|
||||||
|
# global _logfile
|
||||||
|
#
|
||||||
|
# import sys
|
||||||
|
# if "--coverage" in sys.argv:
|
||||||
|
# # Temporary: ignore PendingDeprecationWarning from Coverage (Py3.4)
|
||||||
|
# with warnings.catch_warnings():
|
||||||
|
# warnings.simplefilter("ignore")
|
||||||
|
# import coverage
|
||||||
|
# cov = coverage.coverage(auto_data=True, include="PIL/*")
|
||||||
|
# cov.start()
|
||||||
|
#
|
||||||
|
# def report():
|
||||||
|
# if run:
|
||||||
|
# run()
|
||||||
|
# if success.count and not failure.count:
|
||||||
|
# print("ok")
|
||||||
|
# # only clean out tempfiles if test passed
|
||||||
|
# import os
|
||||||
|
# import os.path
|
||||||
|
# import tempfile
|
||||||
|
# for file in _tempfiles:
|
||||||
|
# try:
|
||||||
|
# os.remove(file)
|
||||||
|
# except OSError:
|
||||||
|
# pass # report?
|
||||||
|
# temp_root = os.path.join(tempfile.gettempdir(), 'pillow-tests')
|
||||||
|
# try:
|
||||||
|
# os.rmdir(temp_root)
|
||||||
|
# except OSError:
|
||||||
|
# pass
|
||||||
|
#
|
||||||
|
# import atexit
|
||||||
|
# atexit.register(report)
|
||||||
|
#
|
||||||
|
# if "--log" in sys.argv:
|
||||||
|
# _logfile = open("test.log", "a")
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# _setup()
|
BIN
Tests/images/imagedraw_arc.png
Normal file
After Width: | Height: | Size: 284 B |
BIN
Tests/images/imagedraw_bitmap.png
Normal file
After Width: | Height: | Size: 2.1 KiB |
BIN
Tests/images/imagedraw_chord.png
Normal file
After Width: | Height: | Size: 326 B |
BIN
Tests/images/imagedraw_ellipse.png
Normal file
After Width: | Height: | Size: 491 B |
BIN
Tests/images/imagedraw_floodfill.png
Normal file
After Width: | Height: | Size: 232 B |
BIN
Tests/images/imagedraw_floodfill2.png
Normal file
After Width: | Height: | Size: 212 B |
BIN
Tests/images/imagedraw_line.png
Normal file
After Width: | Height: | Size: 286 B |
BIN
Tests/images/imagedraw_pieslice.png
Normal file
After Width: | Height: | Size: 405 B |
BIN
Tests/images/imagedraw_point.png
Normal file
After Width: | Height: | Size: 124 B |
BIN
Tests/images/imagedraw_polygon.png
Normal file
After Width: | Height: | Size: 292 B |
BIN
Tests/images/imagedraw_rectangle.png
Normal file
After Width: | Height: | Size: 228 B |
BIN
Tests/images/lena.spider
Normal file
|
@ -1,24 +1,32 @@
|
||||||
from __future__ import print_function
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
from tester import *
|
|
||||||
|
|
||||||
import PIL
|
import PIL
|
||||||
import PIL.Image
|
import PIL.Image
|
||||||
|
|
||||||
# Make sure we have the binary extension
|
|
||||||
im = PIL.Image.core.new("L", (100, 100))
|
|
||||||
|
|
||||||
assert PIL.Image.VERSION[:3] == '1.1'
|
class TestSanity(PillowTestCase):
|
||||||
|
|
||||||
# Create an image and do stuff with it.
|
def test_sanity(self):
|
||||||
im = PIL.Image.new("1", (100, 100))
|
|
||||||
assert (im.mode, im.size) == ('1', (100, 100))
|
|
||||||
assert len(im.tobytes()) == 1300
|
|
||||||
|
|
||||||
# Create images in all remaining major modes.
|
# Make sure we have the binary extension
|
||||||
im = PIL.Image.new("L", (100, 100))
|
im = PIL.Image.core.new("L", (100, 100))
|
||||||
im = PIL.Image.new("P", (100, 100))
|
|
||||||
im = PIL.Image.new("RGB", (100, 100))
|
|
||||||
im = PIL.Image.new("I", (100, 100))
|
|
||||||
im = PIL.Image.new("F", (100, 100))
|
|
||||||
|
|
||||||
print("ok")
|
self.assertEqual(PIL.Image.VERSION[:3], '1.1')
|
||||||
|
|
||||||
|
# Create an image and do stuff with it.
|
||||||
|
im = PIL.Image.new("1", (100, 100))
|
||||||
|
self.assertEqual((im.mode, im.size), ('1', (100, 100)))
|
||||||
|
self.assertEqual(len(im.tobytes()), 1300)
|
||||||
|
|
||||||
|
# Create images in all remaining major modes.
|
||||||
|
im = PIL.Image.new("L", (100, 100))
|
||||||
|
im = PIL.Image.new("P", (100, 100))
|
||||||
|
im = PIL.Image.new("RGB", (100, 100))
|
||||||
|
im = PIL.Image.new("I", (100, 100))
|
||||||
|
im = PIL.Image.new("F", (100, 100))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
import PIL
|
|
||||||
import PIL.Image
|
|
||||||
|
|
||||||
import glob, os
|
|
||||||
|
|
||||||
for file in glob.glob("../pil-archive/*"):
|
|
||||||
f, e = os.path.splitext(file)
|
|
||||||
if e in [".txt", ".ttf", ".otf", ".zip"]:
|
|
||||||
continue
|
|
||||||
try:
|
|
||||||
im = PIL.Image.open(file)
|
|
||||||
im.load()
|
|
||||||
except IOError as v:
|
|
||||||
print("-", "failed to open", file, "-", v)
|
|
||||||
else:
|
|
||||||
print("+", file, im.mode, im.size, im.format)
|
|
||||||
if e == ".exif":
|
|
||||||
try:
|
|
||||||
info = im._getexif()
|
|
||||||
except KeyError as v:
|
|
||||||
print("-", "failed to get exif info from", file, "-", v)
|
|
||||||
|
|
||||||
print("ok")
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
import os
|
import os
|
||||||
|
@ -6,37 +6,40 @@ import os
|
||||||
base = os.path.join('Tests', 'images', 'bmp')
|
base = os.path.join('Tests', 'images', 'bmp')
|
||||||
|
|
||||||
|
|
||||||
def get_files(d, ext='.bmp'):
|
class TestBmpReference(PillowTestCase):
|
||||||
return [os.path.join(base,d,f) for f
|
|
||||||
|
def get_files(self, d, ext='.bmp'):
|
||||||
|
return [os.path.join(base, d, f) for f
|
||||||
in os.listdir(os.path.join(base, d)) if ext in f]
|
in os.listdir(os.path.join(base, d)) if ext in f]
|
||||||
|
|
||||||
def test_bad():
|
def test_bad(self):
|
||||||
""" These shouldn't crash/dos, but they shouldn't return anything either """
|
""" These shouldn't crash/dos, but they shouldn't return anything
|
||||||
for f in get_files('b'):
|
either """
|
||||||
|
for f in self.get_files('b'):
|
||||||
try:
|
try:
|
||||||
im = Image.open(f)
|
im = Image.open(f)
|
||||||
im.load()
|
im.load()
|
||||||
except Exception as msg:
|
except Exception: # as msg:
|
||||||
pass
|
pass
|
||||||
# print ("Bad Image %s: %s" %(f,msg))
|
# print ("Bad Image %s: %s" %(f,msg))
|
||||||
|
|
||||||
def test_questionable():
|
def test_questionable(self):
|
||||||
""" These shouldn't crash/dos, but its not well defined that these are in spec """
|
""" These shouldn't crash/dos, but its not well defined that these
|
||||||
for f in get_files('q'):
|
are in spec """
|
||||||
|
for f in self.get_files('q'):
|
||||||
try:
|
try:
|
||||||
im = Image.open(f)
|
im = Image.open(f)
|
||||||
im.load()
|
im.load()
|
||||||
except Exception as msg:
|
except Exception: # as msg:
|
||||||
pass
|
pass
|
||||||
# print ("Bad Image %s: %s" %(f,msg))
|
# print ("Bad Image %s: %s" %(f,msg))
|
||||||
|
|
||||||
|
def test_good(self):
|
||||||
def test_good():
|
|
||||||
""" These should all work. There's a set of target files in the
|
""" These should all work. There's a set of target files in the
|
||||||
html directory that we can compare against. """
|
html directory that we can compare against. """
|
||||||
|
|
||||||
# Target files, if they're not just replacing the extension
|
# Target files, if they're not just replacing the extension
|
||||||
file_map = { 'pal1wb.bmp': 'pal1.png',
|
file_map = {'pal1wb.bmp': 'pal1.png',
|
||||||
'pal4rle.bmp': 'pal4.png',
|
'pal4rle.bmp': 'pal4.png',
|
||||||
'pal8-0.bmp': 'pal8.png',
|
'pal8-0.bmp': 'pal8.png',
|
||||||
'pal8rle.bmp': 'pal8.png',
|
'pal8rle.bmp': 'pal8.png',
|
||||||
|
@ -58,10 +61,10 @@ def test_good():
|
||||||
(head, name) = os.path.split(f)
|
(head, name) = os.path.split(f)
|
||||||
if name in file_map:
|
if name in file_map:
|
||||||
return os.path.join(base, 'html', file_map[name])
|
return os.path.join(base, 'html', file_map[name])
|
||||||
(name,ext) = os.path.splitext(name)
|
(name, ext) = os.path.splitext(name)
|
||||||
return os.path.join(base, 'html', "%s.png"%name)
|
return os.path.join(base, 'html', "%s.png" % name)
|
||||||
|
|
||||||
for f in get_files('g'):
|
for f in self.get_files('g'):
|
||||||
try:
|
try:
|
||||||
im = Image.open(f)
|
im = Image.open(f)
|
||||||
im.load()
|
im.load()
|
||||||
|
@ -73,8 +76,7 @@ def test_good():
|
||||||
# be differently ordered for an equivalent image.
|
# be differently ordered for an equivalent image.
|
||||||
im = im.convert('RGBA')
|
im = im.convert('RGBA')
|
||||||
compare = im.convert('RGBA')
|
compare = im.convert('RGBA')
|
||||||
assert_image_similar(im, compare,5)
|
self.assert_image_similar(im, compare, 5)
|
||||||
|
|
||||||
|
|
||||||
except Exception as msg:
|
except Exception as msg:
|
||||||
# there are three here that are unsupported:
|
# there are three here that are unsupported:
|
||||||
|
@ -82,5 +84,11 @@ def test_good():
|
||||||
os.path.join(base, 'g', 'pal8rle.bmp'),
|
os.path.join(base, 'g', 'pal8rle.bmp'),
|
||||||
os.path.join(base, 'g', 'pal4rle.bmp'))
|
os.path.join(base, 'g', 'pal4rle.bmp'))
|
||||||
if f not in unsupported:
|
if f not in unsupported:
|
||||||
assert_true(False, "Unsupported Image %s: %s" %(f,msg))
|
self.assertTrue(
|
||||||
|
False, "Unsupported Image %s: %s" % (f, msg))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,99 +1,136 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import cffi
|
import cffi
|
||||||
|
from PIL import PyAccess
|
||||||
except:
|
except:
|
||||||
skip()
|
# Skip in setUp()
|
||||||
|
pass
|
||||||
|
|
||||||
from PIL import Image, PyAccess
|
from PIL import Image
|
||||||
|
|
||||||
import test_image_putpixel as put
|
|
||||||
import test_image_getpixel as get
|
|
||||||
|
|
||||||
|
from test_image_putpixel import TestImagePutPixel
|
||||||
|
from test_image_getpixel import TestImageGetPixel
|
||||||
|
|
||||||
Image.USE_CFFI_ACCESS = True
|
Image.USE_CFFI_ACCESS = True
|
||||||
|
|
||||||
def test_put():
|
|
||||||
put.test_sanity()
|
|
||||||
|
|
||||||
def test_get():
|
class TestCffiPutPixel(TestImagePutPixel):
|
||||||
get.test_basic()
|
|
||||||
get.test_signedness()
|
|
||||||
|
|
||||||
def _test_get_access(im):
|
def setUp(self):
|
||||||
|
try:
|
||||||
|
import cffi
|
||||||
|
except:
|
||||||
|
self.skipTest("No cffi")
|
||||||
|
|
||||||
|
def test_put(self):
|
||||||
|
self.test_sanity()
|
||||||
|
|
||||||
|
|
||||||
|
class TestCffiGetPixel(TestImageGetPixel):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
try:
|
||||||
|
import cffi
|
||||||
|
except:
|
||||||
|
self.skipTest("No cffi")
|
||||||
|
|
||||||
|
def test_get(self):
|
||||||
|
self.test_basic()
|
||||||
|
self.test_signedness()
|
||||||
|
|
||||||
|
|
||||||
|
class TestCffi(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
try:
|
||||||
|
import cffi
|
||||||
|
except:
|
||||||
|
self.skipTest("No cffi")
|
||||||
|
|
||||||
|
def _test_get_access(self, im):
|
||||||
""" Do we get the same thing as the old pixel access """
|
""" Do we get the same thing as the old pixel access """
|
||||||
|
|
||||||
""" Using private interfaces, forcing a capi access and a pyaccess for the same image """
|
""" Using private interfaces, forcing a capi access and
|
||||||
|
a pyaccess for the same image """
|
||||||
caccess = im.im.pixel_access(False)
|
caccess = im.im.pixel_access(False)
|
||||||
access = PyAccess.new(im, False)
|
access = PyAccess.new(im, False)
|
||||||
|
|
||||||
w,h = im.size
|
w, h = im.size
|
||||||
for x in range(0,w,10):
|
for x in range(0, w, 10):
|
||||||
for y in range(0,h,10):
|
for y in range(0, h, 10):
|
||||||
assert_equal(access[(x,y)], caccess[(x,y)])
|
self.assertEqual(access[(x, y)], caccess[(x, y)])
|
||||||
|
|
||||||
def test_get_vs_c():
|
def test_get_vs_c(self):
|
||||||
_test_get_access(lena('RGB'))
|
rgb = lena('RGB')
|
||||||
_test_get_access(lena('RGBA'))
|
rgb.load()
|
||||||
_test_get_access(lena('L'))
|
self._test_get_access(rgb)
|
||||||
_test_get_access(lena('LA'))
|
self._test_get_access(lena('RGBA'))
|
||||||
_test_get_access(lena('1'))
|
self._test_get_access(lena('L'))
|
||||||
_test_get_access(lena('P'))
|
self._test_get_access(lena('LA'))
|
||||||
#_test_get_access(lena('PA')) # PA -- how do I make a PA image???
|
self._test_get_access(lena('1'))
|
||||||
_test_get_access(lena('F'))
|
self._test_get_access(lena('P'))
|
||||||
|
# self._test_get_access(lena('PA')) # PA -- how do I make a PA image?
|
||||||
|
self._test_get_access(lena('F'))
|
||||||
|
|
||||||
im = Image.new('I;16', (10,10), 40000)
|
im = Image.new('I;16', (10, 10), 40000)
|
||||||
_test_get_access(im)
|
self._test_get_access(im)
|
||||||
im = Image.new('I;16L', (10,10), 40000)
|
im = Image.new('I;16L', (10, 10), 40000)
|
||||||
_test_get_access(im)
|
self._test_get_access(im)
|
||||||
im = Image.new('I;16B', (10,10), 40000)
|
im = Image.new('I;16B', (10, 10), 40000)
|
||||||
_test_get_access(im)
|
self._test_get_access(im)
|
||||||
|
|
||||||
im = Image.new('I', (10,10), 40000)
|
im = Image.new('I', (10, 10), 40000)
|
||||||
_test_get_access(im)
|
self._test_get_access(im)
|
||||||
# These don't actually appear to be modes that I can actually make,
|
# These don't actually appear to be modes that I can actually make,
|
||||||
# as unpack sets them directly into the I mode.
|
# as unpack sets them directly into the I mode.
|
||||||
#im = Image.new('I;32L', (10,10), -2**10)
|
# im = Image.new('I;32L', (10, 10), -2**10)
|
||||||
#_test_get_access(im)
|
# self._test_get_access(im)
|
||||||
#im = Image.new('I;32B', (10,10), 2**10)
|
# im = Image.new('I;32B', (10, 10), 2**10)
|
||||||
#_test_get_access(im)
|
# self._test_get_access(im)
|
||||||
|
|
||||||
|
def _test_set_access(self, im, color):
|
||||||
|
|
||||||
def _test_set_access(im, color):
|
|
||||||
""" Are we writing the correct bits into the image? """
|
""" Are we writing the correct bits into the image? """
|
||||||
|
|
||||||
""" Using private interfaces, forcing a capi access and a pyaccess for the same image """
|
""" Using private interfaces, forcing a capi access and
|
||||||
|
a pyaccess for the same image """
|
||||||
caccess = im.im.pixel_access(False)
|
caccess = im.im.pixel_access(False)
|
||||||
access = PyAccess.new(im, False)
|
access = PyAccess.new(im, False)
|
||||||
|
|
||||||
w,h = im.size
|
w, h = im.size
|
||||||
for x in range(0,w,10):
|
for x in range(0, w, 10):
|
||||||
for y in range(0,h,10):
|
for y in range(0, h, 10):
|
||||||
access[(x,y)] = color
|
access[(x, y)] = color
|
||||||
assert_equal(color, caccess[(x,y)])
|
self.assertEqual(color, caccess[(x, y)])
|
||||||
|
|
||||||
def test_set_vs_c():
|
def test_set_vs_c(self):
|
||||||
_test_set_access(lena('RGB'), (255, 128,0) )
|
rgb = lena('RGB')
|
||||||
_test_set_access(lena('RGBA'), (255, 192, 128, 0))
|
rgb.load()
|
||||||
_test_set_access(lena('L'), 128)
|
self._test_set_access(rgb, (255, 128, 0))
|
||||||
_test_set_access(lena('LA'), (128,128))
|
self._test_set_access(lena('RGBA'), (255, 192, 128, 0))
|
||||||
_test_set_access(lena('1'), 255)
|
self._test_set_access(lena('L'), 128)
|
||||||
_test_set_access(lena('P') , 128)
|
self._test_set_access(lena('LA'), (128, 128))
|
||||||
##_test_set_access(i, (128,128)) #PA -- undone how to make
|
self._test_set_access(lena('1'), 255)
|
||||||
_test_set_access(lena('F'), 1024.0)
|
self._test_set_access(lena('P'), 128)
|
||||||
|
# self._test_set_access(i, (128, 128)) #PA -- undone how to make
|
||||||
|
self._test_set_access(lena('F'), 1024.0)
|
||||||
|
|
||||||
im = Image.new('I;16', (10,10), 40000)
|
im = Image.new('I;16', (10, 10), 40000)
|
||||||
_test_set_access(im, 45000)
|
self._test_set_access(im, 45000)
|
||||||
im = Image.new('I;16L', (10,10), 40000)
|
im = Image.new('I;16L', (10, 10), 40000)
|
||||||
_test_set_access(im, 45000)
|
self._test_set_access(im, 45000)
|
||||||
im = Image.new('I;16B', (10,10), 40000)
|
im = Image.new('I;16B', (10, 10), 40000)
|
||||||
_test_set_access(im, 45000)
|
self._test_set_access(im, 45000)
|
||||||
|
|
||||||
|
im = Image.new('I', (10, 10), 40000)
|
||||||
|
self._test_set_access(im, 45000)
|
||||||
|
# im = Image.new('I;32L', (10, 10), -(2**10))
|
||||||
|
# self._test_set_access(im, -(2**13)+1)
|
||||||
|
# im = Image.new('I;32B', (10, 10), 2**10)
|
||||||
|
# self._test_set_access(im, 2**13-1)
|
||||||
|
|
||||||
|
|
||||||
im = Image.new('I', (10,10), 40000)
|
if __name__ == '__main__':
|
||||||
_test_set_access(im, 45000)
|
unittest.main()
|
||||||
# im = Image.new('I;32L', (10,10), -(2**10))
|
|
||||||
# _test_set_access(im, -(2**13)+1)
|
# End of file
|
||||||
#im = Image.new('I;32B', (10,10), 2**10)
|
|
||||||
#_test_set_access(im, 2**13-1)
|
|
||||||
|
|
|
@ -1,30 +1,31 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
import io
|
import io
|
||||||
|
|
||||||
def roundtrip(im):
|
|
||||||
outfile = tempfile("temp.bmp")
|
class TestFileBmp(PillowTestCase):
|
||||||
|
|
||||||
|
def roundtrip(self, im):
|
||||||
|
outfile = self.tempfile("temp.bmp")
|
||||||
|
|
||||||
im.save(outfile, 'BMP')
|
im.save(outfile, 'BMP')
|
||||||
|
|
||||||
reloaded = Image.open(outfile)
|
reloaded = Image.open(outfile)
|
||||||
reloaded.load()
|
reloaded.load()
|
||||||
assert_equal(im.mode, reloaded.mode)
|
self.assertEqual(im.mode, reloaded.mode)
|
||||||
assert_equal(im.size, reloaded.size)
|
self.assertEqual(im.size, reloaded.size)
|
||||||
assert_equal(reloaded.format, "BMP")
|
self.assertEqual(reloaded.format, "BMP")
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
self.roundtrip(lena())
|
||||||
|
|
||||||
def test_sanity():
|
self.roundtrip(lena("1"))
|
||||||
roundtrip(lena())
|
self.roundtrip(lena("L"))
|
||||||
|
self.roundtrip(lena("P"))
|
||||||
|
self.roundtrip(lena("RGB"))
|
||||||
|
|
||||||
roundtrip(lena("1"))
|
def test_save_to_bytes(self):
|
||||||
roundtrip(lena("L"))
|
|
||||||
roundtrip(lena("P"))
|
|
||||||
roundtrip(lena("RGB"))
|
|
||||||
|
|
||||||
|
|
||||||
def test_save_to_bytes():
|
|
||||||
output = io.BytesIO()
|
output = io.BytesIO()
|
||||||
im = lena()
|
im = lena()
|
||||||
im.save(output, "BMP")
|
im.save(output, "BMP")
|
||||||
|
@ -32,7 +33,12 @@ def test_save_to_bytes():
|
||||||
output.seek(0)
|
output.seek(0)
|
||||||
reloaded = Image.open(output)
|
reloaded = Image.open(output)
|
||||||
|
|
||||||
assert_equal(im.mode, reloaded.mode)
|
self.assertEqual(im.mode, reloaded.mode)
|
||||||
assert_equal(im.size, reloaded.size)
|
self.assertEqual(im.size, reloaded.size)
|
||||||
assert_equal(reloaded.format, "BMP")
|
self.assertEqual(reloaded.format, "BMP")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image, EpsImagePlugin
|
from PIL import Image, EpsImagePlugin
|
||||||
import io
|
import io
|
||||||
|
|
||||||
if not EpsImagePlugin.has_ghostscript():
|
|
||||||
skip()
|
|
||||||
|
|
||||||
# Our two EPS test files (they are identical except for their bounding boxes)
|
# Our two EPS test files (they are identical except for their bounding boxes)
|
||||||
file1 = "Tests/images/zero_bb.eps"
|
file1 = "Tests/images/zero_bb.eps"
|
||||||
file2 = "Tests/images/non_zero_bb.eps"
|
file2 = "Tests/images/non_zero_bb.eps"
|
||||||
|
@ -20,91 +17,93 @@ file2_compare_scale2 = "Tests/images/non_zero_bb_scale2.png"
|
||||||
# EPS test files with binary preview
|
# EPS test files with binary preview
|
||||||
file3 = "Tests/images/binary_preview_map.eps"
|
file3 = "Tests/images/binary_preview_map.eps"
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileEps(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if not EpsImagePlugin.has_ghostscript():
|
||||||
|
self.skipTest("Ghostscript not available")
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
# Regular scale
|
# Regular scale
|
||||||
image1 = Image.open(file1)
|
image1 = Image.open(file1)
|
||||||
image1.load()
|
image1.load()
|
||||||
assert_equal(image1.mode, "RGB")
|
self.assertEqual(image1.mode, "RGB")
|
||||||
assert_equal(image1.size, (460, 352))
|
self.assertEqual(image1.size, (460, 352))
|
||||||
assert_equal(image1.format, "EPS")
|
self.assertEqual(image1.format, "EPS")
|
||||||
|
|
||||||
image2 = Image.open(file2)
|
image2 = Image.open(file2)
|
||||||
image2.load()
|
image2.load()
|
||||||
assert_equal(image2.mode, "RGB")
|
self.assertEqual(image2.mode, "RGB")
|
||||||
assert_equal(image2.size, (360, 252))
|
self.assertEqual(image2.size, (360, 252))
|
||||||
assert_equal(image2.format, "EPS")
|
self.assertEqual(image2.format, "EPS")
|
||||||
|
|
||||||
# Double scale
|
# Double scale
|
||||||
image1_scale2 = Image.open(file1)
|
image1_scale2 = Image.open(file1)
|
||||||
image1_scale2.load(scale=2)
|
image1_scale2.load(scale=2)
|
||||||
assert_equal(image1_scale2.mode, "RGB")
|
self.assertEqual(image1_scale2.mode, "RGB")
|
||||||
assert_equal(image1_scale2.size, (920, 704))
|
self.assertEqual(image1_scale2.size, (920, 704))
|
||||||
assert_equal(image1_scale2.format, "EPS")
|
self.assertEqual(image1_scale2.format, "EPS")
|
||||||
|
|
||||||
image2_scale2 = Image.open(file2)
|
image2_scale2 = Image.open(file2)
|
||||||
image2_scale2.load(scale=2)
|
image2_scale2.load(scale=2)
|
||||||
assert_equal(image2_scale2.mode, "RGB")
|
self.assertEqual(image2_scale2.mode, "RGB")
|
||||||
assert_equal(image2_scale2.size, (720, 504))
|
self.assertEqual(image2_scale2.size, (720, 504))
|
||||||
assert_equal(image2_scale2.format, "EPS")
|
self.assertEqual(image2_scale2.format, "EPS")
|
||||||
|
|
||||||
|
def test_file_object(self):
|
||||||
def test_file_object():
|
|
||||||
# issue 479
|
# issue 479
|
||||||
image1 = Image.open(file1)
|
image1 = Image.open(file1)
|
||||||
with open(tempfile('temp_file.eps'), 'wb') as fh:
|
with open(self.tempfile('temp_file.eps'), 'wb') as fh:
|
||||||
image1.save(fh, 'EPS')
|
image1.save(fh, 'EPS')
|
||||||
|
|
||||||
|
def test_iobase_object(self):
|
||||||
def test_iobase_object():
|
|
||||||
# issue 479
|
# issue 479
|
||||||
image1 = Image.open(file1)
|
image1 = Image.open(file1)
|
||||||
with io.open(tempfile('temp_iobase.eps'), 'wb') as fh:
|
with io.open(self.tempfile('temp_iobase.eps'), 'wb') as fh:
|
||||||
image1.save(fh, 'EPS')
|
image1.save(fh, 'EPS')
|
||||||
|
|
||||||
|
def test_render_scale1(self):
|
||||||
def test_render_scale1():
|
|
||||||
# We need png support for these render test
|
# We need png support for these render test
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
||||||
skip("zip/deflate support not available")
|
self.skipTest("zip/deflate support not available")
|
||||||
|
|
||||||
# Zero bounding box
|
# Zero bounding box
|
||||||
image1_scale1 = Image.open(file1)
|
image1_scale1 = Image.open(file1)
|
||||||
image1_scale1.load()
|
image1_scale1.load()
|
||||||
image1_scale1_compare = Image.open(file1_compare).convert("RGB")
|
image1_scale1_compare = Image.open(file1_compare).convert("RGB")
|
||||||
image1_scale1_compare.load()
|
image1_scale1_compare.load()
|
||||||
assert_image_similar(image1_scale1, image1_scale1_compare, 5)
|
self.assert_image_similar(image1_scale1, image1_scale1_compare, 5)
|
||||||
|
|
||||||
# Non-Zero bounding box
|
# Non-Zero bounding box
|
||||||
image2_scale1 = Image.open(file2)
|
image2_scale1 = Image.open(file2)
|
||||||
image2_scale1.load()
|
image2_scale1.load()
|
||||||
image2_scale1_compare = Image.open(file2_compare).convert("RGB")
|
image2_scale1_compare = Image.open(file2_compare).convert("RGB")
|
||||||
image2_scale1_compare.load()
|
image2_scale1_compare.load()
|
||||||
assert_image_similar(image2_scale1, image2_scale1_compare, 10)
|
self.assert_image_similar(image2_scale1, image2_scale1_compare, 10)
|
||||||
|
|
||||||
|
def test_render_scale2(self):
|
||||||
def test_render_scale2():
|
|
||||||
# We need png support for these render test
|
# We need png support for these render test
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
||||||
skip("zip/deflate support not available")
|
self.skipTest("zip/deflate support not available")
|
||||||
|
|
||||||
# Zero bounding box
|
# Zero bounding box
|
||||||
image1_scale2 = Image.open(file1)
|
image1_scale2 = Image.open(file1)
|
||||||
image1_scale2.load(scale=2)
|
image1_scale2.load(scale=2)
|
||||||
image1_scale2_compare = Image.open(file1_compare_scale2).convert("RGB")
|
image1_scale2_compare = Image.open(file1_compare_scale2).convert("RGB")
|
||||||
image1_scale2_compare.load()
|
image1_scale2_compare.load()
|
||||||
assert_image_similar(image1_scale2, image1_scale2_compare, 5)
|
self.assert_image_similar(image1_scale2, image1_scale2_compare, 5)
|
||||||
|
|
||||||
# Non-Zero bounding box
|
# Non-Zero bounding box
|
||||||
image2_scale2 = Image.open(file2)
|
image2_scale2 = Image.open(file2)
|
||||||
image2_scale2.load(scale=2)
|
image2_scale2.load(scale=2)
|
||||||
image2_scale2_compare = Image.open(file2_compare_scale2).convert("RGB")
|
image2_scale2_compare = Image.open(file2_compare_scale2).convert("RGB")
|
||||||
image2_scale2_compare.load()
|
image2_scale2_compare.load()
|
||||||
assert_image_similar(image2_scale2, image2_scale2_compare, 10)
|
self.assert_image_similar(image2_scale2, image2_scale2_compare, 10)
|
||||||
|
|
||||||
|
def test_resize(self):
|
||||||
def test_resize():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
image1 = Image.open(file1)
|
image1 = Image.open(file1)
|
||||||
image2 = Image.open(file2)
|
image2 = Image.open(file2)
|
||||||
|
@ -115,11 +114,10 @@ def test_resize():
|
||||||
image2 = image2.resize(new_size)
|
image2 = image2.resize(new_size)
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert_equal(image1.size, new_size)
|
self.assertEqual(image1.size, new_size)
|
||||||
assert_equal(image2.size, new_size)
|
self.assertEqual(image2.size, new_size)
|
||||||
|
|
||||||
|
def test_thumbnail(self):
|
||||||
def test_thumbnail():
|
|
||||||
# Issue #619
|
# Issue #619
|
||||||
# Arrange
|
# Arrange
|
||||||
image1 = Image.open(file1)
|
image1 = Image.open(file1)
|
||||||
|
@ -131,12 +129,15 @@ def test_thumbnail():
|
||||||
image2.thumbnail(new_size)
|
image2.thumbnail(new_size)
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert_equal(max(image1.size), max(new_size))
|
self.assertEqual(max(image1.size), max(new_size))
|
||||||
assert_equal(max(image2.size), max(new_size))
|
self.assertEqual(max(image2.size), max(new_size))
|
||||||
|
|
||||||
def test_read_binary_preview():
|
def test_read_binary_preview(self):
|
||||||
# Issue 302
|
# Issue 302
|
||||||
# open image with binary preview
|
# open image with binary preview
|
||||||
image1 = Image.open(file3)
|
Image.open(file3)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
# End of file
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -6,9 +6,18 @@ from PIL import Image
|
||||||
file = "Images/lena.fli"
|
file = "Images/lena.fli"
|
||||||
data = open(file, "rb").read()
|
data = open(file, "rb").read()
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileFli(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "P")
|
self.assertEqual(im.mode, "P")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "FLI")
|
self.assertEqual(im.format, "FLI")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,73 +1,78 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if "gif_encoder" not in codecs or "gif_decoder" not in codecs:
|
|
||||||
skip("gif support not available") # can this happen?
|
|
||||||
|
|
||||||
# sample gif stream
|
# sample gif stream
|
||||||
file = "Images/lena.gif"
|
file = "Images/lena.gif"
|
||||||
with open(file, "rb") as f:
|
with open(file, "rb") as f:
|
||||||
data = f.read()
|
data = f.read()
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileGif(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "gif_encoder" not in codecs or "gif_decoder" not in codecs:
|
||||||
|
self.skipTest("gif support not available") # can this happen?
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "P")
|
self.assertEqual(im.mode, "P")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "GIF")
|
self.assertEqual(im.format, "GIF")
|
||||||
|
|
||||||
|
def test_optimize(self):
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
def test_optimize():
|
|
||||||
def test(optimize):
|
def test(optimize):
|
||||||
im = Image.new("L", (1, 1), 0)
|
im = Image.new("L", (1, 1), 0)
|
||||||
file = BytesIO()
|
file = BytesIO()
|
||||||
im.save(file, "GIF", optimize=optimize)
|
im.save(file, "GIF", optimize=optimize)
|
||||||
return len(file.getvalue())
|
return len(file.getvalue())
|
||||||
assert_equal(test(0), 800)
|
self.assertEqual(test(0), 800)
|
||||||
assert_equal(test(1), 38)
|
self.assertEqual(test(1), 38)
|
||||||
|
|
||||||
def test_roundtrip():
|
def test_roundtrip(self):
|
||||||
out = tempfile('temp.gif')
|
out = self.tempfile('temp.gif')
|
||||||
im = lena()
|
im = lena()
|
||||||
im.save(out)
|
im.save(out)
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
|
|
||||||
assert_image_similar(reread.convert('RGB'), im, 50)
|
self.assert_image_similar(reread.convert('RGB'), im, 50)
|
||||||
|
|
||||||
def test_roundtrip2():
|
def test_roundtrip2(self):
|
||||||
#see https://github.com/python-imaging/Pillow/issues/403
|
# see https://github.com/python-pillow/Pillow/issues/403
|
||||||
out = tempfile('temp.gif')
|
out = self.tempfile('temp.gif')
|
||||||
im = Image.open('Images/lena.gif')
|
im = Image.open('Images/lena.gif')
|
||||||
im2 = im.copy()
|
im2 = im.copy()
|
||||||
im2.save(out)
|
im2.save(out)
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
|
|
||||||
assert_image_similar(reread.convert('RGB'), lena(), 50)
|
self.assert_image_similar(reread.convert('RGB'), lena(), 50)
|
||||||
|
|
||||||
|
def test_palette_handling(self):
|
||||||
def test_palette_handling():
|
# see https://github.com/python-pillow/Pillow/issues/513
|
||||||
# see https://github.com/python-imaging/Pillow/issues/513
|
|
||||||
|
|
||||||
im = Image.open('Images/lena.gif')
|
im = Image.open('Images/lena.gif')
|
||||||
im = im.convert('RGB')
|
im = im.convert('RGB')
|
||||||
|
|
||||||
im = im.resize((100,100), Image.ANTIALIAS)
|
im = im.resize((100, 100), Image.ANTIALIAS)
|
||||||
im2 = im.convert('P', palette=Image.ADAPTIVE, colors=256)
|
im2 = im.convert('P', palette=Image.ADAPTIVE, colors=256)
|
||||||
|
|
||||||
f = tempfile('temp.gif')
|
f = self.tempfile('temp.gif')
|
||||||
im2.save(f, optimize=True)
|
im2.save(f, optimize=True)
|
||||||
|
|
||||||
reloaded = Image.open(f)
|
reloaded = Image.open(f)
|
||||||
|
|
||||||
assert_image_similar(im, reloaded.convert('RGB'), 10)
|
self.assert_image_similar(im, reloaded.convert('RGB'), 10)
|
||||||
|
|
||||||
def test_palette_434():
|
def test_palette_434(self):
|
||||||
# see https://github.com/python-imaging/Pillow/issues/434
|
# see https://github.com/python-pillow/Pillow/issues/434
|
||||||
|
|
||||||
def roundtrip(im, *args, **kwargs):
|
def roundtrip(im, *args, **kwargs):
|
||||||
out = tempfile('temp.gif')
|
out = self.tempfile('temp.gif')
|
||||||
im.save(out, *args, **kwargs)
|
im.save(out, *args, **kwargs)
|
||||||
reloaded = Image.open(out)
|
reloaded = Image.open(out)
|
||||||
|
|
||||||
|
@ -76,12 +81,16 @@ def test_palette_434():
|
||||||
orig = "Tests/images/test.colors.gif"
|
orig = "Tests/images/test.colors.gif"
|
||||||
im = Image.open(orig)
|
im = Image.open(orig)
|
||||||
|
|
||||||
assert_image_equal(*roundtrip(im))
|
self.assert_image_equal(*roundtrip(im))
|
||||||
assert_image_equal(*roundtrip(im, optimize=True))
|
self.assert_image_equal(*roundtrip(im, optimize=True))
|
||||||
|
|
||||||
im = im.convert("RGB")
|
im = im.convert("RGB")
|
||||||
# check automatic P conversion
|
# check automatic P conversion
|
||||||
reloaded = roundtrip(im)[1].convert('RGB')
|
reloaded = roundtrip(im)[1].convert('RGB')
|
||||||
assert_image_equal(im, reloaded)
|
self.assert_image_equal(im, reloaded)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -8,42 +8,45 @@ data = open(file, "rb").read()
|
||||||
|
|
||||||
enable_jpeg2k = hasattr(Image.core, 'jp2klib_version')
|
enable_jpeg2k = hasattr(Image.core, 'jp2klib_version')
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileIcns(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
# Loading this icon by default should result in the largest size
|
# Loading this icon by default should result in the largest size
|
||||||
# (512x512@2x) being loaded
|
# (512x512@2x) being loaded
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGBA")
|
self.assertEqual(im.mode, "RGBA")
|
||||||
assert_equal(im.size, (1024, 1024))
|
self.assertEqual(im.size, (1024, 1024))
|
||||||
assert_equal(im.format, "ICNS")
|
self.assertEqual(im.format, "ICNS")
|
||||||
|
|
||||||
def test_sizes():
|
def test_sizes(self):
|
||||||
# Check that we can load all of the sizes, and that the final pixel
|
# Check that we can load all of the sizes, and that the final pixel
|
||||||
# dimensions are as expected
|
# dimensions are as expected
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
for w,h,r in im.info['sizes']:
|
for w, h, r in im.info['sizes']:
|
||||||
wr = w * r
|
wr = w * r
|
||||||
hr = h * r
|
hr = h * r
|
||||||
im2 = Image.open(file)
|
im2 = Image.open(file)
|
||||||
im2.size = (w, h, r)
|
im2.size = (w, h, r)
|
||||||
im2.load()
|
im2.load()
|
||||||
assert_equal(im2.mode, 'RGBA')
|
self.assertEqual(im2.mode, 'RGBA')
|
||||||
assert_equal(im2.size, (wr, hr))
|
self.assertEqual(im2.size, (wr, hr))
|
||||||
|
|
||||||
def test_older_icon():
|
def test_older_icon(self):
|
||||||
# This icon was made with Icon Composer rather than iconutil; it still
|
# This icon was made with Icon Composer rather than iconutil; it still
|
||||||
# uses PNG rather than JP2, however (since it was made on 10.9).
|
# uses PNG rather than JP2, however (since it was made on 10.9).
|
||||||
im = Image.open('Tests/images/pillow2.icns')
|
im = Image.open('Tests/images/pillow2.icns')
|
||||||
for w,h,r in im.info['sizes']:
|
for w, h, r in im.info['sizes']:
|
||||||
wr = w * r
|
wr = w * r
|
||||||
hr = h * r
|
hr = h * r
|
||||||
im2 = Image.open('Tests/images/pillow2.icns')
|
im2 = Image.open('Tests/images/pillow2.icns')
|
||||||
im2.size = (w, h, r)
|
im2.size = (w, h, r)
|
||||||
im2.load()
|
im2.load()
|
||||||
assert_equal(im2.mode, 'RGBA')
|
self.assertEqual(im2.mode, 'RGBA')
|
||||||
assert_equal(im2.size, (wr, hr))
|
self.assertEqual(im2.size, (wr, hr))
|
||||||
|
|
||||||
def test_jp2_icon():
|
def test_jp2_icon(self):
|
||||||
# This icon was made by using Uli Kusterer's oldiconutil to replace
|
# This icon was made by using Uli Kusterer's oldiconutil to replace
|
||||||
# the PNG images with JPEG 2000 ones. The advantage of doing this is
|
# the PNG images with JPEG 2000 ones. The advantage of doing this is
|
||||||
# that OS X 10.5 supports JPEG 2000 but not PNG; some commercial
|
# that OS X 10.5 supports JPEG 2000 but not PNG; some commercial
|
||||||
|
@ -55,12 +58,17 @@ def test_jp2_icon():
|
||||||
return
|
return
|
||||||
|
|
||||||
im = Image.open('Tests/images/pillow3.icns')
|
im = Image.open('Tests/images/pillow3.icns')
|
||||||
for w,h,r in im.info['sizes']:
|
for w, h, r in im.info['sizes']:
|
||||||
wr = w * r
|
wr = w * r
|
||||||
hr = h * r
|
hr = h * r
|
||||||
im2 = Image.open('Tests/images/pillow3.icns')
|
im2 = Image.open('Tests/images/pillow3.icns')
|
||||||
im2.size = (w, h, r)
|
im2.size = (w, h, r)
|
||||||
im2.load()
|
im2.load()
|
||||||
assert_equal(im2.mode, 'RGBA')
|
self.assertEqual(im2.mode, 'RGBA')
|
||||||
assert_equal(im2.size, (wr, hr))
|
self.assertEqual(im2.size, (wr, hr))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -6,9 +6,18 @@ from PIL import Image
|
||||||
file = "Images/lena.ico"
|
file = "Images/lena.ico"
|
||||||
data = open(file, "rb").read()
|
data = open(file, "rb").read()
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileIco(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGBA")
|
self.assertEqual(im.mode, "RGBA")
|
||||||
assert_equal(im.size, (16, 16))
|
self.assertEqual(im.size, (16, 16))
|
||||||
assert_equal(im.format, "ICO")
|
self.assertEqual(im.format, "ICO")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,19 +1,23 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena, py3
|
||||||
|
|
||||||
import random
|
import random
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
from PIL import ImageFile
|
from PIL import ImageFile
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if "jpeg_encoder" not in codecs or "jpeg_decoder" not in codecs:
|
test_file = "Tests/images/lena.jpg"
|
||||||
skip("jpeg support not available")
|
|
||||||
|
|
||||||
test_file = "Images/lena.jpg"
|
|
||||||
|
|
||||||
|
|
||||||
def roundtrip(im, **options):
|
class TestFileJpeg(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "jpeg_encoder" not in codecs or "jpeg_decoder" not in codecs:
|
||||||
|
self.skipTest("jpeg support not available")
|
||||||
|
|
||||||
|
def roundtrip(self, im, **options):
|
||||||
out = BytesIO()
|
out = BytesIO()
|
||||||
im.save(out, "JPEG", **options)
|
im.save(out, "JPEG", **options)
|
||||||
bytes = out.tell()
|
bytes = out.tell()
|
||||||
|
@ -22,81 +26,78 @@ def roundtrip(im, **options):
|
||||||
im.bytes = bytes # for testing only
|
im.bytes = bytes # for testing only
|
||||||
return im
|
return im
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
def test_sanity(self):
|
||||||
|
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
|
||||||
# internal version number
|
# internal version number
|
||||||
assert_match(Image.core.jpeglib_version, "\d+\.\d+$")
|
self.assertRegexpMatches(Image.core.jpeglib_version, "\d+\.\d+$")
|
||||||
|
|
||||||
im = Image.open(test_file)
|
im = Image.open(test_file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "JPEG")
|
self.assertEqual(im.format, "JPEG")
|
||||||
|
|
||||||
|
def test_app(self):
|
||||||
# --------------------------------------------------------------------
|
|
||||||
|
|
||||||
def test_app():
|
|
||||||
# Test APP/COM reader (@PIL135)
|
# Test APP/COM reader (@PIL135)
|
||||||
im = Image.open(test_file)
|
im = Image.open(test_file)
|
||||||
assert_equal(im.applist[0],
|
self.assertEqual(
|
||||||
|
im.applist[0],
|
||||||
("APP0", b"JFIF\x00\x01\x01\x00\x00\x01\x00\x01\x00\x00"))
|
("APP0", b"JFIF\x00\x01\x01\x00\x00\x01\x00\x01\x00\x00"))
|
||||||
assert_equal(im.applist[1], ("COM", b"Python Imaging Library"))
|
self.assertEqual(im.applist[1], ("COM", b"Python Imaging Library"))
|
||||||
assert_equal(len(im.applist), 2)
|
self.assertEqual(len(im.applist), 2)
|
||||||
|
|
||||||
|
def test_cmyk(self):
|
||||||
def test_cmyk():
|
|
||||||
# Test CMYK handling. Thanks to Tim and Charlie for test data,
|
# Test CMYK handling. Thanks to Tim and Charlie for test data,
|
||||||
# Michael for getting me to look one more time.
|
# Michael for getting me to look one more time.
|
||||||
f = "Tests/images/pil_sample_cmyk.jpg"
|
f = "Tests/images/pil_sample_cmyk.jpg"
|
||||||
im = Image.open(f)
|
im = Image.open(f)
|
||||||
# the source image has red pixels in the upper left corner.
|
# the source image has red pixels in the upper left corner.
|
||||||
c, m, y, k = [x / 255.0 for x in im.getpixel((0, 0))]
|
c, m, y, k = [x / 255.0 for x in im.getpixel((0, 0))]
|
||||||
assert_true(c == 0.0 and m > 0.8 and y > 0.8 and k == 0.0)
|
self.assertEqual(c, 0.0)
|
||||||
|
self.assertGreater(m, 0.8)
|
||||||
|
self.assertGreater(y, 0.8)
|
||||||
|
self.assertEqual(k, 0.0)
|
||||||
# the opposite corner is black
|
# the opposite corner is black
|
||||||
c, m, y, k = [x / 255.0 for x in im.getpixel((im.size[0]-1, im.size[1]-1))]
|
c, m, y, k = [x / 255.0 for x in im.getpixel((im.size[0]-1, im.size[1]-1))]
|
||||||
assert_true(k > 0.9)
|
self.assertGreater(k, 0.9)
|
||||||
# roundtrip, and check again
|
# roundtrip, and check again
|
||||||
im = roundtrip(im)
|
im = self.roundtrip(im)
|
||||||
c, m, y, k = [x / 255.0 for x in im.getpixel((0, 0))]
|
c, m, y, k = [x / 255.0 for x in im.getpixel((0, 0))]
|
||||||
assert_true(c == 0.0 and m > 0.8 and y > 0.8 and k == 0.0)
|
self.assertEqual(c, 0.0)
|
||||||
|
self.assertGreater(m, 0.8)
|
||||||
|
self.assertGreater(y, 0.8)
|
||||||
|
self.assertEqual(k, 0.0)
|
||||||
c, m, y, k = [x / 255.0 for x in im.getpixel((im.size[0]-1, im.size[1]-1))]
|
c, m, y, k = [x / 255.0 for x in im.getpixel((im.size[0]-1, im.size[1]-1))]
|
||||||
assert_true(k > 0.9)
|
self.assertGreater(k, 0.9)
|
||||||
|
|
||||||
|
def test_dpi(self):
|
||||||
def test_dpi():
|
|
||||||
def test(xdpi, ydpi=None):
|
def test(xdpi, ydpi=None):
|
||||||
im = Image.open(test_file)
|
im = Image.open(test_file)
|
||||||
im = roundtrip(im, dpi=(xdpi, ydpi or xdpi))
|
im = self.roundtrip(im, dpi=(xdpi, ydpi or xdpi))
|
||||||
return im.info.get("dpi")
|
return im.info.get("dpi")
|
||||||
assert_equal(test(72), (72, 72))
|
self.assertEqual(test(72), (72, 72))
|
||||||
assert_equal(test(300), (300, 300))
|
self.assertEqual(test(300), (300, 300))
|
||||||
assert_equal(test(100, 200), (100, 200))
|
self.assertEqual(test(100, 200), (100, 200))
|
||||||
assert_equal(test(0), None) # square pixels
|
self.assertEqual(test(0), None) # square pixels
|
||||||
|
|
||||||
|
def test_icc(self):
|
||||||
def test_icc():
|
|
||||||
# Test ICC support
|
# Test ICC support
|
||||||
im1 = Image.open("Tests/images/rgb.jpg")
|
im1 = Image.open("Tests/images/rgb.jpg")
|
||||||
icc_profile = im1.info["icc_profile"]
|
icc_profile = im1.info["icc_profile"]
|
||||||
assert_equal(len(icc_profile), 3144)
|
self.assertEqual(len(icc_profile), 3144)
|
||||||
# Roundtrip via physical file.
|
# Roundtrip via physical file.
|
||||||
f = tempfile("temp.jpg")
|
f = self.tempfile("temp.jpg")
|
||||||
im1.save(f, icc_profile=icc_profile)
|
im1.save(f, icc_profile=icc_profile)
|
||||||
im2 = Image.open(f)
|
im2 = Image.open(f)
|
||||||
assert_equal(im2.info.get("icc_profile"), icc_profile)
|
self.assertEqual(im2.info.get("icc_profile"), icc_profile)
|
||||||
# Roundtrip via memory buffer.
|
# Roundtrip via memory buffer.
|
||||||
im1 = roundtrip(lena())
|
im1 = self.roundtrip(lena())
|
||||||
im2 = roundtrip(lena(), icc_profile=icc_profile)
|
im2 = self.roundtrip(lena(), icc_profile=icc_profile)
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
assert_false(im1.info.get("icc_profile"))
|
self.assertFalse(im1.info.get("icc_profile"))
|
||||||
assert_true(im2.info.get("icc_profile"))
|
self.assertTrue(im2.info.get("icc_profile"))
|
||||||
|
|
||||||
|
def test_icc_big(self):
|
||||||
def test_icc_big():
|
|
||||||
# Make sure that the "extra" support handles large blocks
|
# Make sure that the "extra" support handles large blocks
|
||||||
def test(n):
|
def test(n):
|
||||||
# The ICC APP marker can store 65519 bytes per marker, so
|
# The ICC APP marker can store 65519 bytes per marker, so
|
||||||
|
@ -104,8 +105,8 @@ def test_icc_big():
|
||||||
# order issues.
|
# order issues.
|
||||||
icc_profile = (b"Test"*int(n/4+1))[:n]
|
icc_profile = (b"Test"*int(n/4+1))[:n]
|
||||||
assert len(icc_profile) == n # sanity
|
assert len(icc_profile) == n # sanity
|
||||||
im1 = roundtrip(lena(), icc_profile=icc_profile)
|
im1 = self.roundtrip(lena(), icc_profile=icc_profile)
|
||||||
assert_equal(im1.info.get("icc_profile"), icc_profile or None)
|
self.assertEqual(im1.info.get("icc_profile"), icc_profile or None)
|
||||||
test(0)
|
test(0)
|
||||||
test(1)
|
test(1)
|
||||||
test(3)
|
test(3)
|
||||||
|
@ -117,38 +118,33 @@ def test_icc_big():
|
||||||
test(ImageFile.MAXBLOCK+1) # full buffer block plus one byte
|
test(ImageFile.MAXBLOCK+1) # full buffer block plus one byte
|
||||||
test(ImageFile.MAXBLOCK*4+3) # large block
|
test(ImageFile.MAXBLOCK*4+3) # large block
|
||||||
|
|
||||||
|
def test_optimize(self):
|
||||||
|
im1 = self.roundtrip(lena())
|
||||||
|
im2 = self.roundtrip(lena(), optimize=1)
|
||||||
|
self.assert_image_equal(im1, im2)
|
||||||
|
self.assertGreaterEqual(im1.bytes, im2.bytes)
|
||||||
|
|
||||||
def test_optimize():
|
def test_optimize_large_buffer(self):
|
||||||
im1 = roundtrip(lena())
|
# https://github.com/python-pillow/Pillow/issues/148
|
||||||
im2 = roundtrip(lena(), optimize=1)
|
f = self.tempfile('temp.jpg')
|
||||||
assert_image_equal(im1, im2)
|
|
||||||
assert_true(im1.bytes >= im2.bytes)
|
|
||||||
|
|
||||||
|
|
||||||
def test_optimize_large_buffer():
|
|
||||||
# https://github.com/python-imaging/Pillow/issues/148
|
|
||||||
f = tempfile('temp.jpg')
|
|
||||||
# this requires ~ 1.5x Image.MAXBLOCK
|
# this requires ~ 1.5x Image.MAXBLOCK
|
||||||
im = Image.new("RGB", (4096, 4096), 0xff3333)
|
im = Image.new("RGB", (4096, 4096), 0xff3333)
|
||||||
im.save(f, format="JPEG", optimize=True)
|
im.save(f, format="JPEG", optimize=True)
|
||||||
|
|
||||||
|
def test_progressive(self):
|
||||||
|
im1 = self.roundtrip(lena())
|
||||||
|
im2 = self.roundtrip(lena(), progressive=True)
|
||||||
|
self.assert_image_equal(im1, im2)
|
||||||
|
self.assertGreaterEqual(im1.bytes, im2.bytes)
|
||||||
|
|
||||||
def test_progressive():
|
def test_progressive_large_buffer(self):
|
||||||
im1 = roundtrip(lena())
|
f = self.tempfile('temp.jpg')
|
||||||
im2 = roundtrip(lena(), progressive=True)
|
|
||||||
assert_image_equal(im1, im2)
|
|
||||||
assert_true(im1.bytes >= im2.bytes)
|
|
||||||
|
|
||||||
|
|
||||||
def test_progressive_large_buffer():
|
|
||||||
f = tempfile('temp.jpg')
|
|
||||||
# this requires ~ 1.5x Image.MAXBLOCK
|
# this requires ~ 1.5x Image.MAXBLOCK
|
||||||
im = Image.new("RGB", (4096, 4096), 0xff3333)
|
im = Image.new("RGB", (4096, 4096), 0xff3333)
|
||||||
im.save(f, format="JPEG", progressive=True)
|
im.save(f, format="JPEG", progressive=True)
|
||||||
|
|
||||||
|
def test_progressive_large_buffer_highest_quality(self):
|
||||||
def test_progressive_large_buffer_highest_quality():
|
f = self.tempfile('temp.jpg')
|
||||||
f = tempfile('temp.jpg')
|
|
||||||
if py3:
|
if py3:
|
||||||
a = bytes(random.randint(0, 255) for _ in range(256 * 256 * 3))
|
a = bytes(random.randint(0, 255) for _ in range(256 * 256 * 3))
|
||||||
else:
|
else:
|
||||||
|
@ -157,89 +153,85 @@ def test_progressive_large_buffer_highest_quality():
|
||||||
# this requires more bytes than pixels in the image
|
# this requires more bytes than pixels in the image
|
||||||
im.save(f, format="JPEG", progressive=True, quality=100)
|
im.save(f, format="JPEG", progressive=True, quality=100)
|
||||||
|
|
||||||
|
def test_large_exif(self):
|
||||||
def test_large_exif():
|
# https://github.com/python-pillow/Pillow/issues/148
|
||||||
# https://github.com/python-imaging/Pillow/issues/148
|
f = self.tempfile('temp.jpg')
|
||||||
f = tempfile('temp.jpg')
|
|
||||||
im = lena()
|
im = lena()
|
||||||
im.save(f, 'JPEG', quality=90, exif=b"1"*65532)
|
im.save(f, 'JPEG', quality=90, exif=b"1"*65532)
|
||||||
|
|
||||||
|
def test_progressive_compat(self):
|
||||||
|
im1 = self.roundtrip(lena())
|
||||||
|
im2 = self.roundtrip(lena(), progressive=1)
|
||||||
|
im3 = self.roundtrip(lena(), progression=1) # compatibility
|
||||||
|
self.assert_image_equal(im1, im2)
|
||||||
|
self.assert_image_equal(im1, im3)
|
||||||
|
self.assertFalse(im1.info.get("progressive"))
|
||||||
|
self.assertFalse(im1.info.get("progression"))
|
||||||
|
self.assertTrue(im2.info.get("progressive"))
|
||||||
|
self.assertTrue(im2.info.get("progression"))
|
||||||
|
self.assertTrue(im3.info.get("progressive"))
|
||||||
|
self.assertTrue(im3.info.get("progression"))
|
||||||
|
|
||||||
def test_progressive_compat():
|
def test_quality(self):
|
||||||
im1 = roundtrip(lena())
|
im1 = self.roundtrip(lena())
|
||||||
im2 = roundtrip(lena(), progressive=1)
|
im2 = self.roundtrip(lena(), quality=50)
|
||||||
im3 = roundtrip(lena(), progression=1) # compatibility
|
self.assert_image(im1, im2.mode, im2.size)
|
||||||
assert_image_equal(im1, im2)
|
self.assertGreaterEqual(im1.bytes, im2.bytes)
|
||||||
assert_image_equal(im1, im3)
|
|
||||||
assert_false(im1.info.get("progressive"))
|
|
||||||
assert_false(im1.info.get("progression"))
|
|
||||||
assert_true(im2.info.get("progressive"))
|
|
||||||
assert_true(im2.info.get("progression"))
|
|
||||||
assert_true(im3.info.get("progressive"))
|
|
||||||
assert_true(im3.info.get("progression"))
|
|
||||||
|
|
||||||
|
def test_smooth(self):
|
||||||
|
im1 = self.roundtrip(lena())
|
||||||
|
im2 = self.roundtrip(lena(), smooth=100)
|
||||||
|
self.assert_image(im1, im2.mode, im2.size)
|
||||||
|
|
||||||
def test_quality():
|
def test_subsampling(self):
|
||||||
im1 = roundtrip(lena())
|
|
||||||
im2 = roundtrip(lena(), quality=50)
|
|
||||||
assert_image(im1, im2.mode, im2.size)
|
|
||||||
assert_true(im1.bytes >= im2.bytes)
|
|
||||||
|
|
||||||
|
|
||||||
def test_smooth():
|
|
||||||
im1 = roundtrip(lena())
|
|
||||||
im2 = roundtrip(lena(), smooth=100)
|
|
||||||
assert_image(im1, im2.mode, im2.size)
|
|
||||||
|
|
||||||
|
|
||||||
def test_subsampling():
|
|
||||||
def getsampling(im):
|
def getsampling(im):
|
||||||
layer = im.layer
|
layer = im.layer
|
||||||
return layer[0][1:3] + layer[1][1:3] + layer[2][1:3]
|
return layer[0][1:3] + layer[1][1:3] + layer[2][1:3]
|
||||||
# experimental API
|
# experimental API
|
||||||
im = roundtrip(lena(), subsampling=-1) # default
|
im = self.roundtrip(lena(), subsampling=-1) # default
|
||||||
assert_equal(getsampling(im), (2, 2, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (2, 2, 1, 1, 1, 1))
|
||||||
im = roundtrip(lena(), subsampling=0) # 4:4:4
|
im = self.roundtrip(lena(), subsampling=0) # 4:4:4
|
||||||
assert_equal(getsampling(im), (1, 1, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (1, 1, 1, 1, 1, 1))
|
||||||
im = roundtrip(lena(), subsampling=1) # 4:2:2
|
im = self.roundtrip(lena(), subsampling=1) # 4:2:2
|
||||||
assert_equal(getsampling(im), (2, 1, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (2, 1, 1, 1, 1, 1))
|
||||||
im = roundtrip(lena(), subsampling=2) # 4:1:1
|
im = self.roundtrip(lena(), subsampling=2) # 4:1:1
|
||||||
assert_equal(getsampling(im), (2, 2, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (2, 2, 1, 1, 1, 1))
|
||||||
im = roundtrip(lena(), subsampling=3) # default (undefined)
|
im = self.roundtrip(lena(), subsampling=3) # default (undefined)
|
||||||
assert_equal(getsampling(im), (2, 2, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (2, 2, 1, 1, 1, 1))
|
||||||
|
|
||||||
im = roundtrip(lena(), subsampling="4:4:4")
|
im = self.roundtrip(lena(), subsampling="4:4:4")
|
||||||
assert_equal(getsampling(im), (1, 1, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (1, 1, 1, 1, 1, 1))
|
||||||
im = roundtrip(lena(), subsampling="4:2:2")
|
im = self.roundtrip(lena(), subsampling="4:2:2")
|
||||||
assert_equal(getsampling(im), (2, 1, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (2, 1, 1, 1, 1, 1))
|
||||||
im = roundtrip(lena(), subsampling="4:1:1")
|
im = self.roundtrip(lena(), subsampling="4:1:1")
|
||||||
assert_equal(getsampling(im), (2, 2, 1, 1, 1, 1))
|
self.assertEqual(getsampling(im), (2, 2, 1, 1, 1, 1))
|
||||||
|
|
||||||
assert_exception(TypeError, lambda: roundtrip(lena(), subsampling="1:1:1"))
|
self.assertRaises(
|
||||||
|
TypeError, lambda: self.roundtrip(lena(), subsampling="1:1:1"))
|
||||||
|
|
||||||
|
def test_exif(self):
|
||||||
def test_exif():
|
|
||||||
im = Image.open("Tests/images/pil_sample_rgb.jpg")
|
im = Image.open("Tests/images/pil_sample_rgb.jpg")
|
||||||
info = im._getexif()
|
info = im._getexif()
|
||||||
assert_equal(info[305], 'Adobe Photoshop CS Macintosh')
|
self.assertEqual(info[305], 'Adobe Photoshop CS Macintosh')
|
||||||
|
|
||||||
|
def test_quality_keep(self):
|
||||||
|
im = Image.open("Tests/images/lena.jpg")
|
||||||
|
f = self.tempfile('temp.jpg')
|
||||||
|
im.save(f, quality='keep')
|
||||||
|
|
||||||
def test_quality_keep():
|
def test_junk_jpeg_header(self):
|
||||||
im = Image.open("Images/lena.jpg")
|
# https://github.com/python-pillow/Pillow/issues/630
|
||||||
f = tempfile('temp.jpg')
|
|
||||||
assert_no_exception(lambda: im.save(f, quality='keep'))
|
|
||||||
|
|
||||||
|
|
||||||
def test_qtables():
|
|
||||||
im = Image.open("Images/lena.jpg")
|
|
||||||
qtables = im.quantization
|
|
||||||
f = tempfile('temp.jpg')
|
|
||||||
assert_no_exception(lambda: im.save(f, qtables=qtables, subsampling=0))
|
|
||||||
|
|
||||||
|
|
||||||
def test_junk_jpeg_header():
|
|
||||||
# https://github.com/python-imaging/Pillow/issues/630
|
|
||||||
filename = "Tests/images/junk_jpeg_header.jpg"
|
filename = "Tests/images/junk_jpeg_header.jpg"
|
||||||
assert_no_exception(lambda: Image.open(filename))
|
Image.open(filename)
|
||||||
|
|
||||||
|
def test_qtables():
|
||||||
|
im = Image.open("Tests/images/lena.jpg")
|
||||||
|
qtables = im.quantization
|
||||||
|
reloaded = self.roundtrip(im, qtables=qtables, subsampling=0)
|
||||||
|
self.assertEqual(im.quantization, reloaded.quantization)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
# End of file
|
# End of file
|
||||||
|
|
|
@ -1,21 +1,25 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
from PIL import ImageFile
|
from io import BytesIO
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if "jpeg2k_encoder" not in codecs or "jpeg2k_decoder" not in codecs:
|
|
||||||
skip('JPEG 2000 support not available')
|
|
||||||
|
|
||||||
# OpenJPEG 2.0.0 outputs this debugging message sometimes; we should
|
|
||||||
# ignore it---it doesn't represent a test failure.
|
|
||||||
ignore('Not enough memory to handle tile data')
|
|
||||||
|
|
||||||
test_card = Image.open('Tests/images/test-card.png')
|
test_card = Image.open('Tests/images/test-card.png')
|
||||||
test_card.load()
|
test_card.load()
|
||||||
|
|
||||||
def roundtrip(im, **options):
|
# OpenJPEG 2.0.0 outputs this debugging message sometimes; we should
|
||||||
|
# ignore it---it doesn't represent a test failure.
|
||||||
|
# 'Not enough memory to handle tile data'
|
||||||
|
|
||||||
|
|
||||||
|
class TestFileJpeg2k(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "jpeg2k_encoder" not in codecs or "jpeg2k_decoder" not in codecs:
|
||||||
|
self.skipTest('JPEG 2000 support not available')
|
||||||
|
|
||||||
|
def roundtrip(self, im, **options):
|
||||||
out = BytesIO()
|
out = BytesIO()
|
||||||
im.save(out, "JPEG2000", **options)
|
im.save(out, "JPEG2000", **options)
|
||||||
bytes = out.tell()
|
bytes = out.tell()
|
||||||
|
@ -25,74 +29,68 @@ def roundtrip(im, **options):
|
||||||
im.load()
|
im.load()
|
||||||
return im
|
return im
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
def test_sanity(self):
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
# Internal version number
|
# Internal version number
|
||||||
assert_match(Image.core.jp2klib_version, '\d+\.\d+\.\d+$')
|
self.assertRegexpMatches(Image.core.jp2klib_version, '\d+\.\d+\.\d+$')
|
||||||
|
|
||||||
im = Image.open('Tests/images/test-card-lossless.jp2')
|
im = Image.open('Tests/images/test-card-lossless.jp2')
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, 'RGB')
|
self.assertEqual(im.mode, 'RGB')
|
||||||
assert_equal(im.size, (640, 480))
|
self.assertEqual(im.size, (640, 480))
|
||||||
assert_equal(im.format, 'JPEG2000')
|
self.assertEqual(im.format, 'JPEG2000')
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
# These two test pre-written JPEG 2000 files that were not written with
|
||||||
|
# PIL (they were made using Adobe Photoshop)
|
||||||
|
|
||||||
# These two test pre-written JPEG 2000 files that were not written with
|
def test_lossless(self):
|
||||||
# PIL (they were made using Adobe Photoshop)
|
|
||||||
|
|
||||||
def test_lossless():
|
|
||||||
im = Image.open('Tests/images/test-card-lossless.jp2')
|
im = Image.open('Tests/images/test-card-lossless.jp2')
|
||||||
im.load()
|
im.load()
|
||||||
im.save('/tmp/test-card.png')
|
im.save('/tmp/test-card.png')
|
||||||
assert_image_similar(im, test_card, 1.0e-3)
|
self.assert_image_similar(im, test_card, 1.0e-3)
|
||||||
|
|
||||||
def test_lossy_tiled():
|
def test_lossy_tiled(self):
|
||||||
im = Image.open('Tests/images/test-card-lossy-tiled.jp2')
|
im = Image.open('Tests/images/test-card-lossy-tiled.jp2')
|
||||||
im.load()
|
im.load()
|
||||||
assert_image_similar(im, test_card, 2.0)
|
self.assert_image_similar(im, test_card, 2.0)
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
def test_lossless_rt(self):
|
||||||
|
im = self.roundtrip(test_card)
|
||||||
|
self.assert_image_equal(im, test_card)
|
||||||
|
|
||||||
def test_lossless_rt():
|
def test_lossy_rt(self):
|
||||||
im = roundtrip(test_card)
|
im = self.roundtrip(test_card, quality_layers=[20])
|
||||||
assert_image_equal(im, test_card)
|
self.assert_image_similar(im, test_card, 2.0)
|
||||||
|
|
||||||
def test_lossy_rt():
|
def test_tiled_rt(self):
|
||||||
im = roundtrip(test_card, quality_layers=[20])
|
im = self.roundtrip(test_card, tile_size=(128, 128))
|
||||||
assert_image_similar(im, test_card, 2.0)
|
self.assert_image_equal(im, test_card)
|
||||||
|
|
||||||
def test_tiled_rt():
|
def test_tiled_offset_rt(self):
|
||||||
im = roundtrip(test_card, tile_size=(128, 128))
|
im = self.roundtrip(
|
||||||
assert_image_equal(im, test_card)
|
test_card, tile_size=(128, 128),
|
||||||
|
tile_offset=(0, 0), offset=(32, 32))
|
||||||
|
self.assert_image_equal(im, test_card)
|
||||||
|
|
||||||
def test_tiled_offset_rt():
|
def test_irreversible_rt(self):
|
||||||
im = roundtrip(test_card, tile_size=(128, 128), tile_offset=(0, 0),
|
im = self.roundtrip(test_card, irreversible=True, quality_layers=[20])
|
||||||
offset=(32, 32))
|
self.assert_image_similar(im, test_card, 2.0)
|
||||||
assert_image_equal(im, test_card)
|
|
||||||
|
|
||||||
def test_irreversible_rt():
|
def test_prog_qual_rt(self):
|
||||||
im = roundtrip(test_card, irreversible=True, quality_layers=[20])
|
im = self.roundtrip(
|
||||||
assert_image_similar(im, test_card, 2.0)
|
test_card, quality_layers=[60, 40, 20], progression='LRCP')
|
||||||
|
self.assert_image_similar(im, test_card, 2.0)
|
||||||
|
|
||||||
def test_prog_qual_rt():
|
def test_prog_res_rt(self):
|
||||||
im = roundtrip(test_card, quality_layers=[60, 40, 20], progression='LRCP')
|
im = self.roundtrip(test_card, num_resolutions=8, progression='RLCP')
|
||||||
assert_image_similar(im, test_card, 2.0)
|
self.assert_image_equal(im, test_card)
|
||||||
|
|
||||||
def test_prog_res_rt():
|
def test_reduce(self):
|
||||||
im = roundtrip(test_card, num_resolutions=8, progression='RLCP')
|
|
||||||
assert_image_equal(im, test_card)
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
def test_reduce():
|
|
||||||
im = Image.open('Tests/images/test-card-lossless.jp2')
|
im = Image.open('Tests/images/test-card-lossless.jp2')
|
||||||
im.reduce = 2
|
im.reduce = 2
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.size, (160, 120))
|
self.assertEqual(im.size, (160, 120))
|
||||||
|
|
||||||
def test_layers():
|
def test_layers(self):
|
||||||
out = BytesIO()
|
out = BytesIO()
|
||||||
test_card.save(out, 'JPEG2000', quality_layers=[100, 50, 10],
|
test_card.save(out, 'JPEG2000', quality_layers=[100, 50, 10],
|
||||||
progression='LRCP')
|
progression='LRCP')
|
||||||
|
@ -101,10 +99,16 @@ def test_layers():
|
||||||
im = Image.open(out)
|
im = Image.open(out)
|
||||||
im.layers = 1
|
im.layers = 1
|
||||||
im.load()
|
im.load()
|
||||||
assert_image_similar(im, test_card, 13)
|
self.assert_image_similar(im, test_card, 13)
|
||||||
|
|
||||||
out.seek(0)
|
out.seek(0)
|
||||||
im = Image.open(out)
|
im = Image.open(out)
|
||||||
im.layers = 3
|
im.layers = 3
|
||||||
im.load()
|
im.load()
|
||||||
assert_image_similar(im, test_card, 0.4)
|
self.assert_image_similar(im, test_card, 0.4)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,221 +1,233 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena, py3
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from PIL import Image, TiffImagePlugin
|
from PIL import Image, TiffImagePlugin
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
|
||||||
|
|
||||||
if "libtiff_encoder" not in codecs or "libtiff_decoder" not in codecs:
|
class TestFileLibTiff(PillowTestCase):
|
||||||
skip("tiff support not available")
|
|
||||||
|
|
||||||
def _assert_noerr(im):
|
def setUp(self):
|
||||||
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
|
if "libtiff_encoder" not in codecs or "libtiff_decoder" not in codecs:
|
||||||
|
self.skipTest("tiff support not available")
|
||||||
|
|
||||||
|
def _assert_noerr(self, im):
|
||||||
"""Helper tests that assert basic sanity about the g4 tiff reading"""
|
"""Helper tests that assert basic sanity about the g4 tiff reading"""
|
||||||
#1 bit
|
# 1 bit
|
||||||
assert_equal(im.mode, "1")
|
self.assertEqual(im.mode, "1")
|
||||||
|
|
||||||
# Does the data actually load
|
# Does the data actually load
|
||||||
assert_no_exception(lambda: im.load())
|
im.load()
|
||||||
assert_no_exception(lambda: im.getdata())
|
im.getdata()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
assert_equal(im._compression, 'group4')
|
self.assertEqual(im._compression, 'group4')
|
||||||
except:
|
except:
|
||||||
print("No _compression")
|
print("No _compression")
|
||||||
print (dir(im))
|
print (dir(im))
|
||||||
|
|
||||||
# can we write it back out, in a different form.
|
# can we write it back out, in a different form.
|
||||||
out = tempfile("temp.png")
|
out = self.tempfile("temp.png")
|
||||||
assert_no_exception(lambda: im.save(out))
|
im.save(out)
|
||||||
|
|
||||||
def test_g4_tiff():
|
def test_g4_tiff(self):
|
||||||
"""Test the ordinary file path load path"""
|
"""Test the ordinary file path load path"""
|
||||||
|
|
||||||
file = "Tests/images/lena_g4_500.tif"
|
file = "Tests/images/lena_g4_500.tif"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_equal(im.size, (500,500))
|
self.assertEqual(im.size, (500, 500))
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
def test_g4_large():
|
def test_g4_large(self):
|
||||||
file = "Tests/images/pport_g4.tif"
|
file = "Tests/images/pport_g4.tif"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
def test_g4_tiff_file():
|
def test_g4_tiff_file(self):
|
||||||
"""Testing the string load path"""
|
"""Testing the string load path"""
|
||||||
|
|
||||||
file = "Tests/images/lena_g4_500.tif"
|
file = "Tests/images/lena_g4_500.tif"
|
||||||
with open(file,'rb') as f:
|
with open(file, 'rb') as f:
|
||||||
im = Image.open(f)
|
im = Image.open(f)
|
||||||
|
|
||||||
assert_equal(im.size, (500,500))
|
self.assertEqual(im.size, (500, 500))
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
def test_g4_tiff_bytesio():
|
def test_g4_tiff_bytesio(self):
|
||||||
"""Testing the stringio loading code path"""
|
"""Testing the stringio loading code path"""
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
file = "Tests/images/lena_g4_500.tif"
|
file = "Tests/images/lena_g4_500.tif"
|
||||||
s = BytesIO()
|
s = BytesIO()
|
||||||
with open(file,'rb') as f:
|
with open(file, 'rb') as f:
|
||||||
s.write(f.read())
|
s.write(f.read())
|
||||||
s.seek(0)
|
s.seek(0)
|
||||||
im = Image.open(s)
|
im = Image.open(s)
|
||||||
|
|
||||||
assert_equal(im.size, (500,500))
|
self.assertEqual(im.size, (500, 500))
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
def test_g4_eq_png():
|
def test_g4_eq_png(self):
|
||||||
""" Checking that we're actually getting the data that we expect"""
|
""" Checking that we're actually getting the data that we expect"""
|
||||||
png = Image.open('Tests/images/lena_bw_500.png')
|
png = Image.open('Tests/images/lena_bw_500.png')
|
||||||
g4 = Image.open('Tests/images/lena_g4_500.tif')
|
g4 = Image.open('Tests/images/lena_g4_500.tif')
|
||||||
|
|
||||||
assert_image_equal(g4, png)
|
self.assert_image_equal(g4, png)
|
||||||
|
|
||||||
# see https://github.com/python-imaging/Pillow/issues/279
|
# see https://github.com/python-pillow/Pillow/issues/279
|
||||||
def test_g4_fillorder_eq_png():
|
def test_g4_fillorder_eq_png(self):
|
||||||
""" Checking that we're actually getting the data that we expect"""
|
""" Checking that we're actually getting the data that we expect"""
|
||||||
png = Image.open('Tests/images/g4-fillorder-test.png')
|
png = Image.open('Tests/images/g4-fillorder-test.png')
|
||||||
g4 = Image.open('Tests/images/g4-fillorder-test.tif')
|
g4 = Image.open('Tests/images/g4-fillorder-test.tif')
|
||||||
|
|
||||||
assert_image_equal(g4, png)
|
self.assert_image_equal(g4, png)
|
||||||
|
|
||||||
def test_g4_write():
|
def test_g4_write(self):
|
||||||
"""Checking to see that the saved image is the same as what we wrote"""
|
"""Checking to see that the saved image is the same as what we wrote"""
|
||||||
file = "Tests/images/lena_g4_500.tif"
|
file = "Tests/images/lena_g4_500.tif"
|
||||||
orig = Image.open(file)
|
orig = Image.open(file)
|
||||||
|
|
||||||
out = tempfile("temp.tif")
|
out = self.tempfile("temp.tif")
|
||||||
rot = orig.transpose(Image.ROTATE_90)
|
rot = orig.transpose(Image.ROTATE_90)
|
||||||
assert_equal(rot.size,(500,500))
|
self.assertEqual(rot.size, (500, 500))
|
||||||
rot.save(out)
|
rot.save(out)
|
||||||
|
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
assert_equal(reread.size,(500,500))
|
self.assertEqual(reread.size, (500, 500))
|
||||||
_assert_noerr(reread)
|
self._assert_noerr(reread)
|
||||||
assert_image_equal(reread, rot)
|
self.assert_image_equal(reread, rot)
|
||||||
assert_equal(reread.info['compression'], 'group4')
|
self.assertEqual(reread.info['compression'], 'group4')
|
||||||
|
|
||||||
assert_equal(reread.info['compression'], orig.info['compression'])
|
self.assertEqual(reread.info['compression'], orig.info['compression'])
|
||||||
|
|
||||||
assert_false(orig.tobytes() == reread.tobytes())
|
self.assertNotEqual(orig.tobytes(), reread.tobytes())
|
||||||
|
|
||||||
def test_adobe_deflate_tiff():
|
def test_adobe_deflate_tiff(self):
|
||||||
file = "Tests/images/tiff_adobe_deflate.tif"
|
file = "Tests/images/tiff_adobe_deflate.tif"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (278, 374))
|
self.assertEqual(im.size, (278, 374))
|
||||||
assert_equal(im.tile[0][:3], ('tiff_adobe_deflate', (0, 0, 278, 374), 0))
|
self.assertEqual(
|
||||||
assert_no_exception(lambda: im.load())
|
im.tile[0][:3], ('tiff_adobe_deflate', (0, 0, 278, 374), 0))
|
||||||
|
im.load()
|
||||||
|
|
||||||
def test_write_metadata():
|
def test_write_metadata(self):
|
||||||
""" Test metadata writing through libtiff """
|
""" Test metadata writing through libtiff """
|
||||||
img = Image.open('Tests/images/lena_g4.tif')
|
img = Image.open('Tests/images/lena_g4.tif')
|
||||||
f = tempfile('temp.tiff')
|
f = self.tempfile('temp.tiff')
|
||||||
|
|
||||||
img.save(f, tiffinfo = img.tag)
|
img.save(f, tiffinfo=img.tag)
|
||||||
|
|
||||||
loaded = Image.open(f)
|
loaded = Image.open(f)
|
||||||
|
|
||||||
original = img.tag.named()
|
original = img.tag.named()
|
||||||
reloaded = loaded.tag.named()
|
reloaded = loaded.tag.named()
|
||||||
|
|
||||||
# PhotometricInterpretation is set from SAVE_INFO, not the original image.
|
# PhotometricInterpretation is set from SAVE_INFO,
|
||||||
ignored = ['StripByteCounts', 'RowsPerStrip', 'PageNumber', 'PhotometricInterpretation']
|
# not the original image.
|
||||||
|
ignored = [
|
||||||
|
'StripByteCounts', 'RowsPerStrip',
|
||||||
|
'PageNumber', 'PhotometricInterpretation']
|
||||||
|
|
||||||
for tag, value in reloaded.items():
|
for tag, value in reloaded.items():
|
||||||
if tag not in ignored:
|
if tag not in ignored:
|
||||||
if tag.endswith('Resolution'):
|
if tag.endswith('Resolution'):
|
||||||
val = original[tag]
|
val = original[tag]
|
||||||
assert_almost_equal(val[0][0]/val[0][1], value[0][0]/value[0][1],
|
self.assert_almost_equal(
|
||||||
|
val[0][0]/val[0][1], value[0][0]/value[0][1],
|
||||||
msg="%s didn't roundtrip" % tag)
|
msg="%s didn't roundtrip" % tag)
|
||||||
else:
|
else:
|
||||||
assert_equal(original[tag], value, "%s didn't roundtrip" % tag)
|
self.assertEqual(
|
||||||
|
original[tag], value, "%s didn't roundtrip" % tag)
|
||||||
|
|
||||||
for tag, value in original.items():
|
for tag, value in original.items():
|
||||||
if tag not in ignored:
|
if tag not in ignored:
|
||||||
if tag.endswith('Resolution'):
|
if tag.endswith('Resolution'):
|
||||||
val = reloaded[tag]
|
val = reloaded[tag]
|
||||||
assert_almost_equal(val[0][0]/val[0][1], value[0][0]/value[0][1],
|
self.assert_almost_equal(
|
||||||
|
val[0][0]/val[0][1], value[0][0]/value[0][1],
|
||||||
msg="%s didn't roundtrip" % tag)
|
msg="%s didn't roundtrip" % tag)
|
||||||
else:
|
else:
|
||||||
assert_equal(value, reloaded[tag], "%s didn't roundtrip" % tag)
|
self.assertEqual(
|
||||||
|
value, reloaded[tag], "%s didn't roundtrip" % tag)
|
||||||
|
|
||||||
|
def test_g3_compression(self):
|
||||||
def test_g3_compression():
|
|
||||||
i = Image.open('Tests/images/lena_g4_500.tif')
|
i = Image.open('Tests/images/lena_g4_500.tif')
|
||||||
out = tempfile("temp.tif")
|
out = self.tempfile("temp.tif")
|
||||||
i.save(out, compression='group3')
|
i.save(out, compression='group3')
|
||||||
|
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
assert_equal(reread.info['compression'], 'group3')
|
self.assertEqual(reread.info['compression'], 'group3')
|
||||||
assert_image_equal(reread, i)
|
self.assert_image_equal(reread, i)
|
||||||
|
|
||||||
def test_little_endian():
|
def test_little_endian(self):
|
||||||
im = Image.open('Tests/images/16bit.deflate.tif')
|
im = Image.open('Tests/images/16bit.deflate.tif')
|
||||||
assert_equal(im.getpixel((0,0)), 480)
|
self.assertEqual(im.getpixel((0, 0)), 480)
|
||||||
assert_equal(im.mode, 'I;16')
|
self.assertEqual(im.mode, 'I;16')
|
||||||
|
|
||||||
b = im.tobytes()
|
b = im.tobytes()
|
||||||
# Bytes are in image native order (little endian)
|
# Bytes are in image native order (little endian)
|
||||||
if py3:
|
if py3:
|
||||||
assert_equal(b[0], ord(b'\xe0'))
|
self.assertEqual(b[0], ord(b'\xe0'))
|
||||||
assert_equal(b[1], ord(b'\x01'))
|
self.assertEqual(b[1], ord(b'\x01'))
|
||||||
else:
|
else:
|
||||||
assert_equal(b[0], b'\xe0')
|
self.assertEqual(b[0], b'\xe0')
|
||||||
assert_equal(b[1], b'\x01')
|
self.assertEqual(b[1], b'\x01')
|
||||||
|
|
||||||
|
out = self.tempfile("temp.tif")
|
||||||
out = tempfile("temp.tif")
|
# out = "temp.le.tif"
|
||||||
#out = "temp.le.tif"
|
|
||||||
im.save(out)
|
im.save(out)
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
|
|
||||||
assert_equal(reread.info['compression'], im.info['compression'])
|
self.assertEqual(reread.info['compression'], im.info['compression'])
|
||||||
assert_equal(reread.getpixel((0,0)), 480)
|
self.assertEqual(reread.getpixel((0, 0)), 480)
|
||||||
# UNDONE - libtiff defaults to writing in native endian, so
|
# UNDONE - libtiff defaults to writing in native endian, so
|
||||||
# on big endian, we'll get back mode = 'I;16B' here.
|
# on big endian, we'll get back mode = 'I;16B' here.
|
||||||
|
|
||||||
def test_big_endian():
|
def test_big_endian(self):
|
||||||
im = Image.open('Tests/images/16bit.MM.deflate.tif')
|
im = Image.open('Tests/images/16bit.MM.deflate.tif')
|
||||||
|
|
||||||
assert_equal(im.getpixel((0,0)), 480)
|
self.assertEqual(im.getpixel((0, 0)), 480)
|
||||||
assert_equal(im.mode, 'I;16B')
|
self.assertEqual(im.mode, 'I;16B')
|
||||||
|
|
||||||
b = im.tobytes()
|
b = im.tobytes()
|
||||||
|
|
||||||
# Bytes are in image native order (big endian)
|
# Bytes are in image native order (big endian)
|
||||||
if py3:
|
if py3:
|
||||||
assert_equal(b[0], ord(b'\x01'))
|
self.assertEqual(b[0], ord(b'\x01'))
|
||||||
assert_equal(b[1], ord(b'\xe0'))
|
self.assertEqual(b[1], ord(b'\xe0'))
|
||||||
else:
|
else:
|
||||||
assert_equal(b[0], b'\x01')
|
self.assertEqual(b[0], b'\x01')
|
||||||
assert_equal(b[1], b'\xe0')
|
self.assertEqual(b[1], b'\xe0')
|
||||||
|
|
||||||
out = tempfile("temp.tif")
|
out = self.tempfile("temp.tif")
|
||||||
im.save(out)
|
im.save(out)
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
|
|
||||||
assert_equal(reread.info['compression'], im.info['compression'])
|
self.assertEqual(reread.info['compression'], im.info['compression'])
|
||||||
assert_equal(reread.getpixel((0,0)), 480)
|
self.assertEqual(reread.getpixel((0, 0)), 480)
|
||||||
|
|
||||||
def test_g4_string_info():
|
def test_g4_string_info(self):
|
||||||
"""Tests String data in info directory"""
|
"""Tests String data in info directory"""
|
||||||
file = "Tests/images/lena_g4_500.tif"
|
file = "Tests/images/lena_g4_500.tif"
|
||||||
orig = Image.open(file)
|
orig = Image.open(file)
|
||||||
|
|
||||||
out = tempfile("temp.tif")
|
out = self.tempfile("temp.tif")
|
||||||
|
|
||||||
orig.tag[269] = 'temp.tif'
|
orig.tag[269] = 'temp.tif'
|
||||||
orig.save(out)
|
orig.save(out)
|
||||||
|
|
||||||
reread = Image.open(out)
|
reread = Image.open(out)
|
||||||
assert_equal('temp.tif', reread.tag[269])
|
self.assertEqual('temp.tif', reread.tag[269])
|
||||||
|
|
||||||
def test_12bit_rawmode():
|
def test_12bit_rawmode(self):
|
||||||
""" Are we generating the same interpretation of the image as Imagemagick is? """
|
""" Are we generating the same interpretation
|
||||||
|
of the image as Imagemagick is? """
|
||||||
TiffImagePlugin.READ_LIBTIFF = True
|
TiffImagePlugin.READ_LIBTIFF = True
|
||||||
#Image.DEBUG = True
|
# Image.DEBUG = True
|
||||||
im = Image.open('Tests/images/12bit.cropped.tif')
|
im = Image.open('Tests/images/12bit.cropped.tif')
|
||||||
im.load()
|
im.load()
|
||||||
TiffImagePlugin.READ_LIBTIFF = False
|
TiffImagePlugin.READ_LIBTIFF = False
|
||||||
|
@ -228,73 +240,79 @@ def test_12bit_rawmode():
|
||||||
im2 = Image.open('Tests/images/12in16bit.tif')
|
im2 = Image.open('Tests/images/12in16bit.tif')
|
||||||
|
|
||||||
if Image.DEBUG:
|
if Image.DEBUG:
|
||||||
print (im.getpixel((0,0)))
|
print (im.getpixel((0, 0)))
|
||||||
print (im.getpixel((0,1)))
|
print (im.getpixel((0, 1)))
|
||||||
print (im.getpixel((0,2)))
|
print (im.getpixel((0, 2)))
|
||||||
|
|
||||||
print (im2.getpixel((0,0)))
|
print (im2.getpixel((0, 0)))
|
||||||
print (im2.getpixel((0,1)))
|
print (im2.getpixel((0, 1)))
|
||||||
print (im2.getpixel((0,2)))
|
print (im2.getpixel((0, 2)))
|
||||||
|
|
||||||
assert_image_equal(im, im2)
|
self.assert_image_equal(im, im2)
|
||||||
|
|
||||||
def test_blur():
|
def test_blur(self):
|
||||||
# test case from irc, how to do blur on b/w image and save to compressed tif.
|
# test case from irc, how to do blur on b/w image
|
||||||
|
# and save to compressed tif.
|
||||||
from PIL import ImageFilter
|
from PIL import ImageFilter
|
||||||
out = tempfile('temp.tif')
|
out = self.tempfile('temp.tif')
|
||||||
im = Image.open('Tests/images/pport_g4.tif')
|
im = Image.open('Tests/images/pport_g4.tif')
|
||||||
im = im.convert('L')
|
im = im.convert('L')
|
||||||
|
|
||||||
im=im.filter(ImageFilter.GaussianBlur(4))
|
im = im.filter(ImageFilter.GaussianBlur(4))
|
||||||
im.save(out, compression='tiff_adobe_deflate')
|
im.save(out, compression='tiff_adobe_deflate')
|
||||||
|
|
||||||
im2 = Image.open(out)
|
im2 = Image.open(out)
|
||||||
im2.load()
|
im2.load()
|
||||||
|
|
||||||
assert_image_equal(im, im2)
|
self.assert_image_equal(im, im2)
|
||||||
|
|
||||||
|
def test_compressions(self):
|
||||||
def test_compressions():
|
|
||||||
im = lena('RGB')
|
im = lena('RGB')
|
||||||
out = tempfile('temp.tif')
|
out = self.tempfile('temp.tif')
|
||||||
|
|
||||||
for compression in ('packbits', 'tiff_lzw'):
|
for compression in ('packbits', 'tiff_lzw'):
|
||||||
im.save(out, compression=compression)
|
im.save(out, compression=compression)
|
||||||
im2 = Image.open(out)
|
im2 = Image.open(out)
|
||||||
assert_image_equal(im, im2)
|
self.assert_image_equal(im, im2)
|
||||||
|
|
||||||
im.save(out, compression='jpeg')
|
im.save(out, compression='jpeg')
|
||||||
im2 = Image.open(out)
|
im2 = Image.open(out)
|
||||||
assert_image_similar(im, im2, 30)
|
self.assert_image_similar(im, im2, 30)
|
||||||
|
|
||||||
|
def test_cmyk_save(self):
|
||||||
def test_cmyk_save():
|
|
||||||
im = lena('CMYK')
|
im = lena('CMYK')
|
||||||
out = tempfile('temp.tif')
|
out = self.tempfile('temp.tif')
|
||||||
|
|
||||||
im.save(out, compression='tiff_adobe_deflate')
|
im.save(out, compression='tiff_adobe_deflate')
|
||||||
im2 = Image.open(out)
|
im2 = Image.open(out)
|
||||||
assert_image_equal(im, im2)
|
self.assert_image_equal(im, im2)
|
||||||
|
|
||||||
def xtest_bw_compression_wRGB():
|
def xtest_bw_compression_wRGB(self):
|
||||||
""" This test passes, but when running all tests causes a failure due to
|
""" This test passes, but when running all tests causes a failure due
|
||||||
output on stderr from the error thrown by libtiff. We need to capture that
|
to output on stderr from the error thrown by libtiff. We need to
|
||||||
but not now"""
|
capture that but not now"""
|
||||||
|
|
||||||
im = lena('RGB')
|
im = lena('RGB')
|
||||||
out = tempfile('temp.tif')
|
out = self.tempfile('temp.tif')
|
||||||
|
|
||||||
assert_exception(IOError, lambda: im.save(out, compression='tiff_ccitt'))
|
self.assertRaises(
|
||||||
assert_exception(IOError, lambda: im.save(out, compression='group3'))
|
IOError, lambda: im.save(out, compression='tiff_ccitt'))
|
||||||
assert_exception(IOError, lambda: im.save(out, compression='group4'))
|
self.assertRaises(IOError, lambda: im.save(out, compression='group3'))
|
||||||
|
self.assertRaises(IOError, lambda: im.save(out, compression='group4'))
|
||||||
|
|
||||||
def test_fp_leak():
|
def test_fp_leak(self):
|
||||||
im = Image.open("Tests/images/lena_g4_500.tif")
|
im = Image.open("Tests/images/lena_g4_500.tif")
|
||||||
fn = im.fp.fileno()
|
fn = im.fp.fileno()
|
||||||
|
|
||||||
assert_no_exception(lambda: os.fstat(fn))
|
os.fstat(fn)
|
||||||
im.load() # this should close it.
|
im.load() # this should close it.
|
||||||
assert_exception(OSError, lambda: os.fstat(fn))
|
self.assertRaises(OSError, lambda: os.fstat(fn))
|
||||||
im = None # this should force even more closed.
|
im = None # this should force even more closed.
|
||||||
assert_exception(OSError, lambda: os.fstat(fn))
|
self.assertRaises(OSError, lambda: os.fstat(fn))
|
||||||
assert_exception(OSError, lambda: os.close(fn))
|
self.assertRaises(OSError, lambda: os.close(fn))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
from tester import *
|
from helper import unittest, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
from test_file_libtiff import _assert_noerr
|
from test_file_libtiff import TestFileLibTiff
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
|
||||||
|
|
||||||
if "libtiff_encoder" not in codecs or "libtiff_decoder" not in codecs:
|
class TestFileLibTiffSmall(TestFileLibTiff):
|
||||||
skip("tiff support not available")
|
|
||||||
|
|
||||||
""" The small lena image was failing on open in the libtiff
|
# Inherits TestFileLibTiff's setUp() and self._assert_noerr()
|
||||||
|
|
||||||
|
""" The small lena image was failing on open in the libtiff
|
||||||
decoder because the file pointer was set to the wrong place
|
decoder because the file pointer was set to the wrong place
|
||||||
by a spurious seek. It wasn't failing with the byteio method.
|
by a spurious seek. It wasn't failing with the byteio method.
|
||||||
|
|
||||||
|
@ -17,36 +17,40 @@ if "libtiff_encoder" not in codecs or "libtiff_decoder" not in codecs:
|
||||||
file just before reading in libtiff. These tests remain
|
file just before reading in libtiff. These tests remain
|
||||||
to ensure that it stays fixed. """
|
to ensure that it stays fixed. """
|
||||||
|
|
||||||
|
def test_g4_lena_file(self):
|
||||||
def test_g4_lena_file():
|
|
||||||
"""Testing the open file load path"""
|
"""Testing the open file load path"""
|
||||||
|
|
||||||
file = "Tests/images/lena_g4.tif"
|
file = "Tests/images/lena_g4.tif"
|
||||||
with open(file,'rb') as f:
|
with open(file, 'rb') as f:
|
||||||
im = Image.open(f)
|
im = Image.open(f)
|
||||||
|
|
||||||
assert_equal(im.size, (128,128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
def test_g4_lena_bytesio():
|
def test_g4_lena_bytesio(self):
|
||||||
"""Testing the bytesio loading code path"""
|
"""Testing the bytesio loading code path"""
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
file = "Tests/images/lena_g4.tif"
|
file = "Tests/images/lena_g4.tif"
|
||||||
s = BytesIO()
|
s = BytesIO()
|
||||||
with open(file,'rb') as f:
|
with open(file, 'rb') as f:
|
||||||
s.write(f.read())
|
s.write(f.read())
|
||||||
s.seek(0)
|
s.seek(0)
|
||||||
im = Image.open(s)
|
im = Image.open(s)
|
||||||
|
|
||||||
assert_equal(im.size, (128,128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
def test_g4_lena():
|
def test_g4_lena(self):
|
||||||
"""The 128x128 lena image fails for some reason. Investigating"""
|
"""The 128x128 lena image fails for some reason. Investigating"""
|
||||||
|
|
||||||
file = "Tests/images/lena_g4.tif"
|
file = "Tests/images/lena_g4.tif"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_equal(im.size, (128,128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
_assert_noerr(im)
|
self._assert_noerr(im)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,15 +1,24 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
|
||||||
file = tempfile("temp.msp")
|
class TestFileMsp(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
|
file = self.tempfile("temp.msp")
|
||||||
|
|
||||||
lena("1").save(file)
|
lena("1").save(file)
|
||||||
|
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "1")
|
self.assertEqual(im.mode, "1")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "MSP")
|
self.assertEqual(im.format, "MSP")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,40 +1,47 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
|
||||||
def _roundtrip(im):
|
class TestFilePcx(PillowTestCase):
|
||||||
f = tempfile("temp.pcx")
|
|
||||||
|
def _roundtrip(self, im):
|
||||||
|
f = self.tempfile("temp.pcx")
|
||||||
im.save(f)
|
im.save(f)
|
||||||
im2 = Image.open(f)
|
im2 = Image.open(f)
|
||||||
|
|
||||||
assert_equal(im2.mode, im.mode)
|
self.assertEqual(im2.mode, im.mode)
|
||||||
assert_equal(im2.size, im.size)
|
self.assertEqual(im2.size, im.size)
|
||||||
assert_equal(im2.format, "PCX")
|
self.assertEqual(im2.format, "PCX")
|
||||||
assert_image_equal(im2, im)
|
self.assert_image_equal(im2, im)
|
||||||
|
|
||||||
def test_sanity():
|
def test_sanity(self):
|
||||||
for mode in ('1', 'L', 'P', 'RGB'):
|
for mode in ('1', 'L', 'P', 'RGB'):
|
||||||
_roundtrip(lena(mode))
|
self._roundtrip(lena(mode))
|
||||||
|
|
||||||
def test_odd():
|
def test_odd(self):
|
||||||
# see issue #523, odd sized images should have a stride that's even.
|
# see issue #523, odd sized images should have a stride that's even.
|
||||||
# not that imagemagick or gimp write pcx that way.
|
# not that imagemagick or gimp write pcx that way.
|
||||||
# we were not handling properly.
|
# we were not handling properly.
|
||||||
for mode in ('1', 'L', 'P', 'RGB'):
|
for mode in ('1', 'L', 'P', 'RGB'):
|
||||||
# larger, odd sized images are better here to ensure that
|
# larger, odd sized images are better here to ensure that
|
||||||
# we handle interrupted scan lines properly.
|
# we handle interrupted scan lines properly.
|
||||||
_roundtrip(lena(mode).resize((511,511)))
|
self._roundtrip(lena(mode).resize((511, 511)))
|
||||||
|
|
||||||
|
def test_pil184(self):
|
||||||
def test_pil184():
|
|
||||||
# Check reading of files where xmin/xmax is not zero.
|
# Check reading of files where xmin/xmax is not zero.
|
||||||
|
|
||||||
file = "Tests/images/pil184.pcx"
|
file = "Tests/images/pil184.pcx"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_equal(im.size, (447, 144))
|
self.assertEqual(im.size, (447, 144))
|
||||||
assert_equal(im.tile[0][1], (0, 0, 447, 144))
|
self.assertEqual(im.tile[0][1], (0, 0, 447, 144))
|
||||||
|
|
||||||
# Make sure all pixels are either 0 or 255.
|
# Make sure all pixels are either 0 or 255.
|
||||||
assert_equal(im.histogram()[0] + im.histogram()[255], 447*144)
|
self.assertEqual(im.histogram()[0] + im.histogram()[255], 447*144)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,58 +1,59 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
import os.path
|
import os.path
|
||||||
|
|
||||||
|
|
||||||
def helper_save_as_pdf(mode):
|
class TestFilePdf(PillowTestCase):
|
||||||
|
|
||||||
|
def helper_save_as_pdf(self, mode):
|
||||||
# Arrange
|
# Arrange
|
||||||
im = lena(mode)
|
im = lena(mode)
|
||||||
outfile = tempfile("temp_" + mode + ".pdf")
|
outfile = self.tempfile("temp_" + mode + ".pdf")
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
im.save(outfile)
|
im.save(outfile)
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert_true(os.path.isfile(outfile))
|
self.assertTrue(os.path.isfile(outfile))
|
||||||
assert_greater(os.path.getsize(outfile), 0)
|
self.assertGreater(os.path.getsize(outfile), 0)
|
||||||
|
|
||||||
|
def test_monochrome(self):
|
||||||
def test_monochrome():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = "1"
|
mode = "1"
|
||||||
|
|
||||||
# Act / Assert
|
# Act / Assert
|
||||||
helper_save_as_pdf(mode)
|
self.helper_save_as_pdf(mode)
|
||||||
|
|
||||||
|
def test_greyscale(self):
|
||||||
def test_greyscale():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = "L"
|
mode = "L"
|
||||||
|
|
||||||
# Act / Assert
|
# Act / Assert
|
||||||
helper_save_as_pdf(mode)
|
self.helper_save_as_pdf(mode)
|
||||||
|
|
||||||
|
def test_rgb(self):
|
||||||
def test_rgb():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = "RGB"
|
mode = "RGB"
|
||||||
|
|
||||||
# Act / Assert
|
# Act / Assert
|
||||||
helper_save_as_pdf(mode)
|
self.helper_save_as_pdf(mode)
|
||||||
|
|
||||||
|
def test_p_mode(self):
|
||||||
def test_p_mode():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = "P"
|
mode = "P"
|
||||||
|
|
||||||
# Act / Assert
|
# Act / Assert
|
||||||
helper_save_as_pdf(mode)
|
self.helper_save_as_pdf(mode)
|
||||||
|
|
||||||
|
def test_cmyk_mode(self):
|
||||||
def test_cmyk_mode():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = "CMYK"
|
mode = "CMYK"
|
||||||
|
|
||||||
# Act / Assert
|
# Act / Assert
|
||||||
helper_save_as_pdf(mode)
|
self.helper_save_as_pdf(mode)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
# End of file
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
from PIL import PngImagePlugin
|
from PIL import PngImagePlugin
|
||||||
|
@ -6,9 +8,6 @@ import zlib
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
|
||||||
skip("zip/deflate support not available")
|
|
||||||
|
|
||||||
# sample png stream
|
# sample png stream
|
||||||
|
|
||||||
file = "Images/lena.png"
|
file = "Images/lena.png"
|
||||||
|
@ -18,6 +17,7 @@ data = open(file, "rb").read()
|
||||||
|
|
||||||
MAGIC = PngImagePlugin._MAGIC
|
MAGIC = PngImagePlugin._MAGIC
|
||||||
|
|
||||||
|
|
||||||
def chunk(cid, *data):
|
def chunk(cid, *data):
|
||||||
file = BytesIO()
|
file = BytesIO()
|
||||||
PngImagePlugin.putchunk(*(file, cid) + data)
|
PngImagePlugin.putchunk(*(file, cid) + data)
|
||||||
|
@ -32,31 +32,39 @@ IEND = chunk(b"IEND")
|
||||||
HEAD = MAGIC + IHDR
|
HEAD = MAGIC + IHDR
|
||||||
TAIL = IDAT + IEND
|
TAIL = IDAT + IEND
|
||||||
|
|
||||||
|
|
||||||
def load(data):
|
def load(data):
|
||||||
return Image.open(BytesIO(data))
|
return Image.open(BytesIO(data))
|
||||||
|
|
||||||
|
|
||||||
def roundtrip(im, **options):
|
def roundtrip(im, **options):
|
||||||
out = BytesIO()
|
out = BytesIO()
|
||||||
im.save(out, "PNG", **options)
|
im.save(out, "PNG", **options)
|
||||||
out.seek(0)
|
out.seek(0)
|
||||||
return Image.open(out)
|
return Image.open(out)
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestFilePng(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
||||||
|
self.skipTest("zip/deflate support not available")
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
# internal version number
|
# internal version number
|
||||||
assert_match(Image.core.zlib_version, "\d+\.\d+\.\d+(\.\d+)?$")
|
self.assertRegexpMatches(
|
||||||
|
Image.core.zlib_version, "\d+\.\d+\.\d+(\.\d+)?$")
|
||||||
|
|
||||||
file = tempfile("temp.png")
|
file = self.tempfile("temp.png")
|
||||||
|
|
||||||
lena("RGB").save(file)
|
lena("RGB").save(file)
|
||||||
|
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "PNG")
|
self.assertEqual(im.format, "PNG")
|
||||||
|
|
||||||
lena("1").save(file)
|
lena("1").save(file)
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
@ -73,145 +81,145 @@ def test_sanity():
|
||||||
lena("I").save(file)
|
lena("I").save(file)
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
def test_broken(self):
|
||||||
|
|
||||||
def test_broken():
|
|
||||||
# Check reading of totally broken files. In this case, the test
|
# Check reading of totally broken files. In this case, the test
|
||||||
# file was checked into Subversion as a text file.
|
# file was checked into Subversion as a text file.
|
||||||
|
|
||||||
file = "Tests/images/broken.png"
|
file = "Tests/images/broken.png"
|
||||||
assert_exception(IOError, lambda: Image.open(file))
|
self.assertRaises(IOError, lambda: Image.open(file))
|
||||||
|
|
||||||
def test_bad_text():
|
def test_bad_text(self):
|
||||||
# Make sure PIL can read malformed tEXt chunks (@PIL152)
|
# Make sure PIL can read malformed tEXt chunks (@PIL152)
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'tEXt') + TAIL)
|
im = load(HEAD + chunk(b'tEXt') + TAIL)
|
||||||
assert_equal(im.info, {})
|
self.assertEqual(im.info, {})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'tEXt', b'spam') + TAIL)
|
im = load(HEAD + chunk(b'tEXt', b'spam') + TAIL)
|
||||||
assert_equal(im.info, {'spam': ''})
|
self.assertEqual(im.info, {'spam': ''})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'tEXt', b'spam\0') + TAIL)
|
im = load(HEAD + chunk(b'tEXt', b'spam\0') + TAIL)
|
||||||
assert_equal(im.info, {'spam': ''})
|
self.assertEqual(im.info, {'spam': ''})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'tEXt', b'spam\0egg') + TAIL)
|
im = load(HEAD + chunk(b'tEXt', b'spam\0egg') + TAIL)
|
||||||
assert_equal(im.info, {'spam': 'egg'})
|
self.assertEqual(im.info, {'spam': 'egg'})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'tEXt', b'spam\0egg\0') + TAIL)
|
im = load(HEAD + chunk(b'tEXt', b'spam\0egg\0') + TAIL)
|
||||||
assert_equal(im.info, {'spam': 'egg\x00'})
|
self.assertEqual(im.info, {'spam': 'egg\x00'})
|
||||||
|
|
||||||
def test_bad_ztxt():
|
def test_bad_ztxt(self):
|
||||||
# Test reading malformed zTXt chunks (python-imaging/Pillow#318)
|
# Test reading malformed zTXt chunks (python-pillow/Pillow#318)
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'zTXt') + TAIL)
|
im = load(HEAD + chunk(b'zTXt') + TAIL)
|
||||||
assert_equal(im.info, {})
|
self.assertEqual(im.info, {})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'zTXt', b'spam') + TAIL)
|
im = load(HEAD + chunk(b'zTXt', b'spam') + TAIL)
|
||||||
assert_equal(im.info, {'spam': ''})
|
self.assertEqual(im.info, {'spam': ''})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'zTXt', b'spam\0') + TAIL)
|
im = load(HEAD + chunk(b'zTXt', b'spam\0') + TAIL)
|
||||||
assert_equal(im.info, {'spam': ''})
|
self.assertEqual(im.info, {'spam': ''})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'zTXt', b'spam\0\0') + TAIL)
|
im = load(HEAD + chunk(b'zTXt', b'spam\0\0') + TAIL)
|
||||||
assert_equal(im.info, {'spam': ''})
|
self.assertEqual(im.info, {'spam': ''})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'zTXt', b'spam\0\0' + zlib.compress(b'egg')[:1]) + TAIL)
|
im = load(HEAD + chunk(
|
||||||
assert_equal(im.info, {'spam': ''})
|
b'zTXt', b'spam\0\0' + zlib.compress(b'egg')[:1]) + TAIL)
|
||||||
|
self.assertEqual(im.info, {'spam': ''})
|
||||||
|
|
||||||
im = load(HEAD + chunk(b'zTXt', b'spam\0\0' + zlib.compress(b'egg')) + TAIL)
|
im = load(
|
||||||
assert_equal(im.info, {'spam': 'egg'})
|
HEAD + chunk(b'zTXt', b'spam\0\0' + zlib.compress(b'egg')) + TAIL)
|
||||||
|
self.assertEqual(im.info, {'spam': 'egg'})
|
||||||
|
|
||||||
def test_interlace():
|
def test_interlace(self):
|
||||||
|
|
||||||
file = "Tests/images/pil123p.png"
|
file = "Tests/images/pil123p.png"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_image(im, "P", (162, 150))
|
self.assert_image(im, "P", (162, 150))
|
||||||
assert_true(im.info.get("interlace"))
|
self.assertTrue(im.info.get("interlace"))
|
||||||
|
|
||||||
assert_no_exception(lambda: im.load())
|
im.load()
|
||||||
|
|
||||||
file = "Tests/images/pil123rgba.png"
|
file = "Tests/images/pil123rgba.png"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_image(im, "RGBA", (162, 150))
|
self.assert_image(im, "RGBA", (162, 150))
|
||||||
assert_true(im.info.get("interlace"))
|
self.assertTrue(im.info.get("interlace"))
|
||||||
|
|
||||||
assert_no_exception(lambda: im.load())
|
im.load()
|
||||||
|
|
||||||
def test_load_transparent_p():
|
def test_load_transparent_p(self):
|
||||||
file = "Tests/images/pil123p.png"
|
file = "Tests/images/pil123p.png"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_image(im, "P", (162, 150))
|
self.assert_image(im, "P", (162, 150))
|
||||||
im = im.convert("RGBA")
|
im = im.convert("RGBA")
|
||||||
assert_image(im, "RGBA", (162, 150))
|
self.assert_image(im, "RGBA", (162, 150))
|
||||||
|
|
||||||
# image has 124 uniqe qlpha values
|
# image has 124 uniqe qlpha values
|
||||||
assert_equal(len(im.split()[3].getcolors()), 124)
|
self.assertEqual(len(im.split()[3].getcolors()), 124)
|
||||||
|
|
||||||
def test_load_transparent_rgb():
|
def test_load_transparent_rgb(self):
|
||||||
file = "Tests/images/rgb_trns.png"
|
file = "Tests/images/rgb_trns.png"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_image(im, "RGB", (64, 64))
|
self.assert_image(im, "RGB", (64, 64))
|
||||||
im = im.convert("RGBA")
|
im = im.convert("RGBA")
|
||||||
assert_image(im, "RGBA", (64, 64))
|
self.assert_image(im, "RGBA", (64, 64))
|
||||||
|
|
||||||
# image has 876 transparent pixels
|
# image has 876 transparent pixels
|
||||||
assert_equal(im.split()[3].getcolors()[0][0], 876)
|
self.assertEqual(im.split()[3].getcolors()[0][0], 876)
|
||||||
|
|
||||||
def test_save_p_transparent_palette():
|
def test_save_p_transparent_palette(self):
|
||||||
in_file = "Tests/images/pil123p.png"
|
in_file = "Tests/images/pil123p.png"
|
||||||
im = Image.open(in_file)
|
im = Image.open(in_file)
|
||||||
|
|
||||||
file = tempfile("temp.png")
|
file = self.tempfile("temp.png")
|
||||||
assert_no_exception(lambda: im.save(file))
|
im.save(file)
|
||||||
|
|
||||||
def test_save_p_single_transparency():
|
def test_save_p_single_transparency(self):
|
||||||
in_file = "Tests/images/p_trns_single.png"
|
in_file = "Tests/images/p_trns_single.png"
|
||||||
im = Image.open(in_file)
|
im = Image.open(in_file)
|
||||||
|
|
||||||
file = tempfile("temp.png")
|
file = self.tempfile("temp.png")
|
||||||
assert_no_exception(lambda: im.save(file))
|
im.save(file)
|
||||||
|
|
||||||
def test_save_l_transparency():
|
def test_save_l_transparency(self):
|
||||||
in_file = "Tests/images/l_trns.png"
|
in_file = "Tests/images/l_trns.png"
|
||||||
im = Image.open(in_file)
|
im = Image.open(in_file)
|
||||||
|
|
||||||
file = tempfile("temp.png")
|
file = self.tempfile("temp.png")
|
||||||
assert_no_exception(lambda: im.save(file))
|
im.save(file)
|
||||||
|
|
||||||
# There are 559 transparent pixels.
|
# There are 559 transparent pixels.
|
||||||
im = im.convert('RGBA')
|
im = im.convert('RGBA')
|
||||||
assert_equal(im.split()[3].getcolors()[0][0], 559)
|
self.assertEqual(im.split()[3].getcolors()[0][0], 559)
|
||||||
|
|
||||||
def test_save_rgb_single_transparency():
|
def test_save_rgb_single_transparency(self):
|
||||||
in_file = "Tests/images/caption_6_33_22.png"
|
in_file = "Tests/images/caption_6_33_22.png"
|
||||||
im = Image.open(in_file)
|
im = Image.open(in_file)
|
||||||
|
|
||||||
file = tempfile("temp.png")
|
file = self.tempfile("temp.png")
|
||||||
assert_no_exception(lambda: im.save(file))
|
im.save(file)
|
||||||
|
|
||||||
def test_load_verify():
|
def test_load_verify(self):
|
||||||
# Check open/load/verify exception (@PIL150)
|
# Check open/load/verify exception (@PIL150)
|
||||||
|
|
||||||
im = Image.open("Images/lena.png")
|
im = Image.open("Images/lena.png")
|
||||||
assert_no_exception(lambda: im.verify())
|
im.verify()
|
||||||
|
|
||||||
im = Image.open("Images/lena.png")
|
im = Image.open("Images/lena.png")
|
||||||
im.load()
|
im.load()
|
||||||
assert_exception(RuntimeError, lambda: im.verify())
|
self.assertRaises(RuntimeError, lambda: im.verify())
|
||||||
|
|
||||||
def test_roundtrip_dpi():
|
def test_roundtrip_dpi(self):
|
||||||
# Check dpi roundtripping
|
# Check dpi roundtripping
|
||||||
|
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
im = roundtrip(im, dpi=(100, 100))
|
im = roundtrip(im, dpi=(100, 100))
|
||||||
assert_equal(im.info["dpi"], (100, 100))
|
self.assertEqual(im.info["dpi"], (100, 100))
|
||||||
|
|
||||||
def test_roundtrip_text():
|
def test_roundtrip_text(self):
|
||||||
# Check text roundtripping
|
# Check text roundtripping
|
||||||
|
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
@ -221,10 +229,10 @@ def test_roundtrip_text():
|
||||||
info.add_text("ZIP", "VALUE", 1)
|
info.add_text("ZIP", "VALUE", 1)
|
||||||
|
|
||||||
im = roundtrip(im, pnginfo=info)
|
im = roundtrip(im, pnginfo=info)
|
||||||
assert_equal(im.info, {'TXT': 'VALUE', 'ZIP': 'VALUE'})
|
self.assertEqual(im.info, {'TXT': 'VALUE', 'ZIP': 'VALUE'})
|
||||||
assert_equal(im.text, {'TXT': 'VALUE', 'ZIP': 'VALUE'})
|
self.assertEqual(im.text, {'TXT': 'VALUE', 'ZIP': 'VALUE'})
|
||||||
|
|
||||||
def test_scary():
|
def test_scary(self):
|
||||||
# Check reading of evil PNG file. For information, see:
|
# Check reading of evil PNG file. For information, see:
|
||||||
# http://scary.beasts.org/security/CESA-2004-001.txt
|
# http://scary.beasts.org/security/CESA-2004-001.txt
|
||||||
# The first byte is removed from pngtest_bad.png
|
# The first byte is removed from pngtest_bad.png
|
||||||
|
@ -234,47 +242,46 @@ def test_scary():
|
||||||
data = b'\x89' + fd.read()
|
data = b'\x89' + fd.read()
|
||||||
|
|
||||||
pngfile = BytesIO(data)
|
pngfile = BytesIO(data)
|
||||||
assert_exception(IOError, lambda: Image.open(pngfile))
|
self.assertRaises(IOError, lambda: Image.open(pngfile))
|
||||||
|
|
||||||
def test_trns_rgb():
|
def test_trns_rgb(self):
|
||||||
# Check writing and reading of tRNS chunks for RGB images.
|
# Check writing and reading of tRNS chunks for RGB images.
|
||||||
# Independent file sample provided by Sebastian Spaeth.
|
# Independent file sample provided by Sebastian Spaeth.
|
||||||
|
|
||||||
file = "Tests/images/caption_6_33_22.png"
|
file = "Tests/images/caption_6_33_22.png"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
assert_equal(im.info["transparency"], (248, 248, 248))
|
self.assertEqual(im.info["transparency"], (248, 248, 248))
|
||||||
|
|
||||||
# check saving transparency by default
|
# check saving transparency by default
|
||||||
im = roundtrip(im)
|
im = roundtrip(im)
|
||||||
assert_equal(im.info["transparency"], (248, 248, 248))
|
self.assertEqual(im.info["transparency"], (248, 248, 248))
|
||||||
|
|
||||||
im = roundtrip(im, transparency=(0, 1, 2))
|
im = roundtrip(im, transparency=(0, 1, 2))
|
||||||
assert_equal(im.info["transparency"], (0, 1, 2))
|
self.assertEqual(im.info["transparency"], (0, 1, 2))
|
||||||
|
|
||||||
def test_trns_p():
|
def test_trns_p(self):
|
||||||
# Check writing a transparency of 0, issue #528
|
# Check writing a transparency of 0, issue #528
|
||||||
im = lena('P')
|
im = lena('P')
|
||||||
im.info['transparency']=0
|
im.info['transparency'] = 0
|
||||||
|
|
||||||
f = tempfile("temp.png")
|
f = self.tempfile("temp.png")
|
||||||
im.save(f)
|
im.save(f)
|
||||||
|
|
||||||
im2 = Image.open(f)
|
im2 = Image.open(f)
|
||||||
assert_true('transparency' in im2.info)
|
self.assertIn('transparency', im2.info)
|
||||||
|
|
||||||
assert_image_equal(im2.convert('RGBA'), im.convert('RGBA'))
|
self.assert_image_equal(im2.convert('RGBA'), im.convert('RGBA'))
|
||||||
|
|
||||||
|
def test_save_icc_profile_none(self):
|
||||||
def test_save_icc_profile_none():
|
|
||||||
# check saving files with an ICC profile set to None (omit profile)
|
# check saving files with an ICC profile set to None (omit profile)
|
||||||
in_file = "Tests/images/icc_profile_none.png"
|
in_file = "Tests/images/icc_profile_none.png"
|
||||||
im = Image.open(in_file)
|
im = Image.open(in_file)
|
||||||
assert_equal(im.info['icc_profile'], None)
|
self.assertEqual(im.info['icc_profile'], None)
|
||||||
|
|
||||||
im = roundtrip(im)
|
im = roundtrip(im)
|
||||||
assert_false('icc_profile' in im.info)
|
self.assertNotIn('icc_profile', im.info)
|
||||||
|
|
||||||
def test_roundtrip_icc_profile():
|
def test_roundtrip_icc_profile(self):
|
||||||
# check that we can roundtrip the icc profile
|
# check that we can roundtrip the icc profile
|
||||||
im = lena('RGB')
|
im = lena('RGB')
|
||||||
|
|
||||||
|
@ -283,5 +290,10 @@ def test_roundtrip_icc_profile():
|
||||||
|
|
||||||
im.info['icc_profile'] = expected_icc
|
im.info['icc_profile'] = expected_icc
|
||||||
im = roundtrip(im)
|
im = roundtrip(im)
|
||||||
assert_equal(im.info['icc_profile'], expected_icc)
|
self.assertEqual(im.info['icc_profile'], expected_icc)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -6,31 +6,37 @@ from PIL import Image
|
||||||
file = "Images/lena.ppm"
|
file = "Images/lena.ppm"
|
||||||
data = open(file, "rb").read()
|
data = open(file, "rb").read()
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFilePpm(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "PPM")
|
self.assertEqual(im.format, "PPM")
|
||||||
|
|
||||||
def test_16bit_pgm():
|
def test_16bit_pgm(self):
|
||||||
im = Image.open('Tests/images/16_bit_binary.pgm')
|
im = Image.open('Tests/images/16_bit_binary.pgm')
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, 'I')
|
self.assertEqual(im.mode, 'I')
|
||||||
assert_equal(im.size, (20,100))
|
self.assertEqual(im.size, (20, 100))
|
||||||
|
|
||||||
tgt = Image.open('Tests/images/16_bit_binary_pgm.png')
|
tgt = Image.open('Tests/images/16_bit_binary_pgm.png')
|
||||||
assert_image_equal(im, tgt)
|
self.assert_image_equal(im, tgt)
|
||||||
|
|
||||||
|
def test_16bit_pgm_write(self):
|
||||||
def test_16bit_pgm_write():
|
|
||||||
im = Image.open('Tests/images/16_bit_binary.pgm')
|
im = Image.open('Tests/images/16_bit_binary.pgm')
|
||||||
im.load()
|
im.load()
|
||||||
|
|
||||||
f = tempfile('temp.pgm')
|
f = self.tempfile('temp.pgm')
|
||||||
assert_no_exception(lambda: im.save(f, 'PPM'))
|
im.save(f, 'PPM')
|
||||||
|
|
||||||
reloaded = Image.open(f)
|
reloaded = Image.open(f)
|
||||||
assert_image_equal(im, reloaded)
|
self.assert_image_equal(im, reloaded)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -6,9 +6,18 @@ from PIL import Image
|
||||||
file = "Images/lena.psd"
|
file = "Images/lena.psd"
|
||||||
data = open(file, "rb").read()
|
data = open(file, "rb").read()
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImagePsd(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "PSD")
|
self.assertEqual(im.format, "PSD")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
39
Tests/test_file_spider.py
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
|
from PIL import Image
|
||||||
|
from PIL import SpiderImagePlugin
|
||||||
|
|
||||||
|
test_file = "Tests/images/lena.spider"
|
||||||
|
|
||||||
|
|
||||||
|
class TestImageSpider(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
im = Image.open(test_file)
|
||||||
|
im.load()
|
||||||
|
self.assertEqual(im.mode, "F")
|
||||||
|
self.assertEqual(im.size, (128, 128))
|
||||||
|
self.assertEqual(im.format, "SPIDER")
|
||||||
|
|
||||||
|
def test_save(self):
|
||||||
|
# Arrange
|
||||||
|
temp = self.tempfile('temp.spider')
|
||||||
|
im = lena()
|
||||||
|
|
||||||
|
# Act
|
||||||
|
im.save(temp, "SPIDER")
|
||||||
|
|
||||||
|
# Assert
|
||||||
|
im2 = Image.open(temp)
|
||||||
|
self.assertEqual(im2.mode, "F")
|
||||||
|
self.assertEqual(im2.size, (128, 128))
|
||||||
|
self.assertEqual(im2.format, "SPIDER")
|
||||||
|
|
||||||
|
def test_isSpiderImage(self):
|
||||||
|
self.assertTrue(SpiderImagePlugin.isSpiderImage(test_file))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
|
@ -1,28 +1,38 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image, TarIO
|
from PIL import Image, TarIO
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
if "zip_decoder" not in codecs and "jpeg_decoder" not in codecs:
|
|
||||||
skip("neither jpeg nor zip support not available")
|
|
||||||
|
|
||||||
# sample ppm stream
|
# sample ppm stream
|
||||||
tarfile = "Images/lena.tar"
|
tarfile = "Images/lena.tar"
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileTar(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "zip_decoder" not in codecs and "jpeg_decoder" not in codecs:
|
||||||
|
self.skipTest("neither jpeg nor zip support not available")
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
if "zip_decoder" in codecs:
|
if "zip_decoder" in codecs:
|
||||||
tar = TarIO.TarIO(tarfile, 'lena.png')
|
tar = TarIO.TarIO(tarfile, 'lena.png')
|
||||||
im = Image.open(tar)
|
im = Image.open(tar)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "PNG")
|
self.assertEqual(im.format, "PNG")
|
||||||
|
|
||||||
if "jpeg_decoder" in codecs:
|
if "jpeg_decoder" in codecs:
|
||||||
tar = TarIO.TarIO(tarfile, 'lena.jpg')
|
tar = TarIO.TarIO(tarfile, 'lena.jpg')
|
||||||
im = Image.open(tar)
|
im = Image.open(tar)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "JPEG")
|
self.assertEqual(im.format, "JPEG")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,18 +1,21 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena, py3
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
|
||||||
file = tempfile("temp.tif")
|
class TestFileTiff(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
|
file = self.tempfile("temp.tif")
|
||||||
|
|
||||||
lena("RGB").save(file)
|
lena("RGB").save(file)
|
||||||
|
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "TIFF")
|
self.assertEqual(im.format, "TIFF")
|
||||||
|
|
||||||
lena("1").save(file)
|
lena("1").save(file)
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
@ -29,85 +32,84 @@ def test_sanity():
|
||||||
lena("I").save(file)
|
lena("I").save(file)
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
def test_mac_tiff():
|
def test_mac_tiff(self):
|
||||||
# Read RGBa images from Mac OS X [@PIL136]
|
# Read RGBa images from Mac OS X [@PIL136]
|
||||||
|
|
||||||
file = "Tests/images/pil136.tiff"
|
file = "Tests/images/pil136.tiff"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_equal(im.mode, "RGBA")
|
self.assertEqual(im.mode, "RGBA")
|
||||||
assert_equal(im.size, (55, 43))
|
self.assertEqual(im.size, (55, 43))
|
||||||
assert_equal(im.tile, [('raw', (0, 0, 55, 43), 8, ('RGBa', 0, 1))])
|
self.assertEqual(im.tile, [('raw', (0, 0, 55, 43), 8, ('RGBa', 0, 1))])
|
||||||
assert_no_exception(lambda: im.load())
|
im.load()
|
||||||
|
|
||||||
def test_gimp_tiff():
|
def test_gimp_tiff(self):
|
||||||
# Read TIFF JPEG images from GIMP [@PIL168]
|
# Read TIFF JPEG images from GIMP [@PIL168]
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
if "jpeg_decoder" not in codecs:
|
if "jpeg_decoder" not in codecs:
|
||||||
skip("jpeg support not available")
|
self.skipTest("jpeg support not available")
|
||||||
|
|
||||||
file = "Tests/images/pil168.tif"
|
file = "Tests/images/pil168.tif"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
|
|
||||||
assert_equal(im.mode, "RGB")
|
self.assertEqual(im.mode, "RGB")
|
||||||
assert_equal(im.size, (256, 256))
|
self.assertEqual(im.size, (256, 256))
|
||||||
assert_equal(im.tile, [
|
self.assertEqual(
|
||||||
|
im.tile, [
|
||||||
('jpeg', (0, 0, 256, 64), 8, ('RGB', '')),
|
('jpeg', (0, 0, 256, 64), 8, ('RGB', '')),
|
||||||
('jpeg', (0, 64, 256, 128), 1215, ('RGB', '')),
|
('jpeg', (0, 64, 256, 128), 1215, ('RGB', '')),
|
||||||
('jpeg', (0, 128, 256, 192), 2550, ('RGB', '')),
|
('jpeg', (0, 128, 256, 192), 2550, ('RGB', '')),
|
||||||
('jpeg', (0, 192, 256, 256), 3890, ('RGB', '')),
|
('jpeg', (0, 192, 256, 256), 3890, ('RGB', '')),
|
||||||
])
|
])
|
||||||
assert_no_exception(lambda: im.load())
|
im.load()
|
||||||
|
|
||||||
def test_xyres_tiff():
|
def test_xyres_tiff(self):
|
||||||
from PIL.TiffImagePlugin import X_RESOLUTION, Y_RESOLUTION
|
from PIL.TiffImagePlugin import X_RESOLUTION, Y_RESOLUTION
|
||||||
file = "Tests/images/pil168.tif"
|
file = "Tests/images/pil168.tif"
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
assert isinstance(im.tag.tags[X_RESOLUTION][0], tuple)
|
assert isinstance(im.tag.tags[X_RESOLUTION][0], tuple)
|
||||||
assert isinstance(im.tag.tags[Y_RESOLUTION][0], tuple)
|
assert isinstance(im.tag.tags[Y_RESOLUTION][0], tuple)
|
||||||
#Try to read a file where X,Y_RESOLUTION are ints
|
# Try to read a file where X,Y_RESOLUTION are ints
|
||||||
im.tag.tags[X_RESOLUTION] = (72,)
|
im.tag.tags[X_RESOLUTION] = (72,)
|
||||||
im.tag.tags[Y_RESOLUTION] = (72,)
|
im.tag.tags[Y_RESOLUTION] = (72,)
|
||||||
im._setup()
|
im._setup()
|
||||||
assert_equal(im.info['dpi'], (72., 72.))
|
self.assertEqual(im.info['dpi'], (72., 72.))
|
||||||
|
|
||||||
|
def test_little_endian(self):
|
||||||
def test_little_endian():
|
|
||||||
im = Image.open('Tests/images/16bit.cropped.tif')
|
im = Image.open('Tests/images/16bit.cropped.tif')
|
||||||
assert_equal(im.getpixel((0,0)), 480)
|
self.assertEqual(im.getpixel((0, 0)), 480)
|
||||||
assert_equal(im.mode, 'I;16')
|
self.assertEqual(im.mode, 'I;16')
|
||||||
|
|
||||||
b = im.tobytes()
|
b = im.tobytes()
|
||||||
# Bytes are in image native order (little endian)
|
# Bytes are in image native order (little endian)
|
||||||
if py3:
|
if py3:
|
||||||
assert_equal(b[0], ord(b'\xe0'))
|
self.assertEqual(b[0], ord(b'\xe0'))
|
||||||
assert_equal(b[1], ord(b'\x01'))
|
self.assertEqual(b[1], ord(b'\x01'))
|
||||||
else:
|
else:
|
||||||
assert_equal(b[0], b'\xe0')
|
self.assertEqual(b[0], b'\xe0')
|
||||||
assert_equal(b[1], b'\x01')
|
self.assertEqual(b[1], b'\x01')
|
||||||
|
|
||||||
|
def test_big_endian(self):
|
||||||
def test_big_endian():
|
|
||||||
im = Image.open('Tests/images/16bit.MM.cropped.tif')
|
im = Image.open('Tests/images/16bit.MM.cropped.tif')
|
||||||
assert_equal(im.getpixel((0,0)), 480)
|
self.assertEqual(im.getpixel((0, 0)), 480)
|
||||||
assert_equal(im.mode, 'I;16B')
|
self.assertEqual(im.mode, 'I;16B')
|
||||||
|
|
||||||
b = im.tobytes()
|
b = im.tobytes()
|
||||||
|
|
||||||
# Bytes are in image native order (big endian)
|
# Bytes are in image native order (big endian)
|
||||||
if py3:
|
if py3:
|
||||||
assert_equal(b[0], ord(b'\x01'))
|
self.assertEqual(b[0], ord(b'\x01'))
|
||||||
assert_equal(b[1], ord(b'\xe0'))
|
self.assertEqual(b[1], ord(b'\xe0'))
|
||||||
else:
|
else:
|
||||||
assert_equal(b[0], b'\x01')
|
self.assertEqual(b[0], b'\x01')
|
||||||
assert_equal(b[1], b'\xe0')
|
self.assertEqual(b[1], b'\xe0')
|
||||||
|
|
||||||
|
def test_12bit_rawmode(self):
|
||||||
|
""" Are we generating the same interpretation
|
||||||
|
of the image as Imagemagick is? """
|
||||||
|
|
||||||
def test_12bit_rawmode():
|
# Image.DEBUG = True
|
||||||
""" Are we generating the same interpretation of the image as Imagemagick is? """
|
|
||||||
|
|
||||||
#Image.DEBUG = True
|
|
||||||
im = Image.open('Tests/images/12bit.cropped.tif')
|
im = Image.open('Tests/images/12bit.cropped.tif')
|
||||||
|
|
||||||
# to make the target --
|
# to make the target --
|
||||||
|
@ -119,23 +121,28 @@ def test_12bit_rawmode():
|
||||||
im2 = Image.open('Tests/images/12in16bit.tif')
|
im2 = Image.open('Tests/images/12in16bit.tif')
|
||||||
|
|
||||||
if Image.DEBUG:
|
if Image.DEBUG:
|
||||||
print (im.getpixel((0,0)))
|
print (im.getpixel((0, 0)))
|
||||||
print (im.getpixel((0,1)))
|
print (im.getpixel((0, 1)))
|
||||||
print (im.getpixel((0,2)))
|
print (im.getpixel((0, 2)))
|
||||||
|
|
||||||
print (im2.getpixel((0,0)))
|
print (im2.getpixel((0, 0)))
|
||||||
print (im2.getpixel((0,1)))
|
print (im2.getpixel((0, 1)))
|
||||||
print (im2.getpixel((0,2)))
|
print (im2.getpixel((0, 2)))
|
||||||
|
|
||||||
assert_image_equal(im, im2)
|
self.assert_image_equal(im, im2)
|
||||||
|
|
||||||
def test_32bit_float():
|
def test_32bit_float(self):
|
||||||
# Issue 614, specific 32 bit float format
|
# Issue 614, specific 32 bit float format
|
||||||
path = 'Tests/images/10ct_32bit_128.tiff'
|
path = 'Tests/images/10ct_32bit_128.tiff'
|
||||||
im = Image.open(path)
|
im = Image.open(path)
|
||||||
im.load()
|
im.load()
|
||||||
|
|
||||||
assert_equal(im.getpixel((0,0)), -0.4526388943195343)
|
self.assertEqual(im.getpixel((0, 0)), -0.4526388943195343)
|
||||||
assert_equal(im.getextrema(), (-3.140936851501465, 3.140684127807617))
|
self.assertEqual(
|
||||||
|
im.getextrema(), (-3.140936851501465, 3.140684127807617))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,12 +1,16 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image, TiffImagePlugin, TiffTags
|
from PIL import Image, TiffImagePlugin, TiffTags
|
||||||
|
|
||||||
tag_ids = dict(zip(TiffTags.TAGS.values(), TiffTags.TAGS.keys()))
|
tag_ids = dict(zip(TiffTags.TAGS.values(), TiffTags.TAGS.keys()))
|
||||||
|
|
||||||
def test_rt_metadata():
|
|
||||||
|
class TestFileTiffMetadata(PillowTestCase):
|
||||||
|
|
||||||
|
def test_rt_metadata(self):
|
||||||
""" Test writing arbitray metadata into the tiff image directory
|
""" Test writing arbitray metadata into the tiff image directory
|
||||||
Use case is ImageJ private tags, one numeric, one arbitrary
|
Use case is ImageJ private tags, one numeric, one arbitrary
|
||||||
data. https://github.com/python-imaging/Pillow/issues/291
|
data. https://github.com/python-pillow/Pillow/issues/291
|
||||||
"""
|
"""
|
||||||
|
|
||||||
img = lena()
|
img = lena()
|
||||||
|
@ -17,16 +21,16 @@ def test_rt_metadata():
|
||||||
info[tag_ids['ImageJMetaDataByteCounts']] = len(textdata)
|
info[tag_ids['ImageJMetaDataByteCounts']] = len(textdata)
|
||||||
info[tag_ids['ImageJMetaData']] = textdata
|
info[tag_ids['ImageJMetaData']] = textdata
|
||||||
|
|
||||||
f = tempfile("temp.tif")
|
f = self.tempfile("temp.tif")
|
||||||
|
|
||||||
img.save(f, tiffinfo=info)
|
img.save(f, tiffinfo=info)
|
||||||
|
|
||||||
loaded = Image.open(f)
|
loaded = Image.open(f)
|
||||||
|
|
||||||
assert_equal(loaded.tag[50838], (len(textdata),))
|
self.assertEqual(loaded.tag[50838], (len(textdata),))
|
||||||
assert_equal(loaded.tag[50839], textdata)
|
self.assertEqual(loaded.tag[50839], textdata)
|
||||||
|
|
||||||
def test_read_metadata():
|
def test_read_metadata(self):
|
||||||
img = Image.open('Tests/images/lena_g4.tif')
|
img = Image.open('Tests/images/lena_g4.tif')
|
||||||
|
|
||||||
known = {'YResolution': ((1207959552, 16777216),),
|
known = {'YResolution': ((1207959552, 16777216),),
|
||||||
|
@ -48,33 +52,42 @@ def test_read_metadata():
|
||||||
'StripOffsets': (8,),
|
'StripOffsets': (8,),
|
||||||
'Software': 'ImageMagick 6.5.7-8 2012-08-17 Q16 http://www.imagemagick.org'}
|
'Software': 'ImageMagick 6.5.7-8 2012-08-17 Q16 http://www.imagemagick.org'}
|
||||||
|
|
||||||
# assert_equal is equivalent, but less helpful in telling what's wrong.
|
# self.assertEqual is equivalent,
|
||||||
|
# but less helpful in telling what's wrong.
|
||||||
named = img.tag.named()
|
named = img.tag.named()
|
||||||
for tag, value in named.items():
|
for tag, value in named.items():
|
||||||
assert_equal(known[tag], value)
|
self.assertEqual(known[tag], value)
|
||||||
|
|
||||||
for tag, value in known.items():
|
for tag, value in known.items():
|
||||||
assert_equal(value, named[tag])
|
self.assertEqual(value, named[tag])
|
||||||
|
|
||||||
|
def test_write_metadata(self):
|
||||||
def test_write_metadata():
|
|
||||||
""" Test metadata writing through the python code """
|
""" Test metadata writing through the python code """
|
||||||
img = Image.open('Tests/images/lena.tif')
|
img = Image.open('Tests/images/lena.tif')
|
||||||
|
|
||||||
f = tempfile('temp.tiff')
|
f = self.tempfile('temp.tiff')
|
||||||
img.save(f, tiffinfo = img.tag)
|
img.save(f, tiffinfo=img.tag)
|
||||||
|
|
||||||
loaded = Image.open(f)
|
loaded = Image.open(f)
|
||||||
|
|
||||||
original = img.tag.named()
|
original = img.tag.named()
|
||||||
reloaded = loaded.tag.named()
|
reloaded = loaded.tag.named()
|
||||||
|
|
||||||
ignored = ['StripByteCounts', 'RowsPerStrip', 'PageNumber', 'StripOffsets']
|
ignored = [
|
||||||
|
'StripByteCounts', 'RowsPerStrip', 'PageNumber', 'StripOffsets']
|
||||||
|
|
||||||
for tag, value in reloaded.items():
|
for tag, value in reloaded.items():
|
||||||
if tag not in ignored:
|
if tag not in ignored:
|
||||||
assert_equal(original[tag], value, "%s didn't roundtrip" % tag)
|
self.assertEqual(
|
||||||
|
original[tag], value, "%s didn't roundtrip" % tag)
|
||||||
|
|
||||||
for tag, value in original.items():
|
for tag, value in original.items():
|
||||||
if tag not in ignored:
|
if tag not in ignored:
|
||||||
assert_equal(value, reloaded[tag], "%s didn't roundtrip" % tag)
|
self.assertEqual(
|
||||||
|
value, reloaded[tag], "%s didn't roundtrip" % tag)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,68 +1,79 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from PIL import _webp
|
from PIL import _webp
|
||||||
except:
|
except:
|
||||||
skip('webp support not installed')
|
# Skip in setUp()
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
def test_version():
|
class TestFileWebp(PillowTestCase):
|
||||||
assert_no_exception(lambda: _webp.WebPDecoderVersion())
|
|
||||||
assert_no_exception(lambda: _webp.WebPDecoderBuggyAlpha())
|
|
||||||
|
|
||||||
def test_read_rgb():
|
def setUp(self):
|
||||||
|
try:
|
||||||
|
from PIL import _webp
|
||||||
|
except:
|
||||||
|
self.skipTest('WebP support not installed')
|
||||||
|
|
||||||
|
def test_version(self):
|
||||||
|
_webp.WebPDecoderVersion()
|
||||||
|
_webp.WebPDecoderBuggyAlpha()
|
||||||
|
|
||||||
|
def test_read_rgb(self):
|
||||||
|
|
||||||
file_path = "Images/lena.webp"
|
file_path = "Images/lena.webp"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
|
|
||||||
assert_equal(image.mode, "RGB")
|
self.assertEqual(image.mode, "RGB")
|
||||||
assert_equal(image.size, (128, 128))
|
self.assertEqual(image.size, (128, 128))
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_no_exception(lambda: image.load())
|
image.load()
|
||||||
assert_no_exception(lambda: image.getdata())
|
image.getdata()
|
||||||
|
|
||||||
# generated with: dwebp -ppm ../../Images/lena.webp -o lena_webp_bits.ppm
|
# generated with:
|
||||||
|
# dwebp -ppm ../../Images/lena.webp -o lena_webp_bits.ppm
|
||||||
target = Image.open('Tests/images/lena_webp_bits.ppm')
|
target = Image.open('Tests/images/lena_webp_bits.ppm')
|
||||||
assert_image_similar(image, target, 20.0)
|
self.assert_image_similar(image, target, 20.0)
|
||||||
|
|
||||||
|
def test_write_rgb(self):
|
||||||
def test_write_rgb():
|
|
||||||
"""
|
"""
|
||||||
Can we write a RGB mode file to webp without error. Does it have the bits we
|
Can we write a RGB mode file to webp without error.
|
||||||
expect?
|
Does it have the bits we expect?
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
temp_file = tempfile("temp.webp")
|
temp_file = self.tempfile("temp.webp")
|
||||||
|
|
||||||
lena("RGB").save(temp_file)
|
lena("RGB").save(temp_file)
|
||||||
|
|
||||||
image = Image.open(temp_file)
|
image = Image.open(temp_file)
|
||||||
image.load()
|
image.load()
|
||||||
|
|
||||||
assert_equal(image.mode, "RGB")
|
self.assertEqual(image.mode, "RGB")
|
||||||
assert_equal(image.size, (128, 128))
|
self.assertEqual(image.size, (128, 128))
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_no_exception(lambda: image.load())
|
image.load()
|
||||||
assert_no_exception(lambda: image.getdata())
|
image.getdata()
|
||||||
|
|
||||||
# If we're using the exact same version of webp, this test should pass.
|
# If we're using the exact same version of WebP, this test should pass.
|
||||||
# but it doesn't if the webp is generated on Ubuntu and tested on Fedora.
|
# but it doesn't if the WebP is generated on Ubuntu and tested on
|
||||||
|
# Fedora.
|
||||||
|
|
||||||
# generated with: dwebp -ppm temp.webp -o lena_webp_write.ppm
|
# generated with: dwebp -ppm temp.webp -o lena_webp_write.ppm
|
||||||
#target = Image.open('Tests/images/lena_webp_write.ppm')
|
# target = Image.open('Tests/images/lena_webp_write.ppm')
|
||||||
#assert_image_equal(image, target)
|
# self.assert_image_equal(image, target)
|
||||||
|
|
||||||
# This test asserts that the images are similar. If the average pixel difference
|
# This test asserts that the images are similar. If the average pixel
|
||||||
# between the two images is less than the epsilon value, then we're going to
|
# difference between the two images is less than the epsilon value,
|
||||||
# accept that it's a reasonable lossy version of the image. The included lena images
|
# then we're going to accept that it's a reasonable lossy version of
|
||||||
# for webp are showing ~16 on Ubuntu, the jpegs are showing ~18.
|
# the image. The included lena images for WebP are showing ~16 on
|
||||||
|
# Ubuntu, the jpegs are showing ~18.
|
||||||
target = lena("RGB")
|
target = lena("RGB")
|
||||||
assert_image_similar(image, target, 20.0)
|
self.assert_image_similar(image, target, 20.0)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,82 +1,91 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from PIL import _webp
|
from PIL import _webp
|
||||||
except:
|
except:
|
||||||
skip('webp support not installed')
|
pass
|
||||||
|
# Skip in setUp()
|
||||||
|
|
||||||
|
|
||||||
if _webp.WebPDecoderBuggyAlpha():
|
class TestFileWebpAlpha(PillowTestCase):
|
||||||
skip("Buggy early version of webp installed, not testing transparency")
|
|
||||||
|
|
||||||
def test_read_rgba():
|
def setUp(self):
|
||||||
|
try:
|
||||||
|
from PIL import _webp
|
||||||
|
except:
|
||||||
|
self.skipTest('WebP support not installed')
|
||||||
|
|
||||||
|
if _webp.WebPDecoderBuggyAlpha(self):
|
||||||
|
self.skipTest("Buggy early version of WebP installed, not testing transparency")
|
||||||
|
|
||||||
|
def test_read_rgba(self):
|
||||||
# Generated with `cwebp transparent.png -o transparent.webp`
|
# Generated with `cwebp transparent.png -o transparent.webp`
|
||||||
file_path = "Images/transparent.webp"
|
file_path = "Images/transparent.webp"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
|
|
||||||
assert_equal(image.mode, "RGBA")
|
self.assertEqual(image.mode, "RGBA")
|
||||||
assert_equal(image.size, (200, 150))
|
self.assertEqual(image.size, (200, 150))
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_no_exception(lambda: image.load())
|
image.load()
|
||||||
assert_no_exception(lambda: image.getdata())
|
image.getdata()
|
||||||
|
|
||||||
orig_bytes = image.tobytes()
|
image.tobytes()
|
||||||
|
|
||||||
target = Image.open('Images/transparent.png')
|
target = Image.open('Images/transparent.png')
|
||||||
assert_image_similar(image, target, 20.0)
|
self.assert_image_similar(image, target, 20.0)
|
||||||
|
|
||||||
|
def test_write_lossless_rgb(self):
|
||||||
def test_write_lossless_rgb():
|
temp_file = self.tempfile("temp.webp")
|
||||||
temp_file = tempfile("temp.webp")
|
# temp_file = "temp.webp"
|
||||||
#temp_file = "temp.webp"
|
|
||||||
|
|
||||||
pil_image = lena('RGBA')
|
pil_image = lena('RGBA')
|
||||||
|
|
||||||
mask = Image.new("RGBA", (64, 64), (128,128,128,128))
|
mask = Image.new("RGBA", (64, 64), (128, 128, 128, 128))
|
||||||
pil_image.paste(mask, (0,0), mask) # add some partially transparent bits.
|
# Add some partially transparent bits:
|
||||||
|
pil_image.paste(mask, (0, 0), mask)
|
||||||
|
|
||||||
pil_image.save(temp_file, lossless=True)
|
pil_image.save(temp_file, lossless=True)
|
||||||
|
|
||||||
image = Image.open(temp_file)
|
image = Image.open(temp_file)
|
||||||
image.load()
|
image.load()
|
||||||
|
|
||||||
assert_equal(image.mode, "RGBA")
|
self.assertEqual(image.mode, "RGBA")
|
||||||
assert_equal(image.size, pil_image.size)
|
self.assertEqual(image.size, pil_image.size)
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_no_exception(lambda: image.load())
|
image.load()
|
||||||
assert_no_exception(lambda: image.getdata())
|
image.getdata()
|
||||||
|
|
||||||
|
self.assert_image_equal(image, pil_image)
|
||||||
|
|
||||||
assert_image_equal(image, pil_image)
|
def test_write_rgba(self):
|
||||||
|
|
||||||
def test_write_rgba():
|
|
||||||
"""
|
"""
|
||||||
Can we write a RGBA mode file to webp without error. Does it have the bits we
|
Can we write a RGBA mode file to webp without error.
|
||||||
expect?
|
Does it have the bits we expect?
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
temp_file = tempfile("temp.webp")
|
temp_file = self.tempfile("temp.webp")
|
||||||
|
|
||||||
pil_image = Image.new("RGBA", (10, 10), (255, 0, 0, 20))
|
pil_image = Image.new("RGBA", (10, 10), (255, 0, 0, 20))
|
||||||
pil_image.save(temp_file)
|
pil_image.save(temp_file)
|
||||||
|
|
||||||
if _webp.WebPDecoderBuggyAlpha():
|
if _webp.WebPDecoderBuggyAlpha(self):
|
||||||
return
|
return
|
||||||
|
|
||||||
image = Image.open(temp_file)
|
image = Image.open(temp_file)
|
||||||
image.load()
|
image.load()
|
||||||
|
|
||||||
assert_equal(image.mode, "RGBA")
|
self.assertEqual(image.mode, "RGBA")
|
||||||
assert_equal(image.size, (10, 10))
|
self.assertEqual(image.size, (10, 10))
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_no_exception(image.load)
|
image.load
|
||||||
assert_no_exception(image.getdata)
|
image.getdata
|
||||||
|
|
||||||
assert_image_similar(image, pil_image, 1.0)
|
|
||||||
|
|
||||||
|
self.assert_image_similar(image, pil_image, 1.0)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,33 +1,43 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from PIL import _webp
|
from PIL import _webp
|
||||||
except:
|
except:
|
||||||
skip('webp support not installed')
|
pass
|
||||||
|
# Skip in setUp()
|
||||||
|
|
||||||
|
|
||||||
if (_webp.WebPDecoderVersion() < 0x0200):
|
class TestFileWebpLossless(PillowTestCase):
|
||||||
skip('lossless not included')
|
|
||||||
|
|
||||||
def test_write_lossless_rgb():
|
def setUp(self):
|
||||||
temp_file = tempfile("temp.webp")
|
try:
|
||||||
|
from PIL import _webp
|
||||||
|
except:
|
||||||
|
self.skipTest('WebP support not installed')
|
||||||
|
|
||||||
|
if (_webp.WebPDecoderVersion() < 0x0200):
|
||||||
|
self.skipTest('lossless not included')
|
||||||
|
|
||||||
|
def test_write_lossless_rgb(self):
|
||||||
|
temp_file = self.tempfile("temp.webp")
|
||||||
|
|
||||||
lena("RGB").save(temp_file, lossless=True)
|
lena("RGB").save(temp_file, lossless=True)
|
||||||
|
|
||||||
image = Image.open(temp_file)
|
image = Image.open(temp_file)
|
||||||
image.load()
|
image.load()
|
||||||
|
|
||||||
assert_equal(image.mode, "RGB")
|
self.assertEqual(image.mode, "RGB")
|
||||||
assert_equal(image.size, (128, 128))
|
self.assertEqual(image.size, (128, 128))
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_no_exception(lambda: image.load())
|
image.load()
|
||||||
assert_no_exception(lambda: image.getdata())
|
image.getdata()
|
||||||
|
|
||||||
|
self.assert_image_equal(image, lena("RGB"))
|
||||||
assert_image_equal(image, lena("RGB"))
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,37 +1,40 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
try:
|
|
||||||
|
class TestFileWebpMetadata(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
try:
|
||||||
from PIL import _webp
|
from PIL import _webp
|
||||||
if not _webp.HAVE_WEBPMUX:
|
if not _webp.HAVE_WEBPMUX:
|
||||||
skip('webpmux support not installed')
|
self.skipTest('webpmux support not installed')
|
||||||
except:
|
except:
|
||||||
skip('webp support not installed')
|
self.skipTest('WebP support not installed')
|
||||||
|
|
||||||
|
def test_read_exif_metadata(self):
|
||||||
|
|
||||||
def test_read_exif_metadata():
|
|
||||||
|
|
||||||
file_path = "Images/flower.webp"
|
file_path = "Images/flower.webp"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
|
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
exif_data = image.info.get("exif", None)
|
exif_data = image.info.get("exif", None)
|
||||||
assert_true(exif_data)
|
self.assertTrue(exif_data)
|
||||||
|
|
||||||
exif = image._getexif()
|
exif = image._getexif()
|
||||||
|
|
||||||
#camera make
|
# camera make
|
||||||
assert_equal(exif[271], "Canon")
|
self.assertEqual(exif[271], "Canon")
|
||||||
|
|
||||||
jpeg_image = Image.open('Tests/images/flower.jpg')
|
jpeg_image = Image.open('Tests/images/flower.jpg')
|
||||||
expected_exif = jpeg_image.info['exif']
|
expected_exif = jpeg_image.info['exif']
|
||||||
|
|
||||||
assert_equal(exif_data, expected_exif)
|
self.assertEqual(exif_data, expected_exif)
|
||||||
|
|
||||||
|
def test_write_exif_metadata(self):
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
def test_write_exif_metadata():
|
|
||||||
file_path = "Tests/images/flower.jpg"
|
file_path = "Tests/images/flower.jpg"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
expected_exif = image.info['exif']
|
expected_exif = image.info['exif']
|
||||||
|
@ -44,28 +47,29 @@ def test_write_exif_metadata():
|
||||||
webp_image = Image.open(buffer)
|
webp_image = Image.open(buffer)
|
||||||
|
|
||||||
webp_exif = webp_image.info.get('exif', None)
|
webp_exif = webp_image.info.get('exif', None)
|
||||||
assert_true(webp_exif)
|
self.assertTrue(webp_exif)
|
||||||
if webp_exif:
|
if webp_exif:
|
||||||
assert_equal(webp_exif, expected_exif, "Webp Exif didn't match")
|
self.assertEqual(
|
||||||
|
webp_exif, expected_exif, "WebP EXIF didn't match")
|
||||||
|
|
||||||
|
def test_read_icc_profile(self):
|
||||||
def test_read_icc_profile():
|
|
||||||
|
|
||||||
file_path = "Images/flower2.webp"
|
file_path = "Images/flower2.webp"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
|
|
||||||
assert_equal(image.format, "WEBP")
|
self.assertEqual(image.format, "WEBP")
|
||||||
assert_true(image.info.get("icc_profile", None))
|
self.assertTrue(image.info.get("icc_profile", None))
|
||||||
|
|
||||||
icc = image.info['icc_profile']
|
icc = image.info['icc_profile']
|
||||||
|
|
||||||
jpeg_image = Image.open('Tests/images/flower2.jpg')
|
jpeg_image = Image.open('Tests/images/flower2.jpg')
|
||||||
expected_icc = jpeg_image.info['icc_profile']
|
expected_icc = jpeg_image.info['icc_profile']
|
||||||
|
|
||||||
assert_equal(icc, expected_icc)
|
self.assertEqual(icc, expected_icc)
|
||||||
|
|
||||||
|
def test_write_icc_metadata(self):
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
def test_write_icc_metadata():
|
|
||||||
file_path = "Tests/images/flower2.jpg"
|
file_path = "Tests/images/flower2.jpg"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
expected_icc_profile = image.info['icc_profile']
|
expected_icc_profile = image.info['icc_profile']
|
||||||
|
@ -79,15 +83,18 @@ def test_write_icc_metadata():
|
||||||
|
|
||||||
webp_icc_profile = webp_image.info.get('icc_profile', None)
|
webp_icc_profile = webp_image.info.get('icc_profile', None)
|
||||||
|
|
||||||
assert_true(webp_icc_profile)
|
self.assertTrue(webp_icc_profile)
|
||||||
if webp_icc_profile:
|
if webp_icc_profile:
|
||||||
assert_equal(webp_icc_profile, expected_icc_profile, "Webp ICC didn't match")
|
self.assertEqual(
|
||||||
|
webp_icc_profile, expected_icc_profile,
|
||||||
|
"Webp ICC didn't match")
|
||||||
|
|
||||||
|
def test_read_no_exif(self):
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
def test_read_no_exif():
|
|
||||||
file_path = "Tests/images/flower.jpg"
|
file_path = "Tests/images/flower.jpg"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
expected_exif = image.info['exif']
|
image.info['exif']
|
||||||
|
|
||||||
buffer = BytesIO()
|
buffer = BytesIO()
|
||||||
|
|
||||||
|
@ -96,6 +103,10 @@ def test_read_no_exif():
|
||||||
buffer.seek(0)
|
buffer.seek(0)
|
||||||
webp_image = Image.open(buffer)
|
webp_image = Image.open(buffer)
|
||||||
|
|
||||||
assert_false(webp_image._getexif())
|
self.assertFalse(webp_image._getexif())
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -25,10 +25,20 @@ static char basic_bits[] = {
|
||||||
};
|
};
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def test_pil151():
|
|
||||||
|
class TestFileXbm(PillowTestCase):
|
||||||
|
|
||||||
|
def test_pil151(self):
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
im = Image.open(BytesIO(PIL151))
|
im = Image.open(BytesIO(PIL151))
|
||||||
|
|
||||||
assert_no_exception(lambda: im.load())
|
im.load()
|
||||||
assert_equal(im.mode, '1')
|
self.assertEqual(im.mode, '1')
|
||||||
assert_equal(im.size, (32, 32))
|
self.assertEqual(im.size, (32, 32))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -6,9 +6,18 @@ from PIL import Image
|
||||||
file = "Images/lena.xpm"
|
file = "Images/lena.xpm"
|
||||||
data = open(file, "rb").read()
|
data = open(file, "rb").read()
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFileXpm(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
im.load()
|
im.load()
|
||||||
assert_equal(im.mode, "P")
|
self.assertEqual(im.mode, "P")
|
||||||
assert_equal(im.size, (128, 128))
|
self.assertEqual(im.size, (128, 128))
|
||||||
assert_equal(im.format, "XPM")
|
self.assertEqual(im.format, "XPM")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,13 +1,22 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image, FontFile, BdfFontFile
|
from PIL import FontFile, BdfFontFile
|
||||||
|
|
||||||
filename = "Images/courB08.bdf"
|
filename = "Images/courB08.bdf"
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestFontBdf(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
file = open(filename, "rb")
|
file = open(filename, "rb")
|
||||||
font = BdfFontFile.BdfFontFile(file)
|
font = BdfFontFile.BdfFontFile(file)
|
||||||
|
|
||||||
assert_true(isinstance(font, FontFile.FontFile))
|
self.assertIsInstance(font, FontFile.FontFile)
|
||||||
assert_equal(len([_f for _f in font.glyph if _f]), 190)
|
self.assertEqual(len([_f for _f in font.glyph if _f]), 190)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,49 +1,63 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image, FontFile, PcfFontFile
|
from PIL import Image, FontFile, PcfFontFile
|
||||||
from PIL import ImageFont, ImageDraw
|
from PIL import ImageFont, ImageDraw
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
|
||||||
skip("zlib support not available")
|
|
||||||
|
|
||||||
fontname = "Tests/fonts/helvO18.pcf"
|
fontname = "Tests/fonts/helvO18.pcf"
|
||||||
tempname = tempfile("temp.pil", "temp.pbm")
|
|
||||||
|
|
||||||
message = "hello, world"
|
message = "hello, world"
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
|
||||||
|
class TestFontPcf(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
||||||
|
self.skipTest("zlib support not available")
|
||||||
|
|
||||||
|
def save_font(self):
|
||||||
file = open(fontname, "rb")
|
file = open(fontname, "rb")
|
||||||
font = PcfFontFile.PcfFontFile(file)
|
font = PcfFontFile.PcfFontFile(file)
|
||||||
assert_true(isinstance(font, FontFile.FontFile))
|
self.assertIsInstance(font, FontFile.FontFile)
|
||||||
assert_equal(len([_f for _f in font.glyph if _f]), 192)
|
self.assertEqual(len([_f for _f in font.glyph if _f]), 192)
|
||||||
|
|
||||||
|
tempname = self.tempfile("temp.pil", "temp.pbm")
|
||||||
font.save(tempname)
|
font.save(tempname)
|
||||||
|
return tempname
|
||||||
|
|
||||||
def xtest_draw():
|
def test_sanity(self):
|
||||||
|
self.save_font()
|
||||||
|
|
||||||
|
def xtest_draw(self):
|
||||||
|
|
||||||
|
tempname = self.save_font()
|
||||||
font = ImageFont.load(tempname)
|
font = ImageFont.load(tempname)
|
||||||
image = Image.new("L", font.getsize(message), "white")
|
image = Image.new("L", font.getsize(message), "white")
|
||||||
draw = ImageDraw.Draw(image)
|
draw = ImageDraw.Draw(image)
|
||||||
draw.text((0, 0), message, font=font)
|
draw.text((0, 0), message, font=font)
|
||||||
# assert_signature(image, "7216c60f988dea43a46bb68321e3c1b03ec62aee")
|
# assert_signature(image, "7216c60f988dea43a46bb68321e3c1b03ec62aee")
|
||||||
|
|
||||||
def _test_high_characters(message):
|
def _test_high_characters(self, message):
|
||||||
|
|
||||||
|
tempname = self.save_font()
|
||||||
font = ImageFont.load(tempname)
|
font = ImageFont.load(tempname)
|
||||||
image = Image.new("L", font.getsize(message), "white")
|
image = Image.new("L", font.getsize(message), "white")
|
||||||
draw = ImageDraw.Draw(image)
|
draw = ImageDraw.Draw(image)
|
||||||
draw.text((0, 0), message, font=font)
|
draw.text((0, 0), message, font=font)
|
||||||
|
|
||||||
compare = Image.open('Tests/images/high_ascii_chars.png')
|
compare = Image.open('Tests/images/high_ascii_chars.png')
|
||||||
assert_image_equal(image, compare)
|
self.assert_image_equal(image, compare)
|
||||||
|
|
||||||
def test_high_characters():
|
def test_high_characters(self):
|
||||||
message = "".join([chr(i+1) for i in range(140,232)])
|
message = "".join([chr(i+1) for i in range(140, 232)])
|
||||||
_test_high_characters(message)
|
self._test_high_characters(message)
|
||||||
# accept bytes instances in Py3.
|
# accept bytes instances in Py3.
|
||||||
if bytes is not str:
|
if bytes is not str:
|
||||||
_test_high_characters(message.encode('latin1'))
|
self._test_high_characters(message.encode('latin1'))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,41 +1,48 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_white():
|
|
||||||
|
class TestFormatLab(PillowTestCase):
|
||||||
|
|
||||||
|
def test_white(self):
|
||||||
i = Image.open('Tests/images/lab.tif')
|
i = Image.open('Tests/images/lab.tif')
|
||||||
|
|
||||||
bits = i.load()
|
i.load()
|
||||||
|
|
||||||
assert_equal(i.mode, 'LAB')
|
self.assertEqual(i.mode, 'LAB')
|
||||||
|
|
||||||
assert_equal(i.getbands(), ('L','A', 'B'))
|
self.assertEqual(i.getbands(), ('L', 'A', 'B'))
|
||||||
|
|
||||||
k = i.getpixel((0,0))
|
k = i.getpixel((0, 0))
|
||||||
assert_equal(k, (255,128,128))
|
self.assertEqual(k, (255, 128, 128))
|
||||||
|
|
||||||
L = i.getdata(0)
|
L = i.getdata(0)
|
||||||
a = i.getdata(1)
|
a = i.getdata(1)
|
||||||
b = i.getdata(2)
|
b = i.getdata(2)
|
||||||
|
|
||||||
assert_equal(list(L), [255]*100)
|
self.assertEqual(list(L), [255]*100)
|
||||||
assert_equal(list(a), [128]*100)
|
self.assertEqual(list(a), [128]*100)
|
||||||
assert_equal(list(b), [128]*100)
|
self.assertEqual(list(b), [128]*100)
|
||||||
|
|
||||||
|
def test_green(self):
|
||||||
def test_green():
|
|
||||||
# l= 50 (/100), a = -100 (-128 .. 128) b=0 in PS
|
# l= 50 (/100), a = -100 (-128 .. 128) b=0 in PS
|
||||||
# == RGB: 0, 152, 117
|
# == RGB: 0, 152, 117
|
||||||
i = Image.open('Tests/images/lab-green.tif')
|
i = Image.open('Tests/images/lab-green.tif')
|
||||||
|
|
||||||
k = i.getpixel((0,0))
|
k = i.getpixel((0, 0))
|
||||||
assert_equal(k, (128,28,128))
|
self.assertEqual(k, (128, 28, 128))
|
||||||
|
|
||||||
|
def test_red(self):
|
||||||
def test_red():
|
|
||||||
# l= 50 (/100), a = 100 (-128 .. 128) b=0 in PS
|
# l= 50 (/100), a = 100 (-128 .. 128) b=0 in PS
|
||||||
# == RGB: 255, 0, 124
|
# == RGB: 255, 0, 124
|
||||||
i = Image.open('Tests/images/lab-red.tif')
|
i = Image.open('Tests/images/lab-red.tif')
|
||||||
|
|
||||||
k = i.getpixel((0,0))
|
k = i.getpixel((0, 0))
|
||||||
assert_equal(k, (128,228,128))
|
self.assertEqual(k, (128, 228, 128))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,39 +1,51 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImage(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = Image.new("L", (100, 100))
|
im = Image.new("L", (100, 100))
|
||||||
assert_equal(repr(im)[:45], "<PIL.Image.Image image mode=L size=100x100 at")
|
self.assertEqual(
|
||||||
assert_equal(im.mode, "L")
|
repr(im)[:45], "<PIL.Image.Image image mode=L size=100x100 at")
|
||||||
assert_equal(im.size, (100, 100))
|
self.assertEqual(im.mode, "L")
|
||||||
|
self.assertEqual(im.size, (100, 100))
|
||||||
|
|
||||||
im = Image.new("RGB", (100, 100))
|
im = Image.new("RGB", (100, 100))
|
||||||
assert_equal(repr(im)[:45], "<PIL.Image.Image image mode=RGB size=100x100 ")
|
self.assertEqual(
|
||||||
assert_equal(im.mode, "RGB")
|
repr(im)[:45], "<PIL.Image.Image image mode=RGB size=100x100 ")
|
||||||
assert_equal(im.size, (100, 100))
|
self.assertEqual(im.mode, "RGB")
|
||||||
|
self.assertEqual(im.size, (100, 100))
|
||||||
|
|
||||||
im1 = Image.new("L", (100, 100), None)
|
Image.new("L", (100, 100), None)
|
||||||
im2 = Image.new("L", (100, 100), 0)
|
im2 = Image.new("L", (100, 100), 0)
|
||||||
im3 = Image.new("L", (100, 100), "black")
|
im3 = Image.new("L", (100, 100), "black")
|
||||||
|
|
||||||
assert_equal(im2.getcolors(), [(10000, 0)])
|
self.assertEqual(im2.getcolors(), [(10000, 0)])
|
||||||
assert_equal(im3.getcolors(), [(10000, 0)])
|
self.assertEqual(im3.getcolors(), [(10000, 0)])
|
||||||
|
|
||||||
assert_exception(ValueError, lambda: Image.new("X", (100, 100)))
|
self.assertRaises(ValueError, lambda: Image.new("X", (100, 100)))
|
||||||
# assert_exception(MemoryError, lambda: Image.new("L", (1000000, 1000000)))
|
# self.assertRaises(
|
||||||
|
# MemoryError, lambda: Image.new("L", (1000000, 1000000)))
|
||||||
|
|
||||||
def test_internals():
|
def test_internals(self):
|
||||||
|
|
||||||
im = Image.new("L", (100, 100))
|
im = Image.new("L", (100, 100))
|
||||||
im.readonly = 1
|
im.readonly = 1
|
||||||
im._copy()
|
im._copy()
|
||||||
assert_false(im.readonly)
|
self.assertFalse(im.readonly)
|
||||||
|
|
||||||
im.readonly = 1
|
im.readonly = 1
|
||||||
im.paste(0, (0, 0, 100, 100))
|
im.paste(0, (0, 0, 100, 100))
|
||||||
assert_false(im.readonly)
|
self.assertFalse(im.readonly)
|
||||||
|
|
||||||
file = tempfile("temp.ppm")
|
file = self.tempfile("temp.ppm")
|
||||||
im._dump(file)
|
im._dump(file)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,22 +1,29 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
im = lena().resize((128, 100))
|
im = lena().resize((128, 100))
|
||||||
|
|
||||||
def test_toarray():
|
|
||||||
|
class TestImageCrop(PillowTestCase):
|
||||||
|
|
||||||
|
def test_toarray(self):
|
||||||
def test(mode):
|
def test(mode):
|
||||||
ai = im.convert(mode).__array_interface__
|
ai = im.convert(mode).__array_interface__
|
||||||
return ai["shape"], ai["typestr"], len(ai["data"])
|
return ai["shape"], ai["typestr"], len(ai["data"])
|
||||||
# assert_equal(test("1"), ((100, 128), '|b1', 1600))
|
# self.assertEqual(test("1"), ((100, 128), '|b1', 1600))
|
||||||
assert_equal(test("L"), ((100, 128), '|u1', 12800))
|
self.assertEqual(test("L"), ((100, 128), '|u1', 12800))
|
||||||
assert_equal(test("I"), ((100, 128), Image._ENDIAN + 'i4', 51200)) # FIXME: wrong?
|
|
||||||
assert_equal(test("F"), ((100, 128), Image._ENDIAN + 'f4', 51200)) # FIXME: wrong?
|
|
||||||
assert_equal(test("RGB"), ((100, 128, 3), '|u1', 38400))
|
|
||||||
assert_equal(test("RGBA"), ((100, 128, 4), '|u1', 51200))
|
|
||||||
assert_equal(test("RGBX"), ((100, 128, 4), '|u1', 51200))
|
|
||||||
|
|
||||||
def test_fromarray():
|
# FIXME: wrong?
|
||||||
|
self.assertEqual(test("I"), ((100, 128), Image._ENDIAN + 'i4', 51200))
|
||||||
|
# FIXME: wrong?
|
||||||
|
self.assertEqual(test("F"), ((100, 128), Image._ENDIAN + 'f4', 51200))
|
||||||
|
|
||||||
|
self.assertEqual(test("RGB"), ((100, 128, 3), '|u1', 38400))
|
||||||
|
self.assertEqual(test("RGBA"), ((100, 128, 4), '|u1', 51200))
|
||||||
|
self.assertEqual(test("RGBX"), ((100, 128, 4), '|u1', 51200))
|
||||||
|
|
||||||
|
def test_fromarray(self):
|
||||||
def test(mode):
|
def test(mode):
|
||||||
i = im.convert(mode)
|
i = im.convert(mode)
|
||||||
a = i.__array_interface__
|
a = i.__array_interface__
|
||||||
|
@ -24,10 +31,16 @@ def test_fromarray():
|
||||||
i.__array_interface__ = a # patch in new version of attribute
|
i.__array_interface__ = a # patch in new version of attribute
|
||||||
out = Image.fromarray(i)
|
out = Image.fromarray(i)
|
||||||
return out.mode, out.size, list(i.getdata()) == list(out.getdata())
|
return out.mode, out.size, list(i.getdata()) == list(out.getdata())
|
||||||
# assert_equal(test("1"), ("1", (128, 100), True))
|
# self.assertEqual(test("1"), ("1", (128, 100), True))
|
||||||
assert_equal(test("L"), ("L", (128, 100), True))
|
self.assertEqual(test("L"), ("L", (128, 100), True))
|
||||||
assert_equal(test("I"), ("I", (128, 100), True))
|
self.assertEqual(test("I"), ("I", (128, 100), True))
|
||||||
assert_equal(test("F"), ("F", (128, 100), True))
|
self.assertEqual(test("F"), ("F", (128, 100), True))
|
||||||
assert_equal(test("RGB"), ("RGB", (128, 100), True))
|
self.assertEqual(test("RGB"), ("RGB", (128, 100), True))
|
||||||
assert_equal(test("RGBA"), ("RGBA", (128, 100), True))
|
self.assertEqual(test("RGBA"), ("RGBA", (128, 100), True))
|
||||||
assert_equal(test("RGBX"), ("RGBA", (128, 100), True))
|
self.assertEqual(test("RGBX"), ("RGBA", (128, 100), True))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,84 +1,78 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImageConvert(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
def convert(im, mode):
|
def convert(im, mode):
|
||||||
out = im.convert(mode)
|
out = im.convert(mode)
|
||||||
assert_equal(out.mode, mode)
|
self.assertEqual(out.mode, mode)
|
||||||
assert_equal(out.size, im.size)
|
self.assertEqual(out.size, im.size)
|
||||||
|
|
||||||
modes = "1", "L", "I", "F", "RGB", "RGBA", "RGBX", "CMYK", "YCbCr"
|
modes = "1", "L", "I", "F", "RGB", "RGBA", "RGBX", "CMYK", "YCbCr"
|
||||||
|
|
||||||
for mode in modes:
|
for mode in modes:
|
||||||
im = lena(mode)
|
im = lena(mode)
|
||||||
for mode in modes:
|
for mode in modes:
|
||||||
yield_test(convert, im, mode)
|
convert(im, mode)
|
||||||
|
|
||||||
|
def test_default(self):
|
||||||
def test_default():
|
|
||||||
|
|
||||||
im = lena("P")
|
im = lena("P")
|
||||||
assert_image(im, "P", im.size)
|
self.assert_image(im, "P", im.size)
|
||||||
im = im.convert()
|
im = im.convert()
|
||||||
assert_image(im, "RGB", im.size)
|
self.assert_image(im, "RGB", im.size)
|
||||||
im = im.convert()
|
im = im.convert()
|
||||||
assert_image(im, "RGB", im.size)
|
self.assert_image(im, "RGB", im.size)
|
||||||
|
|
||||||
|
# ref https://github.com/python-pillow/Pillow/issues/274
|
||||||
|
|
||||||
# ref https://github.com/python-imaging/Pillow/issues/274
|
def _test_float_conversion(self, im):
|
||||||
|
|
||||||
def _test_float_conversion(im):
|
|
||||||
orig = im.getpixel((5, 5))
|
orig = im.getpixel((5, 5))
|
||||||
converted = im.convert('F').getpixel((5, 5))
|
converted = im.convert('F').getpixel((5, 5))
|
||||||
assert_equal(orig, converted)
|
self.assertEqual(orig, converted)
|
||||||
|
|
||||||
|
def test_8bit(self):
|
||||||
def test_8bit():
|
|
||||||
im = Image.open('Images/lena.jpg')
|
im = Image.open('Images/lena.jpg')
|
||||||
_test_float_conversion(im.convert('L'))
|
self._test_float_conversion(im.convert('L'))
|
||||||
|
|
||||||
|
def test_16bit(self):
|
||||||
def test_16bit():
|
|
||||||
im = Image.open('Tests/images/16bit.cropped.tif')
|
im = Image.open('Tests/images/16bit.cropped.tif')
|
||||||
_test_float_conversion(im)
|
self._test_float_conversion(im)
|
||||||
|
|
||||||
|
def test_16bit_workaround(self):
|
||||||
def test_16bit_workaround():
|
|
||||||
im = Image.open('Tests/images/16bit.cropped.tif')
|
im = Image.open('Tests/images/16bit.cropped.tif')
|
||||||
_test_float_conversion(im.convert('I'))
|
self._test_float_conversion(im.convert('I'))
|
||||||
|
|
||||||
|
def test_rgba_p(self):
|
||||||
def test_rgba_p():
|
|
||||||
im = lena('RGBA')
|
im = lena('RGBA')
|
||||||
im.putalpha(lena('L'))
|
im.putalpha(lena('L'))
|
||||||
|
|
||||||
converted = im.convert('P')
|
converted = im.convert('P')
|
||||||
comparable = converted.convert('RGBA')
|
comparable = converted.convert('RGBA')
|
||||||
|
|
||||||
assert_image_similar(im, comparable, 20)
|
self.assert_image_similar(im, comparable, 20)
|
||||||
|
|
||||||
|
def test_trns_p(self):
|
||||||
def test_trns_p():
|
|
||||||
im = lena('P')
|
im = lena('P')
|
||||||
im.info['transparency'] = 0
|
im.info['transparency'] = 0
|
||||||
|
|
||||||
f = tempfile('temp.png')
|
f = self.tempfile('temp.png')
|
||||||
|
|
||||||
l = im.convert('L')
|
l = im.convert('L')
|
||||||
assert_equal(l.info['transparency'], 0) # undone
|
self.assertEqual(l.info['transparency'], 0) # undone
|
||||||
assert_no_exception(lambda: l.save(f))
|
l.save(f)
|
||||||
|
|
||||||
rgb = im.convert('RGB')
|
rgb = im.convert('RGB')
|
||||||
assert_equal(rgb.info['transparency'], (0, 0, 0)) # undone
|
self.assertEqual(rgb.info['transparency'], (0, 0, 0)) # undone
|
||||||
assert_no_exception(lambda: rgb.save(f))
|
rgb.save(f)
|
||||||
|
|
||||||
|
# ref https://github.com/python-pillow/Pillow/issues/664
|
||||||
|
|
||||||
# ref https://github.com/python-imaging/Pillow/issues/664
|
def test_trns_p_rgba(self):
|
||||||
|
|
||||||
def test_trns_p_rgba():
|
|
||||||
# Arrange
|
# Arrange
|
||||||
im = lena('P')
|
im = lena('P')
|
||||||
im.info['transparency'] = 128
|
im.info['transparency'] = 128
|
||||||
|
@ -87,44 +81,50 @@ def test_trns_p_rgba():
|
||||||
rgba = im.convert('RGBA')
|
rgba = im.convert('RGBA')
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert_false('transparency' in rgba.info)
|
self.assertNotIn('transparency', rgba.info)
|
||||||
|
|
||||||
|
def test_trns_l(self):
|
||||||
def test_trns_l():
|
|
||||||
im = lena('L')
|
im = lena('L')
|
||||||
im.info['transparency'] = 128
|
im.info['transparency'] = 128
|
||||||
|
|
||||||
f = tempfile('temp.png')
|
f = self.tempfile('temp.png')
|
||||||
|
|
||||||
rgb = im.convert('RGB')
|
rgb = im.convert('RGB')
|
||||||
assert_equal(rgb.info['transparency'], (128, 128, 128)) # undone
|
self.assertEqual(rgb.info['transparency'], (128, 128, 128)) # undone
|
||||||
assert_no_exception(lambda: rgb.save(f))
|
rgb.save(f)
|
||||||
|
|
||||||
p = im.convert('P')
|
p = im.convert('P')
|
||||||
assert_true('transparency' in p.info)
|
self.assertIn('transparency', p.info)
|
||||||
assert_no_exception(lambda: p.save(f))
|
p.save(f)
|
||||||
|
|
||||||
p = assert_warning(UserWarning,
|
p = self.assert_warning(
|
||||||
|
UserWarning,
|
||||||
lambda: im.convert('P', palette=Image.ADAPTIVE))
|
lambda: im.convert('P', palette=Image.ADAPTIVE))
|
||||||
assert_false('transparency' in p.info)
|
self.assertNotIn('transparency', p.info)
|
||||||
assert_no_exception(lambda: p.save(f))
|
p.save(f)
|
||||||
|
|
||||||
|
def test_trns_RGB(self):
|
||||||
def test_trns_RGB():
|
|
||||||
im = lena('RGB')
|
im = lena('RGB')
|
||||||
im.info['transparency'] = im.getpixel((0, 0))
|
im.info['transparency'] = im.getpixel((0, 0))
|
||||||
|
|
||||||
f = tempfile('temp.png')
|
f = self.tempfile('temp.png')
|
||||||
|
|
||||||
l = im.convert('L')
|
l = im.convert('L')
|
||||||
assert_equal(l.info['transparency'], l.getpixel((0, 0))) # undone
|
self.assertEqual(l.info['transparency'], l.getpixel((0, 0))) # undone
|
||||||
assert_no_exception(lambda: l.save(f))
|
l.save(f)
|
||||||
|
|
||||||
p = im.convert('P')
|
p = im.convert('P')
|
||||||
assert_true('transparency' in p.info)
|
self.assertIn('transparency', p.info)
|
||||||
assert_no_exception(lambda: p.save(f))
|
p.save(f)
|
||||||
|
|
||||||
p = assert_warning(UserWarning,
|
p = self.assert_warning(
|
||||||
|
UserWarning,
|
||||||
lambda: im.convert('P', palette=Image.ADAPTIVE))
|
lambda: im.convert('P', palette=Image.ADAPTIVE))
|
||||||
assert_false('transparency' in p.info)
|
self.assertNotIn('transparency', p.info)
|
||||||
assert_no_exception(lambda: p.save(f))
|
p.save(f)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,12 +1,20 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_copy():
|
|
||||||
|
class TestImageCopy(PillowTestCase):
|
||||||
|
|
||||||
|
def test_copy(self):
|
||||||
def copy(mode):
|
def copy(mode):
|
||||||
im = lena(mode)
|
im = lena(mode)
|
||||||
out = im.copy()
|
out = im.copy()
|
||||||
assert_equal(out.mode, mode)
|
self.assertEqual(out.mode, mode)
|
||||||
assert_equal(out.size, im.size)
|
self.assertEqual(out.size, im.size)
|
||||||
for mode in "1", "P", "L", "RGB", "I", "F":
|
for mode in "1", "P", "L", "RGB", "I", "F":
|
||||||
yield_test(copy, mode)
|
copy(mode)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,16 +1,19 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_crop():
|
|
||||||
|
class TestImageCrop(PillowTestCase):
|
||||||
|
|
||||||
|
def test_crop(self):
|
||||||
def crop(mode):
|
def crop(mode):
|
||||||
out = lena(mode).crop((50, 50, 100, 100))
|
out = lena(mode).crop((50, 50, 100, 100))
|
||||||
assert_equal(out.mode, mode)
|
self.assertEqual(out.mode, mode)
|
||||||
assert_equal(out.size, (50, 50))
|
self.assertEqual(out.size, (50, 50))
|
||||||
for mode in "1", "P", "L", "RGB", "I", "F":
|
for mode in "1", "P", "L", "RGB", "I", "F":
|
||||||
yield_test(crop, mode)
|
crop(mode)
|
||||||
|
|
||||||
def test_wide_crop():
|
def test_wide_crop(self):
|
||||||
|
|
||||||
def crop(*bbox):
|
def crop(*bbox):
|
||||||
i = im.crop(bbox)
|
i = im.crop(bbox)
|
||||||
|
@ -21,32 +24,36 @@ def test_wide_crop():
|
||||||
|
|
||||||
im = Image.new("L", (100, 100), 1)
|
im = Image.new("L", (100, 100), 1)
|
||||||
|
|
||||||
assert_equal(crop(0, 0, 100, 100), (0, 10000))
|
self.assertEqual(crop(0, 0, 100, 100), (0, 10000))
|
||||||
assert_equal(crop(25, 25, 75, 75), (0, 2500))
|
self.assertEqual(crop(25, 25, 75, 75), (0, 2500))
|
||||||
|
|
||||||
# sides
|
# sides
|
||||||
assert_equal(crop(-25, 0, 25, 50), (1250, 1250))
|
self.assertEqual(crop(-25, 0, 25, 50), (1250, 1250))
|
||||||
assert_equal(crop(0, -25, 50, 25), (1250, 1250))
|
self.assertEqual(crop(0, -25, 50, 25), (1250, 1250))
|
||||||
assert_equal(crop(75, 0, 125, 50), (1250, 1250))
|
self.assertEqual(crop(75, 0, 125, 50), (1250, 1250))
|
||||||
assert_equal(crop(0, 75, 50, 125), (1250, 1250))
|
self.assertEqual(crop(0, 75, 50, 125), (1250, 1250))
|
||||||
|
|
||||||
assert_equal(crop(-25, 25, 125, 75), (2500, 5000))
|
self.assertEqual(crop(-25, 25, 125, 75), (2500, 5000))
|
||||||
assert_equal(crop(25, -25, 75, 125), (2500, 5000))
|
self.assertEqual(crop(25, -25, 75, 125), (2500, 5000))
|
||||||
|
|
||||||
# corners
|
# corners
|
||||||
assert_equal(crop(-25, -25, 25, 25), (1875, 625))
|
self.assertEqual(crop(-25, -25, 25, 25), (1875, 625))
|
||||||
assert_equal(crop(75, -25, 125, 25), (1875, 625))
|
self.assertEqual(crop(75, -25, 125, 25), (1875, 625))
|
||||||
assert_equal(crop(75, 75, 125, 125), (1875, 625))
|
self.assertEqual(crop(75, 75, 125, 125), (1875, 625))
|
||||||
assert_equal(crop(-25, 75, 25, 125), (1875, 625))
|
self.assertEqual(crop(-25, 75, 25, 125), (1875, 625))
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
def test_negative_crop(self):
|
||||||
|
|
||||||
def test_negative_crop():
|
|
||||||
# Check negative crop size (@PIL171)
|
# Check negative crop size (@PIL171)
|
||||||
|
|
||||||
im = Image.new("L", (512, 512))
|
im = Image.new("L", (512, 512))
|
||||||
im = im.crop((400, 400, 200, 200))
|
im = im.crop((400, 400, 200, 200))
|
||||||
|
|
||||||
assert_equal(im.size, (0, 0))
|
self.assertEqual(im.size, (0, 0))
|
||||||
assert_equal(len(im.getdata()), 0)
|
self.assertEqual(len(im.getdata()), 0)
|
||||||
assert_exception(IndexError, lambda: im.getdata()[0])
|
self.assertRaises(IndexError, lambda: im.getdata()[0])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,30 +1,39 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, fromstring, tostring
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if "jpeg_encoder" not in codecs or "jpeg_decoder" not in codecs:
|
|
||||||
skip("jpeg support not available")
|
|
||||||
|
|
||||||
filename = "Images/lena.jpg"
|
filename = "Images/lena.jpg"
|
||||||
|
|
||||||
data = tostring(Image.open(filename).resize((512, 512)), "JPEG")
|
data = tostring(Image.open(filename).resize((512, 512)), "JPEG")
|
||||||
|
|
||||||
|
|
||||||
def draft(mode, size):
|
def draft(mode, size):
|
||||||
im = fromstring(data)
|
im = fromstring(data)
|
||||||
im.draft(mode, size)
|
im.draft(mode, size)
|
||||||
return im
|
return im
|
||||||
|
|
||||||
def test_size():
|
|
||||||
assert_equal(draft("RGB", (512, 512)).size, (512, 512))
|
|
||||||
assert_equal(draft("RGB", (256, 256)).size, (256, 256))
|
|
||||||
assert_equal(draft("RGB", (128, 128)).size, (128, 128))
|
|
||||||
assert_equal(draft("RGB", (64, 64)).size, (64, 64))
|
|
||||||
assert_equal(draft("RGB", (32, 32)).size, (64, 64))
|
|
||||||
|
|
||||||
def test_mode():
|
class TestImageDraft(PillowTestCase):
|
||||||
assert_equal(draft("1", (512, 512)).mode, "RGB")
|
|
||||||
assert_equal(draft("L", (512, 512)).mode, "L")
|
def setUp(self):
|
||||||
assert_equal(draft("RGB", (512, 512)).mode, "RGB")
|
if "jpeg_encoder" not in codecs or "jpeg_decoder" not in codecs:
|
||||||
assert_equal(draft("YCbCr", (512, 512)).mode, "YCbCr")
|
self.skipTest("jpeg support not available")
|
||||||
|
|
||||||
|
def test_size(self):
|
||||||
|
self.assertEqual(draft("RGB", (512, 512)).size, (512, 512))
|
||||||
|
self.assertEqual(draft("RGB", (256, 256)).size, (256, 256))
|
||||||
|
self.assertEqual(draft("RGB", (128, 128)).size, (128, 128))
|
||||||
|
self.assertEqual(draft("RGB", (64, 64)).size, (64, 64))
|
||||||
|
self.assertEqual(draft("RGB", (32, 32)).size, (64, 64))
|
||||||
|
|
||||||
|
def test_mode(self):
|
||||||
|
self.assertEqual(draft("1", (512, 512)).mode, "RGB")
|
||||||
|
self.assertEqual(draft("L", (512, 512)).mode, "L")
|
||||||
|
self.assertEqual(draft("RGB", (512, 512)).mode, "RGB")
|
||||||
|
self.assertEqual(draft("YCbCr", (512, 512)).mode, "YCbCr")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,15 +1,18 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
from PIL import ImageFilter
|
from PIL import ImageFilter
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageFilter(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
def filter(filter):
|
def filter(filter):
|
||||||
im = lena("L")
|
im = lena("L")
|
||||||
out = im.filter(filter)
|
out = im.filter(filter)
|
||||||
assert_equal(out.mode, im.mode)
|
self.assertEqual(out.mode, im.mode)
|
||||||
assert_equal(out.size, im.size)
|
self.assertEqual(out.size, im.size)
|
||||||
|
|
||||||
filter(ImageFilter.BLUR)
|
filter(ImageFilter.BLUR)
|
||||||
filter(ImageFilter.CONTOUR)
|
filter(ImageFilter.CONTOUR)
|
||||||
|
@ -27,21 +30,21 @@ def test_sanity():
|
||||||
filter(ImageFilter.ModeFilter)
|
filter(ImageFilter.ModeFilter)
|
||||||
filter(ImageFilter.Kernel((3, 3), list(range(9))))
|
filter(ImageFilter.Kernel((3, 3), list(range(9))))
|
||||||
|
|
||||||
assert_exception(TypeError, lambda: filter("hello"))
|
self.assertRaises(TypeError, lambda: filter("hello"))
|
||||||
|
|
||||||
def test_crash():
|
def test_crash(self):
|
||||||
|
|
||||||
# crashes on small images
|
# crashes on small images
|
||||||
im = Image.new("RGB", (1, 1))
|
im = Image.new("RGB", (1, 1))
|
||||||
assert_no_exception(lambda: im.filter(ImageFilter.SMOOTH))
|
im.filter(ImageFilter.SMOOTH)
|
||||||
|
|
||||||
im = Image.new("RGB", (2, 2))
|
im = Image.new("RGB", (2, 2))
|
||||||
assert_no_exception(lambda: im.filter(ImageFilter.SMOOTH))
|
im.filter(ImageFilter.SMOOTH)
|
||||||
|
|
||||||
im = Image.new("RGB", (3, 3))
|
im = Image.new("RGB", (3, 3))
|
||||||
assert_no_exception(lambda: im.filter(ImageFilter.SMOOTH))
|
im.filter(ImageFilter.SMOOTH)
|
||||||
|
|
||||||
def test_modefilter():
|
def test_modefilter(self):
|
||||||
|
|
||||||
def modefilter(mode):
|
def modefilter(mode):
|
||||||
im = Image.new(mode, (3, 3), None)
|
im = Image.new(mode, (3, 3), None)
|
||||||
|
@ -55,12 +58,12 @@ def test_modefilter():
|
||||||
mod2 = im.filter(ImageFilter.ModeFilter).getpixel((1, 1))
|
mod2 = im.filter(ImageFilter.ModeFilter).getpixel((1, 1))
|
||||||
return mod, mod2
|
return mod, mod2
|
||||||
|
|
||||||
assert_equal(modefilter("1"), (4, 0))
|
self.assertEqual(modefilter("1"), (4, 0))
|
||||||
assert_equal(modefilter("L"), (4, 0))
|
self.assertEqual(modefilter("L"), (4, 0))
|
||||||
assert_equal(modefilter("P"), (4, 0))
|
self.assertEqual(modefilter("P"), (4, 0))
|
||||||
assert_equal(modefilter("RGB"), ((4, 0, 0), (0, 0, 0)))
|
self.assertEqual(modefilter("RGB"), ((4, 0, 0), (0, 0, 0)))
|
||||||
|
|
||||||
def test_rankfilter():
|
def test_rankfilter(self):
|
||||||
|
|
||||||
def rankfilter(mode):
|
def rankfilter(mode):
|
||||||
im = Image.new(mode, (3, 3), None)
|
im = Image.new(mode, (3, 3), None)
|
||||||
|
@ -74,9 +77,15 @@ def test_rankfilter():
|
||||||
max = im.filter(ImageFilter.MaxFilter).getpixel((1, 1))
|
max = im.filter(ImageFilter.MaxFilter).getpixel((1, 1))
|
||||||
return min, med, max
|
return min, med, max
|
||||||
|
|
||||||
assert_equal(rankfilter("1"), (0, 4, 8))
|
self.assertEqual(rankfilter("1"), (0, 4, 8))
|
||||||
assert_equal(rankfilter("L"), (0, 4, 8))
|
self.assertEqual(rankfilter("L"), (0, 4, 8))
|
||||||
assert_exception(ValueError, lambda: rankfilter("P"))
|
self.assertRaises(ValueError, lambda: rankfilter("P"))
|
||||||
assert_equal(rankfilter("RGB"), ((0, 0, 0), (4, 0, 0), (8, 0, 0)))
|
self.assertEqual(rankfilter("RGB"), ((0, 0, 0), (4, 0, 0), (8, 0, 0)))
|
||||||
assert_equal(rankfilter("I"), (0, 4, 8))
|
self.assertEqual(rankfilter("I"), (0, 4, 8))
|
||||||
assert_equal(rankfilter("F"), (0.0, 4.0, 8.0))
|
self.assertEqual(rankfilter("F"), (0.0, 4.0, 8.0))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,10 +1,18 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageFromBytes(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im1 = lena()
|
im1 = lena()
|
||||||
im2 = Image.frombytes(im1.mode, im1.size, im1.tobytes())
|
im2 = Image.frombytes(im1.mode, im1.size, im1.tobytes())
|
||||||
|
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,15 +1,26 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_getbands():
|
|
||||||
|
|
||||||
assert_equal(Image.new("1", (1, 1)).getbands(), ("1",))
|
class TestImageGetBands(PillowTestCase):
|
||||||
assert_equal(Image.new("L", (1, 1)).getbands(), ("L",))
|
|
||||||
assert_equal(Image.new("I", (1, 1)).getbands(), ("I",))
|
def test_getbands(self):
|
||||||
assert_equal(Image.new("F", (1, 1)).getbands(), ("F",))
|
self.assertEqual(Image.new("1", (1, 1)).getbands(), ("1",))
|
||||||
assert_equal(Image.new("P", (1, 1)).getbands(), ("P",))
|
self.assertEqual(Image.new("L", (1, 1)).getbands(), ("L",))
|
||||||
assert_equal(Image.new("RGB", (1, 1)).getbands(), ("R", "G", "B"))
|
self.assertEqual(Image.new("I", (1, 1)).getbands(), ("I",))
|
||||||
assert_equal(Image.new("RGBA", (1, 1)).getbands(), ("R", "G", "B", "A"))
|
self.assertEqual(Image.new("F", (1, 1)).getbands(), ("F",))
|
||||||
assert_equal(Image.new("CMYK", (1, 1)).getbands(), ("C", "M", "Y", "K"))
|
self.assertEqual(Image.new("P", (1, 1)).getbands(), ("P",))
|
||||||
assert_equal(Image.new("YCbCr", (1, 1)).getbands(), ("Y", "Cb", "Cr"))
|
self.assertEqual(Image.new("RGB", (1, 1)).getbands(), ("R", "G", "B"))
|
||||||
|
self.assertEqual(
|
||||||
|
Image.new("RGBA", (1, 1)).getbands(), ("R", "G", "B", "A"))
|
||||||
|
self.assertEqual(
|
||||||
|
Image.new("CMYK", (1, 1)).getbands(), ("C", "M", "Y", "K"))
|
||||||
|
self.assertEqual(
|
||||||
|
Image.new("YCbCr", (1, 1)).getbands(), ("Y", "Cb", "Cr"))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,36 +1,45 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageGetBbox(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
bbox = lena().getbbox()
|
bbox = lena().getbbox()
|
||||||
assert_true(isinstance(bbox, tuple))
|
self.assertIsInstance(bbox, tuple)
|
||||||
|
|
||||||
def test_bbox():
|
def test_bbox(self):
|
||||||
|
|
||||||
# 8-bit mode
|
# 8-bit mode
|
||||||
im = Image.new("L", (100, 100), 0)
|
im = Image.new("L", (100, 100), 0)
|
||||||
assert_equal(im.getbbox(), None)
|
self.assertEqual(im.getbbox(), None)
|
||||||
|
|
||||||
im.paste(255, (10, 25, 90, 75))
|
im.paste(255, (10, 25, 90, 75))
|
||||||
assert_equal(im.getbbox(), (10, 25, 90, 75))
|
self.assertEqual(im.getbbox(), (10, 25, 90, 75))
|
||||||
|
|
||||||
im.paste(255, (25, 10, 75, 90))
|
im.paste(255, (25, 10, 75, 90))
|
||||||
assert_equal(im.getbbox(), (10, 10, 90, 90))
|
self.assertEqual(im.getbbox(), (10, 10, 90, 90))
|
||||||
|
|
||||||
im.paste(255, (-10, -10, 110, 110))
|
im.paste(255, (-10, -10, 110, 110))
|
||||||
assert_equal(im.getbbox(), (0, 0, 100, 100))
|
self.assertEqual(im.getbbox(), (0, 0, 100, 100))
|
||||||
|
|
||||||
# 32-bit mode
|
# 32-bit mode
|
||||||
im = Image.new("RGB", (100, 100), 0)
|
im = Image.new("RGB", (100, 100), 0)
|
||||||
assert_equal(im.getbbox(), None)
|
self.assertEqual(im.getbbox(), None)
|
||||||
|
|
||||||
im.paste(255, (10, 25, 90, 75))
|
im.paste(255, (10, 25, 90, 75))
|
||||||
assert_equal(im.getbbox(), (10, 25, 90, 75))
|
self.assertEqual(im.getbbox(), (10, 25, 90, 75))
|
||||||
|
|
||||||
im.paste(255, (25, 10, 75, 90))
|
im.paste(255, (25, 10, 75, 90))
|
||||||
assert_equal(im.getbbox(), (10, 10, 90, 90))
|
self.assertEqual(im.getbbox(), (10, 10, 90, 90))
|
||||||
|
|
||||||
im.paste(255, (-10, -10, 110, 110))
|
im.paste(255, (-10, -10, 110, 110))
|
||||||
assert_equal(im.getbbox(), (0, 0, 100, 100))
|
self.assertEqual(im.getbbox(), (0, 0, 100, 100))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_getcolors():
|
class TestImageGetColors(PillowTestCase):
|
||||||
|
|
||||||
|
def test_getcolors(self):
|
||||||
|
|
||||||
def getcolors(mode, limit=None):
|
def getcolors(mode, limit=None):
|
||||||
im = lena(mode)
|
im = lena(mode)
|
||||||
|
@ -14,51 +15,60 @@ def test_getcolors():
|
||||||
return len(colors)
|
return len(colors)
|
||||||
return None
|
return None
|
||||||
|
|
||||||
assert_equal(getcolors("1"), 2)
|
self.assertEqual(getcolors("1"), 2)
|
||||||
assert_equal(getcolors("L"), 193)
|
self.assertEqual(getcolors("L"), 193)
|
||||||
assert_equal(getcolors("I"), 193)
|
self.assertEqual(getcolors("I"), 193)
|
||||||
assert_equal(getcolors("F"), 193)
|
self.assertEqual(getcolors("F"), 193)
|
||||||
assert_equal(getcolors("P"), 54) # fixed palette
|
self.assertEqual(getcolors("P"), 54) # fixed palette
|
||||||
assert_equal(getcolors("RGB"), None)
|
self.assertEqual(getcolors("RGB"), None)
|
||||||
assert_equal(getcolors("RGBA"), None)
|
self.assertEqual(getcolors("RGBA"), None)
|
||||||
assert_equal(getcolors("CMYK"), None)
|
self.assertEqual(getcolors("CMYK"), None)
|
||||||
assert_equal(getcolors("YCbCr"), None)
|
self.assertEqual(getcolors("YCbCr"), None)
|
||||||
|
|
||||||
assert_equal(getcolors("L", 128), None)
|
self.assertEqual(getcolors("L", 128), None)
|
||||||
assert_equal(getcolors("L", 1024), 193)
|
self.assertEqual(getcolors("L", 1024), 193)
|
||||||
|
|
||||||
assert_equal(getcolors("RGB", 8192), None)
|
self.assertEqual(getcolors("RGB", 8192), None)
|
||||||
assert_equal(getcolors("RGB", 16384), 14836)
|
self.assertEqual(getcolors("RGB", 16384), 14836)
|
||||||
assert_equal(getcolors("RGB", 100000), 14836)
|
self.assertEqual(getcolors("RGB", 100000), 14836)
|
||||||
|
|
||||||
assert_equal(getcolors("RGBA", 16384), 14836)
|
self.assertEqual(getcolors("RGBA", 16384), 14836)
|
||||||
assert_equal(getcolors("CMYK", 16384), 14836)
|
self.assertEqual(getcolors("CMYK", 16384), 14836)
|
||||||
assert_equal(getcolors("YCbCr", 16384), 11995)
|
self.assertEqual(getcolors("YCbCr", 16384), 11995)
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
# --------------------------------------------------------------------
|
||||||
|
|
||||||
def test_pack():
|
def test_pack(self):
|
||||||
# Pack problems for small tables (@PIL209)
|
# Pack problems for small tables (@PIL209)
|
||||||
|
|
||||||
im = lena().quantize(3).convert("RGB")
|
im = lena().quantize(3).convert("RGB")
|
||||||
|
|
||||||
expected = [(3236, (227, 183, 147)), (6297, (143, 84, 81)), (6851, (208, 143, 112))]
|
expected = [
|
||||||
|
(3236, (227, 183, 147)),
|
||||||
|
(6297, (143, 84, 81)),
|
||||||
|
(6851, (208, 143, 112))]
|
||||||
|
|
||||||
A = im.getcolors(maxcolors=2)
|
A = im.getcolors(maxcolors=2)
|
||||||
assert_equal(A, None)
|
self.assertEqual(A, None)
|
||||||
|
|
||||||
A = im.getcolors(maxcolors=3)
|
A = im.getcolors(maxcolors=3)
|
||||||
A.sort()
|
A.sort()
|
||||||
assert_equal(A, expected)
|
self.assertEqual(A, expected)
|
||||||
|
|
||||||
A = im.getcolors(maxcolors=4)
|
A = im.getcolors(maxcolors=4)
|
||||||
A.sort()
|
A.sort()
|
||||||
assert_equal(A, expected)
|
self.assertEqual(A, expected)
|
||||||
|
|
||||||
A = im.getcolors(maxcolors=8)
|
A = im.getcolors(maxcolors=8)
|
||||||
A.sort()
|
A.sort()
|
||||||
assert_equal(A, expected)
|
self.assertEqual(A, expected)
|
||||||
|
|
||||||
A = im.getcolors(maxcolors=16)
|
A = im.getcolors(maxcolors=16)
|
||||||
A.sort()
|
A.sort()
|
||||||
assert_equal(A, expected)
|
self.assertEqual(A, expected)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,28 +1,35 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImageGetData(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
data = lena().getdata()
|
data = lena().getdata()
|
||||||
|
|
||||||
assert_no_exception(lambda: len(data))
|
len(data)
|
||||||
assert_no_exception(lambda: list(data))
|
list(data)
|
||||||
|
|
||||||
assert_equal(data[0], (223, 162, 133))
|
self.assertEqual(data[0], (223, 162, 133))
|
||||||
|
|
||||||
def test_roundtrip():
|
def test_roundtrip(self):
|
||||||
|
|
||||||
def getdata(mode):
|
def getdata(mode):
|
||||||
im = lena(mode).resize((32, 30))
|
im = lena(mode).resize((32, 30))
|
||||||
data = im.getdata()
|
data = im.getdata()
|
||||||
return data[0], len(data), len(list(data))
|
return data[0], len(data), len(list(data))
|
||||||
|
|
||||||
assert_equal(getdata("1"), (255, 960, 960))
|
self.assertEqual(getdata("1"), (255, 960, 960))
|
||||||
assert_equal(getdata("L"), (176, 960, 960))
|
self.assertEqual(getdata("L"), (176, 960, 960))
|
||||||
assert_equal(getdata("I"), (176, 960, 960))
|
self.assertEqual(getdata("I"), (176, 960, 960))
|
||||||
assert_equal(getdata("F"), (176.0, 960, 960))
|
self.assertEqual(getdata("F"), (176.0, 960, 960))
|
||||||
assert_equal(getdata("RGB"), ((223, 162, 133), 960, 960))
|
self.assertEqual(getdata("RGB"), ((223, 162, 133), 960, 960))
|
||||||
assert_equal(getdata("RGBA"), ((223, 162, 133, 255), 960, 960))
|
self.assertEqual(getdata("RGBA"), ((223, 162, 133, 255), 960, 960))
|
||||||
assert_equal(getdata("CMYK"), ((32, 93, 122, 0), 960, 960))
|
self.assertEqual(getdata("CMYK"), ((32, 93, 122, 0), 960, 960))
|
||||||
assert_equal(getdata("YCbCr"), ((176, 103, 160), 960, 960))
|
self.assertEqual(getdata("YCbCr"), ((176, 103, 160), 960, 960))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,17 +1,27 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_extrema():
|
class TestImageGetExtrema(PillowTestCase):
|
||||||
|
|
||||||
|
def test_extrema(self):
|
||||||
|
|
||||||
def extrema(mode):
|
def extrema(mode):
|
||||||
return lena(mode).getextrema()
|
return lena(mode).getextrema()
|
||||||
|
|
||||||
assert_equal(extrema("1"), (0, 255))
|
self.assertEqual(extrema("1"), (0, 255))
|
||||||
assert_equal(extrema("L"), (40, 235))
|
self.assertEqual(extrema("L"), (40, 235))
|
||||||
assert_equal(extrema("I"), (40, 235))
|
self.assertEqual(extrema("I"), (40, 235))
|
||||||
assert_equal(extrema("F"), (40.0, 235.0))
|
self.assertEqual(extrema("F"), (40.0, 235.0))
|
||||||
assert_equal(extrema("P"), (11, 218)) # fixed palette
|
self.assertEqual(extrema("P"), (11, 218)) # fixed palette
|
||||||
assert_equal(extrema("RGB"), ((61, 255), (26, 234), (44, 223)))
|
self.assertEqual(
|
||||||
assert_equal(extrema("RGBA"), ((61, 255), (26, 234), (44, 223), (255, 255)))
|
extrema("RGB"), ((61, 255), (26, 234), (44, 223)))
|
||||||
assert_equal(extrema("CMYK"), ((0, 194), (21, 229), (32, 211), (0, 0)))
|
self.assertEqual(
|
||||||
|
extrema("RGBA"), ((61, 255), (26, 234), (44, 223), (255, 255)))
|
||||||
|
self.assertEqual(
|
||||||
|
extrema("CMYK"), ((0, 194), (21, 229), (32, 211), (0, 0)))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,14 +1,19 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena, py3
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImageGetIm(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = lena()
|
im = lena()
|
||||||
type_repr = repr(type(im.getim()))
|
type_repr = repr(type(im.getim()))
|
||||||
|
|
||||||
if py3:
|
if py3:
|
||||||
assert_true("PyCapsule" in type_repr)
|
self.assertIn("PyCapsule", type_repr)
|
||||||
|
|
||||||
assert_true(isinstance(im.im.id, int))
|
self.assertIsInstance(im.im.id, int)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,19 +1,26 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_palette():
|
class TestImageGetPalette(PillowTestCase):
|
||||||
|
|
||||||
|
def test_palette(self):
|
||||||
def palette(mode):
|
def palette(mode):
|
||||||
p = lena(mode).getpalette()
|
p = lena(mode).getpalette()
|
||||||
if p:
|
if p:
|
||||||
return p[:10]
|
return p[:10]
|
||||||
return None
|
return None
|
||||||
assert_equal(palette("1"), None)
|
self.assertEqual(palette("1"), None)
|
||||||
assert_equal(palette("L"), None)
|
self.assertEqual(palette("L"), None)
|
||||||
assert_equal(palette("I"), None)
|
self.assertEqual(palette("I"), None)
|
||||||
assert_equal(palette("F"), None)
|
self.assertEqual(palette("F"), None)
|
||||||
assert_equal(palette("P"), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
self.assertEqual(palette("P"), [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
||||||
assert_equal(palette("RGB"), None)
|
self.assertEqual(palette("RGB"), None)
|
||||||
assert_equal(palette("RGBA"), None)
|
self.assertEqual(palette("RGBA"), None)
|
||||||
assert_equal(palette("CMYK"), None)
|
self.assertEqual(palette("CMYK"), None)
|
||||||
assert_equal(palette("YCbCr"), None)
|
self.assertEqual(palette("YCbCr"), None)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
Image.USE_CFFI_ACCESS=False
|
Image.USE_CFFI_ACCESS = False
|
||||||
|
|
||||||
|
|
||||||
def color(mode):
|
def color(mode):
|
||||||
bands = Image.getmodebands(mode)
|
bands = Image.getmodebands(mode)
|
||||||
|
@ -12,38 +13,41 @@ def color(mode):
|
||||||
return tuple(range(1, bands+1))
|
return tuple(range(1, bands+1))
|
||||||
|
|
||||||
|
|
||||||
|
class TestImageGetPixel(PillowTestCase):
|
||||||
|
|
||||||
def check(mode, c=None):
|
def check(self, mode, c=None):
|
||||||
if not c:
|
if not c:
|
||||||
c = color(mode)
|
c = color(mode)
|
||||||
|
|
||||||
#check putpixel
|
# check putpixel
|
||||||
im = Image.new(mode, (1, 1), None)
|
im = Image.new(mode, (1, 1), None)
|
||||||
im.putpixel((0, 0), c)
|
im.putpixel((0, 0), c)
|
||||||
assert_equal(im.getpixel((0, 0)), c,
|
self.assertEqual(
|
||||||
"put/getpixel roundtrip failed for mode %s, color %s" %
|
im.getpixel((0, 0)), c,
|
||||||
(mode, c))
|
"put/getpixel roundtrip failed for mode %s, color %s" % (mode, c))
|
||||||
|
|
||||||
# check inital color
|
# check inital color
|
||||||
im = Image.new(mode, (1, 1), c)
|
im = Image.new(mode, (1, 1), c)
|
||||||
assert_equal(im.getpixel((0, 0)), c,
|
self.assertEqual(
|
||||||
"initial color failed for mode %s, color %s " %
|
im.getpixel((0, 0)), c,
|
||||||
(mode, color))
|
"initial color failed for mode %s, color %s " % (mode, color))
|
||||||
|
|
||||||
def test_basic():
|
def test_basic(self):
|
||||||
for mode in ("1", "L", "LA", "I", "I;16", "I;16B", "F",
|
for mode in ("1", "L", "LA", "I", "I;16", "I;16B", "F",
|
||||||
"P", "PA", "RGB", "RGBA", "RGBX", "CMYK","YCbCr"):
|
"P", "PA", "RGB", "RGBA", "RGBX", "CMYK", "YCbCr"):
|
||||||
check(mode)
|
self.check(mode)
|
||||||
|
|
||||||
def test_signedness():
|
def test_signedness(self):
|
||||||
# see https://github.com/python-imaging/Pillow/issues/452
|
# see https://github.com/python-pillow/Pillow/issues/452
|
||||||
# pixelaccess is using signed int* instead of uint*
|
# pixelaccess is using signed int* instead of uint*
|
||||||
for mode in ("I;16", "I;16B"):
|
for mode in ("I;16", "I;16B"):
|
||||||
check(mode, 2**15-1)
|
self.check(mode, 2**15-1)
|
||||||
check(mode, 2**15)
|
self.check(mode, 2**15)
|
||||||
check(mode, 2**15+1)
|
self.check(mode, 2**15+1)
|
||||||
check(mode, 2**16-1)
|
self.check(mode, 2**16-1)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,30 +1,38 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageGetProjection(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
projection = im.getprojection()
|
projection = im.getprojection()
|
||||||
|
|
||||||
assert_equal(len(projection), 2)
|
self.assertEqual(len(projection), 2)
|
||||||
assert_equal(len(projection[0]), im.size[0])
|
self.assertEqual(len(projection[0]), im.size[0])
|
||||||
assert_equal(len(projection[1]), im.size[1])
|
self.assertEqual(len(projection[1]), im.size[1])
|
||||||
|
|
||||||
# 8-bit image
|
# 8-bit image
|
||||||
im = Image.new("L", (10, 10))
|
im = Image.new("L", (10, 10))
|
||||||
assert_equal(im.getprojection()[0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
self.assertEqual(im.getprojection()[0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
||||||
assert_equal(im.getprojection()[1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
self.assertEqual(im.getprojection()[1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
||||||
im.paste(255, (2, 4, 8, 6))
|
im.paste(255, (2, 4, 8, 6))
|
||||||
assert_equal(im.getprojection()[0], [0, 0, 1, 1, 1, 1, 1, 1, 0, 0])
|
self.assertEqual(im.getprojection()[0], [0, 0, 1, 1, 1, 1, 1, 1, 0, 0])
|
||||||
assert_equal(im.getprojection()[1], [0, 0, 0, 0, 1, 1, 0, 0, 0, 0])
|
self.assertEqual(im.getprojection()[1], [0, 0, 0, 0, 1, 1, 0, 0, 0, 0])
|
||||||
|
|
||||||
# 32-bit image
|
# 32-bit image
|
||||||
im = Image.new("RGB", (10, 10))
|
im = Image.new("RGB", (10, 10))
|
||||||
assert_equal(im.getprojection()[0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
self.assertEqual(im.getprojection()[0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
||||||
assert_equal(im.getprojection()[1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
self.assertEqual(im.getprojection()[1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
|
||||||
im.paste(255, (2, 4, 8, 6))
|
im.paste(255, (2, 4, 8, 6))
|
||||||
assert_equal(im.getprojection()[0], [0, 0, 1, 1, 1, 1, 1, 1, 0, 0])
|
self.assertEqual(im.getprojection()[0], [0, 0, 1, 1, 1, 1, 1, 1, 0, 0])
|
||||||
assert_equal(im.getprojection()[1], [0, 0, 0, 0, 1, 1, 0, 0, 0, 0])
|
self.assertEqual(im.getprojection()[1], [0, 0, 0, 0, 1, 1, 0, 0, 0, 0])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,19 +1,26 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_histogram():
|
class TestImageHistogram(PillowTestCase):
|
||||||
|
|
||||||
|
def test_histogram(self):
|
||||||
|
|
||||||
def histogram(mode):
|
def histogram(mode):
|
||||||
h = lena(mode).histogram()
|
h = lena(mode).histogram()
|
||||||
return len(h), min(h), max(h)
|
return len(h), min(h), max(h)
|
||||||
|
|
||||||
assert_equal(histogram("1"), (256, 0, 8872))
|
self.assertEqual(histogram("1"), (256, 0, 8872))
|
||||||
assert_equal(histogram("L"), (256, 0, 199))
|
self.assertEqual(histogram("L"), (256, 0, 199))
|
||||||
assert_equal(histogram("I"), (256, 0, 199))
|
self.assertEqual(histogram("I"), (256, 0, 199))
|
||||||
assert_equal(histogram("F"), (256, 0, 199))
|
self.assertEqual(histogram("F"), (256, 0, 199))
|
||||||
assert_equal(histogram("P"), (256, 0, 2912))
|
self.assertEqual(histogram("P"), (256, 0, 2912))
|
||||||
assert_equal(histogram("RGB"), (768, 0, 285))
|
self.assertEqual(histogram("RGB"), (768, 0, 285))
|
||||||
assert_equal(histogram("RGBA"), (1024, 0, 16384))
|
self.assertEqual(histogram("RGBA"), (1024, 0, 16384))
|
||||||
assert_equal(histogram("CMYK"), (1024, 0, 16384))
|
self.assertEqual(histogram("CMYK"), (1024, 0, 16384))
|
||||||
assert_equal(histogram("YCbCr"), (768, 0, 741))
|
self.assertEqual(histogram("YCbCr"), (768, 0, 741))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,27 +1,35 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageLoad(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
pix = im.load()
|
pix = im.load()
|
||||||
|
|
||||||
assert_equal(pix[0, 0], (223, 162, 133))
|
self.assertEqual(pix[0, 0], (223, 162, 133))
|
||||||
|
|
||||||
def test_close():
|
def test_close(self):
|
||||||
im = Image.open("Images/lena.gif")
|
im = Image.open("Images/lena.gif")
|
||||||
assert_no_exception(lambda: im.close())
|
im.close()
|
||||||
assert_exception(ValueError, lambda: im.load())
|
self.assertRaises(ValueError, lambda: im.load())
|
||||||
assert_exception(ValueError, lambda: im.getpixel((0,0)))
|
self.assertRaises(ValueError, lambda: im.getpixel((0, 0)))
|
||||||
|
|
||||||
def test_contextmanager():
|
def test_contextmanager(self):
|
||||||
fn = None
|
fn = None
|
||||||
with Image.open("Images/lena.gif") as im:
|
with Image.open("Images/lena.gif") as im:
|
||||||
fn = im.fp.fileno()
|
fn = im.fp.fileno()
|
||||||
assert_no_exception(lambda: os.fstat(fn))
|
os.fstat(fn)
|
||||||
|
|
||||||
assert_exception(OSError, lambda: os.fstat(fn))
|
self.assertRaises(OSError, lambda: os.fstat(fn))
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,19 +1,22 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageMode(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
assert_no_exception(lambda: im.mode)
|
im.mode
|
||||||
|
|
||||||
def test_properties():
|
def test_properties(self):
|
||||||
def check(mode, *result):
|
def check(mode, *result):
|
||||||
signature = (
|
signature = (
|
||||||
Image.getmodebase(mode), Image.getmodetype(mode),
|
Image.getmodebase(mode), Image.getmodetype(mode),
|
||||||
Image.getmodebands(mode), Image.getmodebandnames(mode),
|
Image.getmodebands(mode), Image.getmodebandnames(mode),
|
||||||
)
|
)
|
||||||
assert_equal(signature, result)
|
self.assertEqual(signature, result)
|
||||||
check("1", "L", "L", 1, ("1",))
|
check("1", "L", "L", 1, ("1",))
|
||||||
check("L", "L", "L", 1, ("L",))
|
check("L", "L", "L", 1, ("L",))
|
||||||
check("P", "RGB", "L", 1, ("P",))
|
check("P", "RGB", "L", 1, ("P",))
|
||||||
|
@ -25,3 +28,9 @@ def test_properties():
|
||||||
check("RGBX", "RGB", "L", 4, ("R", "G", "B", "X"))
|
check("RGBX", "RGB", "L", 4, ("R", "G", "B", "X"))
|
||||||
check("CMYK", "RGB", "L", 4, ("C", "M", "Y", "K"))
|
check("CMYK", "RGB", "L", 4, ("C", "M", "Y", "K"))
|
||||||
check("YCbCr", "RGB", "L", 3, ("Y", "Cb", "Cr"))
|
check("YCbCr", "RGB", "L", 3, ("Y", "Cb", "Cr"))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,16 +1,25 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_offset():
|
class TestImageOffset(PillowTestCase):
|
||||||
|
|
||||||
|
def test_offset(self):
|
||||||
|
|
||||||
im1 = lena()
|
im1 = lena()
|
||||||
|
|
||||||
im2 = assert_warning(DeprecationWarning, lambda: im1.offset(10))
|
im2 = self.assert_warning(DeprecationWarning, lambda: im1.offset(10))
|
||||||
assert_equal(im1.getpixel((0, 0)), im2.getpixel((10, 10)))
|
self.assertEqual(im1.getpixel((0, 0)), im2.getpixel((10, 10)))
|
||||||
|
|
||||||
im2 = assert_warning(DeprecationWarning, lambda: im1.offset(10, 20))
|
im2 = self.assert_warning(
|
||||||
assert_equal(im1.getpixel((0, 0)), im2.getpixel((10, 20)))
|
DeprecationWarning, lambda: im1.offset(10, 20))
|
||||||
|
self.assertEqual(im1.getpixel((0, 0)), im2.getpixel((10, 20)))
|
||||||
|
|
||||||
im2 = assert_warning(DeprecationWarning, lambda: im1.offset(20, 20))
|
im2 = self.assert_warning(
|
||||||
assert_equal(im1.getpixel((0, 0)), im2.getpixel((20, 20)))
|
DeprecationWarning, lambda: im1.offset(20, 20))
|
||||||
|
self.assertEqual(im1.getpixel((0, 0)), im2.getpixel((20, 20)))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
from tester import *
|
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
success()
|
|
|
@ -1,33 +1,41 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
import sys
|
||||||
|
|
||||||
if hasattr(sys, 'pypy_version_info'):
|
|
||||||
# This takes _forever_ on pypy. Open Bug,
|
|
||||||
# see https://github.com/python-imaging/Pillow/issues/484
|
|
||||||
skip()
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImagePoint(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if hasattr(sys, 'pypy_version_info'):
|
||||||
|
# This takes _forever_ on PyPy. Open Bug,
|
||||||
|
# see https://github.com/python-pillow/Pillow/issues/484
|
||||||
|
self.skipTest("Too slow on PyPy")
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
assert_exception(ValueError, lambda: im.point(list(range(256))))
|
self.assertRaises(ValueError, lambda: im.point(list(range(256))))
|
||||||
assert_no_exception(lambda: im.point(list(range(256))*3))
|
im.point(list(range(256))*3)
|
||||||
assert_no_exception(lambda: im.point(lambda x: x))
|
im.point(lambda x: x)
|
||||||
|
|
||||||
im = im.convert("I")
|
im = im.convert("I")
|
||||||
assert_exception(ValueError, lambda: im.point(list(range(256))))
|
self.assertRaises(ValueError, lambda: im.point(list(range(256))))
|
||||||
assert_no_exception(lambda: im.point(lambda x: x*1))
|
im.point(lambda x: x*1)
|
||||||
assert_no_exception(lambda: im.point(lambda x: x+1))
|
im.point(lambda x: x+1)
|
||||||
assert_no_exception(lambda: im.point(lambda x: x*1+1))
|
im.point(lambda x: x*1+1)
|
||||||
assert_exception(TypeError, lambda: im.point(lambda x: x-1))
|
self.assertRaises(TypeError, lambda: im.point(lambda x: x-1))
|
||||||
assert_exception(TypeError, lambda: im.point(lambda x: x/1))
|
self.assertRaises(TypeError, lambda: im.point(lambda x: x/1))
|
||||||
|
|
||||||
|
def test_16bit_lut(self):
|
||||||
def test_16bit_lut():
|
|
||||||
""" Tests for 16 bit -> 8 bit lut for converting I->L images
|
""" Tests for 16 bit -> 8 bit lut for converting I->L images
|
||||||
see https://github.com/python-imaging/Pillow/issues/440
|
see https://github.com/python-pillow/Pillow/issues/440
|
||||||
"""
|
"""
|
||||||
|
|
||||||
im = lena("I")
|
im = lena("I")
|
||||||
assert_no_exception(lambda: im.point(list(range(256))*256, 'L'))
|
im.point(list(range(256))*256, 'L')
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,43 +1,52 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_interface():
|
|
||||||
|
class TestImagePutAlpha(PillowTestCase):
|
||||||
|
|
||||||
|
def test_interface(self):
|
||||||
|
|
||||||
im = Image.new("RGBA", (1, 1), (1, 2, 3, 0))
|
im = Image.new("RGBA", (1, 1), (1, 2, 3, 0))
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3, 0))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3, 0))
|
||||||
|
|
||||||
im = Image.new("RGBA", (1, 1), (1, 2, 3))
|
im = Image.new("RGBA", (1, 1), (1, 2, 3))
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3, 255))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3, 255))
|
||||||
|
|
||||||
im.putalpha(Image.new("L", im.size, 4))
|
im.putalpha(Image.new("L", im.size, 4))
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3, 4))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3, 4))
|
||||||
|
|
||||||
im.putalpha(5)
|
im.putalpha(5)
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3, 5))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3, 5))
|
||||||
|
|
||||||
def test_promote():
|
def test_promote(self):
|
||||||
|
|
||||||
im = Image.new("L", (1, 1), 1)
|
im = Image.new("L", (1, 1), 1)
|
||||||
assert_equal(im.getpixel((0, 0)), 1)
|
self.assertEqual(im.getpixel((0, 0)), 1)
|
||||||
|
|
||||||
im.putalpha(2)
|
im.putalpha(2)
|
||||||
assert_equal(im.mode, 'LA')
|
self.assertEqual(im.mode, 'LA')
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2))
|
||||||
|
|
||||||
im = Image.new("RGB", (1, 1), (1, 2, 3))
|
im = Image.new("RGB", (1, 1), (1, 2, 3))
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3))
|
||||||
|
|
||||||
im.putalpha(4)
|
im.putalpha(4)
|
||||||
assert_equal(im.mode, 'RGBA')
|
self.assertEqual(im.mode, 'RGBA')
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3, 4))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3, 4))
|
||||||
|
|
||||||
def test_readonly():
|
def test_readonly(self):
|
||||||
|
|
||||||
im = Image.new("RGB", (1, 1), (1, 2, 3))
|
im = Image.new("RGB", (1, 1), (1, 2, 3))
|
||||||
im.readonly = 1
|
im.readonly = 1
|
||||||
|
|
||||||
im.putalpha(4)
|
im.putalpha(4)
|
||||||
assert_false(im.readonly)
|
self.assertFalse(im.readonly)
|
||||||
assert_equal(im.mode, 'RGBA')
|
self.assertEqual(im.mode, 'RGBA')
|
||||||
assert_equal(im.getpixel((0, 0)), (1, 2, 3, 4))
|
self.assertEqual(im.getpixel((0, 0)), (1, 2, 3, 4))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImagePutData(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im1 = lena()
|
im1 = lena()
|
||||||
|
|
||||||
|
@ -13,28 +16,33 @@ def test_sanity():
|
||||||
im2 = Image.new(im1.mode, im1.size, 0)
|
im2 = Image.new(im1.mode, im1.size, 0)
|
||||||
im2.putdata(data)
|
im2.putdata(data)
|
||||||
|
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
|
|
||||||
# readonly
|
# readonly
|
||||||
im2 = Image.new(im1.mode, im2.size, 0)
|
im2 = Image.new(im1.mode, im2.size, 0)
|
||||||
im2.readonly = 1
|
im2.readonly = 1
|
||||||
im2.putdata(data)
|
im2.putdata(data)
|
||||||
|
|
||||||
assert_false(im2.readonly)
|
self.assertFalse(im2.readonly)
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
|
|
||||||
|
def test_long_integers(self):
|
||||||
def test_long_integers():
|
|
||||||
# see bug-200802-systemerror
|
# see bug-200802-systemerror
|
||||||
def put(value):
|
def put(value):
|
||||||
im = Image.new("RGBA", (1, 1))
|
im = Image.new("RGBA", (1, 1))
|
||||||
im.putdata([value])
|
im.putdata([value])
|
||||||
return im.getpixel((0, 0))
|
return im.getpixel((0, 0))
|
||||||
assert_equal(put(0xFFFFFFFF), (255, 255, 255, 255))
|
self.assertEqual(put(0xFFFFFFFF), (255, 255, 255, 255))
|
||||||
assert_equal(put(0xFFFFFFFF), (255, 255, 255, 255))
|
self.assertEqual(put(0xFFFFFFFF), (255, 255, 255, 255))
|
||||||
assert_equal(put(-1), (255, 255, 255, 255))
|
self.assertEqual(put(-1), (255, 255, 255, 255))
|
||||||
assert_equal(put(-1), (255, 255, 255, 255))
|
self.assertEqual(put(-1), (255, 255, 255, 255))
|
||||||
if sys.maxsize > 2**32:
|
if sys.maxsize > 2**32:
|
||||||
assert_equal(put(sys.maxsize), (255, 255, 255, 255))
|
self.assertEqual(put(sys.maxsize), (255, 255, 255, 255))
|
||||||
else:
|
else:
|
||||||
assert_equal(put(sys.maxsize), (255, 255, 255, 127))
|
self.assertEqual(put(sys.maxsize), (255, 255, 255, 127))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
from PIL import ImagePalette
|
from PIL import ImagePalette
|
||||||
|
|
||||||
def test_putpalette():
|
|
||||||
|
class TestImagePutPalette(PillowTestCase):
|
||||||
|
|
||||||
|
def test_putpalette(self):
|
||||||
def palette(mode):
|
def palette(mode):
|
||||||
im = lena(mode).copy()
|
im = lena(mode).copy()
|
||||||
im.putpalette(list(range(256))*3)
|
im.putpalette(list(range(256))*3)
|
||||||
|
@ -11,18 +13,24 @@ def test_putpalette():
|
||||||
if p:
|
if p:
|
||||||
return im.mode, p[:10]
|
return im.mode, p[:10]
|
||||||
return im.mode
|
return im.mode
|
||||||
assert_exception(ValueError, lambda: palette("1"))
|
self.assertRaises(ValueError, lambda: palette("1"))
|
||||||
assert_equal(palette("L"), ("P", [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]))
|
self.assertEqual(palette("L"), ("P", [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]))
|
||||||
assert_equal(palette("P"), ("P", [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]))
|
self.assertEqual(palette("P"), ("P", [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]))
|
||||||
assert_exception(ValueError, lambda: palette("I"))
|
self.assertRaises(ValueError, lambda: palette("I"))
|
||||||
assert_exception(ValueError, lambda: palette("F"))
|
self.assertRaises(ValueError, lambda: palette("F"))
|
||||||
assert_exception(ValueError, lambda: palette("RGB"))
|
self.assertRaises(ValueError, lambda: palette("RGB"))
|
||||||
assert_exception(ValueError, lambda: palette("RGBA"))
|
self.assertRaises(ValueError, lambda: palette("RGBA"))
|
||||||
assert_exception(ValueError, lambda: palette("YCbCr"))
|
self.assertRaises(ValueError, lambda: palette("YCbCr"))
|
||||||
|
|
||||||
def test_imagepalette():
|
def test_imagepalette(self):
|
||||||
im = lena("P")
|
im = lena("P")
|
||||||
assert_no_exception(lambda: im.putpalette(ImagePalette.negative()))
|
im.putpalette(ImagePalette.negative())
|
||||||
assert_no_exception(lambda: im.putpalette(ImagePalette.random()))
|
im.putpalette(ImagePalette.random())
|
||||||
assert_no_exception(lambda: im.putpalette(ImagePalette.sepia()))
|
im.putpalette(ImagePalette.sepia())
|
||||||
assert_no_exception(lambda: im.putpalette(ImagePalette.wedge()))
|
im.putpalette(ImagePalette.wedge())
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
Image.USE_CFFI_ACCESS=False
|
Image.USE_CFFI_ACCESS = False
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImagePutPixel(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im1 = lena()
|
im1 = lena()
|
||||||
im2 = Image.new(im1.mode, im1.size, 0)
|
im2 = Image.new(im1.mode, im1.size, 0)
|
||||||
|
@ -14,7 +17,7 @@ def test_sanity():
|
||||||
pos = x, y
|
pos = x, y
|
||||||
im2.putpixel(pos, im1.getpixel(pos))
|
im2.putpixel(pos, im1.getpixel(pos))
|
||||||
|
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
|
|
||||||
im2 = Image.new(im1.mode, im1.size, 0)
|
im2 = Image.new(im1.mode, im1.size, 0)
|
||||||
im2.readonly = 1
|
im2.readonly = 1
|
||||||
|
@ -24,8 +27,8 @@ def test_sanity():
|
||||||
pos = x, y
|
pos = x, y
|
||||||
im2.putpixel(pos, im1.getpixel(pos))
|
im2.putpixel(pos, im1.getpixel(pos))
|
||||||
|
|
||||||
assert_false(im2.readonly)
|
self.assertFalse(im2.readonly)
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
|
|
||||||
im2 = Image.new(im1.mode, im1.size, 0)
|
im2 = Image.new(im1.mode, im1.size, 0)
|
||||||
|
|
||||||
|
@ -36,10 +39,12 @@ def test_sanity():
|
||||||
for x in range(im1.size[0]):
|
for x in range(im1.size[0]):
|
||||||
pix2[x, y] = pix1[x, y]
|
pix2[x, y] = pix1[x, y]
|
||||||
|
|
||||||
assert_image_equal(im1, im2)
|
self.assert_image_equal(im1, im2)
|
||||||
|
|
||||||
|
# see test_image_getpixel for more tests
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
# see test_image_getpixel for more tests
|
|
||||||
|
|
||||||
|
|
|
@ -1,27 +1,35 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
|
||||||
|
class TestImageQuantize(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
im = im.quantize()
|
im = im.quantize()
|
||||||
assert_image(im, "P", im.size)
|
self.assert_image(im, "P", im.size)
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
im = im.quantize(palette=lena("P"))
|
im = im.quantize(palette=lena("P"))
|
||||||
assert_image(im, "P", im.size)
|
self.assert_image(im, "P", im.size)
|
||||||
|
|
||||||
def test_octree_quantize():
|
def test_octree_quantize(self):
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
im = im.quantize(100, Image.FASTOCTREE)
|
im = im.quantize(100, Image.FASTOCTREE)
|
||||||
assert_image(im, "P", im.size)
|
self.assert_image(im, "P", im.size)
|
||||||
|
|
||||||
assert len(im.getcolors()) == 100
|
assert len(im.getcolors()) == 100
|
||||||
|
|
||||||
def test_rgba_quantize():
|
def test_rgba_quantize(self):
|
||||||
im = lena('RGBA')
|
im = lena('RGBA')
|
||||||
assert_no_exception(lambda: im.quantize())
|
im.quantize()
|
||||||
assert_exception(Exception, lambda: im.quantize(method=0))
|
self.assertRaises(Exception, lambda: im.quantize(method=0))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,12 +1,19 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_resize():
|
class TestImageResize(PillowTestCase):
|
||||||
|
|
||||||
|
def test_resize(self):
|
||||||
def resize(mode, size):
|
def resize(mode, size):
|
||||||
out = lena(mode).resize(size)
|
out = lena(mode).resize(size)
|
||||||
assert_equal(out.mode, mode)
|
self.assertEqual(out.mode, mode)
|
||||||
assert_equal(out.size, size)
|
self.assertEqual(out.size, size)
|
||||||
for mode in "1", "P", "L", "RGB", "I", "F":
|
for mode in "1", "P", "L", "RGB", "I", "F":
|
||||||
yield_test(resize, mode, (100, 100))
|
resize(mode, (100, 100))
|
||||||
yield_test(resize, mode, (200, 200))
|
resize(mode, (200, 200))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,15 +1,22 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_rotate():
|
class TestImageRotate(PillowTestCase):
|
||||||
|
|
||||||
|
def test_rotate(self):
|
||||||
def rotate(mode):
|
def rotate(mode):
|
||||||
im = lena(mode)
|
im = lena(mode)
|
||||||
out = im.rotate(45)
|
out = im.rotate(45)
|
||||||
assert_equal(out.mode, mode)
|
self.assertEqual(out.mode, mode)
|
||||||
assert_equal(out.size, im.size) # default rotate clips output
|
self.assertEqual(out.size, im.size) # default rotate clips output
|
||||||
out = im.rotate(45, expand=1)
|
out = im.rotate(45, expand=1)
|
||||||
assert_equal(out.mode, mode)
|
self.assertEqual(out.mode, mode)
|
||||||
assert_true(out.size != im.size)
|
self.assertNotEqual(out.size, im.size)
|
||||||
for mode in "1", "P", "L", "RGB", "I", "F":
|
for mode in "1", "P", "L", "RGB", "I", "F":
|
||||||
yield_test(rotate, mode)
|
rotate(mode)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
from tester import *
|
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
success()
|
|
|
@ -1,5 +0,0 @@
|
||||||
from tester import *
|
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
success()
|
|
|
@ -1,5 +0,0 @@
|
||||||
from tester import *
|
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
success()
|
|
|
@ -1,49 +1,67 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_split():
|
|
||||||
|
class TestImageSplit(PillowTestCase):
|
||||||
|
|
||||||
|
def test_split(self):
|
||||||
def split(mode):
|
def split(mode):
|
||||||
layers = lena(mode).split()
|
layers = lena(mode).split()
|
||||||
return [(i.mode, i.size[0], i.size[1]) for i in layers]
|
return [(i.mode, i.size[0], i.size[1]) for i in layers]
|
||||||
assert_equal(split("1"), [('1', 128, 128)])
|
self.assertEqual(split("1"), [('1', 128, 128)])
|
||||||
assert_equal(split("L"), [('L', 128, 128)])
|
self.assertEqual(split("L"), [('L', 128, 128)])
|
||||||
assert_equal(split("I"), [('I', 128, 128)])
|
self.assertEqual(split("I"), [('I', 128, 128)])
|
||||||
assert_equal(split("F"), [('F', 128, 128)])
|
self.assertEqual(split("F"), [('F', 128, 128)])
|
||||||
assert_equal(split("P"), [('P', 128, 128)])
|
self.assertEqual(split("P"), [('P', 128, 128)])
|
||||||
assert_equal(split("RGB"), [('L', 128, 128), ('L', 128, 128), ('L', 128, 128)])
|
self.assertEqual(
|
||||||
assert_equal(split("RGBA"), [('L', 128, 128), ('L', 128, 128), ('L', 128, 128), ('L', 128, 128)])
|
split("RGB"), [('L', 128, 128), ('L', 128, 128), ('L', 128, 128)])
|
||||||
assert_equal(split("CMYK"), [('L', 128, 128), ('L', 128, 128), ('L', 128, 128), ('L', 128, 128)])
|
self.assertEqual(
|
||||||
assert_equal(split("YCbCr"), [('L', 128, 128), ('L', 128, 128), ('L', 128, 128)])
|
split("RGBA"),
|
||||||
|
[('L', 128, 128), ('L', 128, 128),
|
||||||
|
('L', 128, 128), ('L', 128, 128)])
|
||||||
|
self.assertEqual(
|
||||||
|
split("CMYK"),
|
||||||
|
[('L', 128, 128), ('L', 128, 128),
|
||||||
|
('L', 128, 128), ('L', 128, 128)])
|
||||||
|
self.assertEqual(
|
||||||
|
split("YCbCr"),
|
||||||
|
[('L', 128, 128), ('L', 128, 128), ('L', 128, 128)])
|
||||||
|
|
||||||
def test_split_merge():
|
def test_split_merge(self):
|
||||||
def split_merge(mode):
|
def split_merge(mode):
|
||||||
return Image.merge(mode, lena(mode).split())
|
return Image.merge(mode, lena(mode).split())
|
||||||
assert_image_equal(lena("1"), split_merge("1"))
|
self.assert_image_equal(lena("1"), split_merge("1"))
|
||||||
assert_image_equal(lena("L"), split_merge("L"))
|
self.assert_image_equal(lena("L"), split_merge("L"))
|
||||||
assert_image_equal(lena("I"), split_merge("I"))
|
self.assert_image_equal(lena("I"), split_merge("I"))
|
||||||
assert_image_equal(lena("F"), split_merge("F"))
|
self.assert_image_equal(lena("F"), split_merge("F"))
|
||||||
assert_image_equal(lena("P"), split_merge("P"))
|
self.assert_image_equal(lena("P"), split_merge("P"))
|
||||||
assert_image_equal(lena("RGB"), split_merge("RGB"))
|
self.assert_image_equal(lena("RGB"), split_merge("RGB"))
|
||||||
assert_image_equal(lena("RGBA"), split_merge("RGBA"))
|
self.assert_image_equal(lena("RGBA"), split_merge("RGBA"))
|
||||||
assert_image_equal(lena("CMYK"), split_merge("CMYK"))
|
self.assert_image_equal(lena("CMYK"), split_merge("CMYK"))
|
||||||
assert_image_equal(lena("YCbCr"), split_merge("YCbCr"))
|
self.assert_image_equal(lena("YCbCr"), split_merge("YCbCr"))
|
||||||
|
|
||||||
def test_split_open():
|
def test_split_open(self):
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
if 'zip_encoder' in codecs:
|
if 'zip_encoder' in codecs:
|
||||||
file = tempfile("temp.png")
|
file = self.tempfile("temp.png")
|
||||||
else:
|
else:
|
||||||
file = tempfile("temp.pcx")
|
file = self.tempfile("temp.pcx")
|
||||||
|
|
||||||
def split_open(mode):
|
def split_open(mode):
|
||||||
lena(mode).save(file)
|
lena(mode).save(file)
|
||||||
im = Image.open(file)
|
im = Image.open(file)
|
||||||
return len(im.split())
|
return len(im.split())
|
||||||
assert_equal(split_open("1"), 1)
|
self.assertEqual(split_open("1"), 1)
|
||||||
assert_equal(split_open("L"), 1)
|
self.assertEqual(split_open("L"), 1)
|
||||||
assert_equal(split_open("P"), 1)
|
self.assertEqual(split_open("P"), 1)
|
||||||
assert_equal(split_open("RGB"), 3)
|
self.assertEqual(split_open("RGB"), 3)
|
||||||
if 'zip_encoder' in codecs:
|
if 'zip_encoder' in codecs:
|
||||||
assert_equal(split_open("RGBA"), 4)
|
self.assertEqual(split_open("RGBA"), 4)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
from tester import *
|
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
success()
|
|
|
@ -1,36 +1,43 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImageThumbnail(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
im.thumbnail((100, 100))
|
im.thumbnail((100, 100))
|
||||||
|
|
||||||
assert_image(im, im.mode, (100, 100))
|
self.assert_image(im, im.mode, (100, 100))
|
||||||
|
|
||||||
def test_aspect():
|
def test_aspect(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
im.thumbnail((100, 100))
|
im.thumbnail((100, 100))
|
||||||
assert_image(im, im.mode, (100, 100))
|
self.assert_image(im, im.mode, (100, 100))
|
||||||
|
|
||||||
im = lena().resize((128, 256))
|
im = lena().resize((128, 256))
|
||||||
im.thumbnail((100, 100))
|
im.thumbnail((100, 100))
|
||||||
assert_image(im, im.mode, (50, 100))
|
self.assert_image(im, im.mode, (50, 100))
|
||||||
|
|
||||||
im = lena().resize((128, 256))
|
im = lena().resize((128, 256))
|
||||||
im.thumbnail((50, 100))
|
im.thumbnail((50, 100))
|
||||||
assert_image(im, im.mode, (50, 100))
|
self.assert_image(im, im.mode, (50, 100))
|
||||||
|
|
||||||
im = lena().resize((256, 128))
|
im = lena().resize((256, 128))
|
||||||
im.thumbnail((100, 100))
|
im.thumbnail((100, 100))
|
||||||
assert_image(im, im.mode, (100, 50))
|
self.assert_image(im, im.mode, (100, 50))
|
||||||
|
|
||||||
im = lena().resize((256, 128))
|
im = lena().resize((256, 128))
|
||||||
im.thumbnail((100, 50))
|
im.thumbnail((100, 50))
|
||||||
assert_image(im, im.mode, (100, 50))
|
self.assert_image(im, im.mode, (100, 50))
|
||||||
|
|
||||||
im = lena().resize((128, 128))
|
im = lena().resize((128, 128))
|
||||||
im.thumbnail((100, 100))
|
im.thumbnail((100, 100))
|
||||||
assert_image(im, im.mode, (100, 100))
|
self.assert_image(im, im.mode, (100, 100))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,15 +1,22 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena, fromstring
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImageToBitmap(PillowTestCase):
|
||||||
|
|
||||||
assert_exception(ValueError, lambda: lena().tobitmap())
|
def test_sanity(self):
|
||||||
assert_no_exception(lambda: lena().convert("1").tobitmap())
|
|
||||||
|
self.assertRaises(ValueError, lambda: lena().tobitmap())
|
||||||
|
lena().convert("1").tobitmap()
|
||||||
|
|
||||||
im1 = lena().convert("1")
|
im1 = lena().convert("1")
|
||||||
|
|
||||||
bitmap = im1.tobitmap()
|
bitmap = im1.tobitmap()
|
||||||
|
|
||||||
assert_true(isinstance(bitmap, bytes))
|
self.assertIsInstance(bitmap, bytes)
|
||||||
assert_image_equal(im1, fromstring(bitmap))
|
self.assert_image_equal(im1, fromstring(bitmap))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,7 +1,13 @@
|
||||||
from tester import *
|
from helper import unittest, lena
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
def test_sanity():
|
class TestImageToBytes(unittest.TestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
data = lena().tobytes()
|
data = lena().tobytes()
|
||||||
assert_true(isinstance(data, bytes))
|
self.assertTrue(isinstance(data, bytes))
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,100 +1,103 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
def test_extent():
|
|
||||||
|
class TestImageTransform(PillowTestCase):
|
||||||
|
|
||||||
|
def test_extent(self):
|
||||||
im = lena('RGB')
|
im = lena('RGB')
|
||||||
(w,h) = im.size
|
(w, h) = im.size
|
||||||
transformed = im.transform(im.size, Image.EXTENT,
|
transformed = im.transform(im.size, Image.EXTENT,
|
||||||
(0,0,
|
(0, 0,
|
||||||
w//2,h//2), # ul -> lr
|
w//2, h//2), # ul -> lr
|
||||||
Image.BILINEAR)
|
Image.BILINEAR)
|
||||||
|
|
||||||
|
scaled = im.resize((w*2, h*2), Image.BILINEAR).crop((0, 0, w, h))
|
||||||
|
|
||||||
scaled = im.resize((w*2, h*2), Image.BILINEAR).crop((0,0,w,h))
|
# undone -- precision?
|
||||||
|
self.assert_image_similar(transformed, scaled, 10)
|
||||||
|
|
||||||
assert_image_similar(transformed, scaled, 10) # undone -- precision?
|
def test_quad(self):
|
||||||
|
|
||||||
def test_quad():
|
|
||||||
# one simple quad transform, equivalent to scale & crop upper left quad
|
# one simple quad transform, equivalent to scale & crop upper left quad
|
||||||
im = lena('RGB')
|
im = lena('RGB')
|
||||||
(w,h) = im.size
|
(w, h) = im.size
|
||||||
transformed = im.transform(im.size, Image.QUAD,
|
transformed = im.transform(im.size, Image.QUAD,
|
||||||
(0,0,0,h//2,
|
(0, 0, 0, h//2,
|
||||||
w//2,h//2,w//2,0), # ul -> ccw around quad
|
# ul -> ccw around quad:
|
||||||
|
w//2, h//2, w//2, 0),
|
||||||
Image.BILINEAR)
|
Image.BILINEAR)
|
||||||
|
|
||||||
scaled = im.resize((w*2, h*2), Image.BILINEAR).crop((0,0,w,h))
|
scaled = im.resize((w*2, h*2), Image.BILINEAR).crop((0, 0, w, h))
|
||||||
|
|
||||||
assert_image_equal(transformed, scaled)
|
self.assert_image_equal(transformed, scaled)
|
||||||
|
|
||||||
def test_mesh():
|
def test_mesh(self):
|
||||||
# this should be a checkerboard of halfsized lenas in ul, lr
|
# this should be a checkerboard of halfsized lenas in ul, lr
|
||||||
im = lena('RGBA')
|
im = lena('RGBA')
|
||||||
(w,h) = im.size
|
(w, h) = im.size
|
||||||
transformed = im.transform(im.size, Image.MESH,
|
transformed = im.transform(im.size, Image.MESH,
|
||||||
[((0,0,w//2,h//2), # box
|
[((0, 0, w//2, h//2), # box
|
||||||
(0,0,0,h,
|
(0, 0, 0, h,
|
||||||
w,h,w,0)), # ul -> ccw around quad
|
w, h, w, 0)), # ul -> ccw around quad
|
||||||
((w//2,h//2,w,h), # box
|
((w//2, h//2, w, h), # box
|
||||||
(0,0,0,h,
|
(0, 0, 0, h,
|
||||||
w,h,w,0))], # ul -> ccw around quad
|
w, h, w, 0))], # ul -> ccw around quad
|
||||||
Image.BILINEAR)
|
Image.BILINEAR)
|
||||||
|
|
||||||
#transformed.save('transformed.png')
|
# transformed.save('transformed.png')
|
||||||
|
|
||||||
scaled = im.resize((w//2, h//2), Image.BILINEAR)
|
scaled = im.resize((w//2, h//2), Image.BILINEAR)
|
||||||
|
|
||||||
checker = Image.new('RGBA', im.size)
|
checker = Image.new('RGBA', im.size)
|
||||||
checker.paste(scaled, (0,0))
|
checker.paste(scaled, (0, 0))
|
||||||
checker.paste(scaled, (w//2,h//2))
|
checker.paste(scaled, (w//2, h//2))
|
||||||
|
|
||||||
assert_image_equal(transformed, checker)
|
self.assert_image_equal(transformed, checker)
|
||||||
|
|
||||||
# now, check to see that the extra area is (0,0,0,0)
|
# now, check to see that the extra area is (0, 0, 0, 0)
|
||||||
blank = Image.new('RGBA', (w//2,h//2), (0,0,0,0))
|
blank = Image.new('RGBA', (w//2, h//2), (0, 0, 0, 0))
|
||||||
|
|
||||||
assert_image_equal(blank, transformed.crop((w//2,0,w,h//2)))
|
self.assert_image_equal(blank, transformed.crop((w//2, 0, w, h//2)))
|
||||||
assert_image_equal(blank, transformed.crop((0,h//2,w//2,h)))
|
self.assert_image_equal(blank, transformed.crop((0, h//2, w//2, h)))
|
||||||
|
|
||||||
def _test_alpha_premult(op):
|
def _test_alpha_premult(self, op):
|
||||||
# create image with half white, half black, with the black half transparent.
|
# create image with half white, half black,
|
||||||
|
# with the black half transparent.
|
||||||
# do op,
|
# do op,
|
||||||
# there should be no darkness in the white section.
|
# there should be no darkness in the white section.
|
||||||
im = Image.new('RGBA', (10,10), (0,0,0,0));
|
im = Image.new('RGBA', (10, 10), (0, 0, 0, 0))
|
||||||
im2 = Image.new('RGBA', (5,10), (255,255,255,255));
|
im2 = Image.new('RGBA', (5, 10), (255, 255, 255, 255))
|
||||||
im.paste(im2, (0,0))
|
im.paste(im2, (0, 0))
|
||||||
|
|
||||||
im = op(im, (40,10))
|
im = op(im, (40, 10))
|
||||||
im_background = Image.new('RGB', (40,10), (255,255,255))
|
im_background = Image.new('RGB', (40, 10), (255, 255, 255))
|
||||||
im_background.paste(im, (0,0), im)
|
im_background.paste(im, (0, 0), im)
|
||||||
|
|
||||||
hist = im_background.histogram()
|
hist = im_background.histogram()
|
||||||
assert_equal(40*10, hist[-1])
|
self.assertEqual(40*10, hist[-1])
|
||||||
|
|
||||||
|
def test_alpha_premult_resize(self):
|
||||||
def test_alpha_premult_resize():
|
|
||||||
|
|
||||||
def op (im, sz):
|
|
||||||
return im.resize(sz, Image.LINEAR)
|
|
||||||
|
|
||||||
_test_alpha_premult(op)
|
|
||||||
|
|
||||||
def test_alpha_premult_transform():
|
|
||||||
|
|
||||||
def op(im, sz):
|
def op(im, sz):
|
||||||
(w,h) = im.size
|
return im.resize(sz, Image.LINEAR)
|
||||||
|
|
||||||
|
self._test_alpha_premult(op)
|
||||||
|
|
||||||
|
def test_alpha_premult_transform(self):
|
||||||
|
|
||||||
|
def op(im, sz):
|
||||||
|
(w, h) = im.size
|
||||||
return im.transform(sz, Image.EXTENT,
|
return im.transform(sz, Image.EXTENT,
|
||||||
(0,0,
|
(0, 0,
|
||||||
w,h),
|
w, h),
|
||||||
Image.BILINEAR)
|
Image.BILINEAR)
|
||||||
|
|
||||||
_test_alpha_premult(op)
|
self._test_alpha_premult(op)
|
||||||
|
|
||||||
|
def test_blank_fill(self):
|
||||||
def test_blank_fill():
|
|
||||||
# attempting to hit
|
# attempting to hit
|
||||||
# https://github.com/python-imaging/Pillow/issues/254 reported
|
# https://github.com/python-pillow/Pillow/issues/254 reported
|
||||||
#
|
#
|
||||||
# issue is that transforms with transparent overflow area
|
# issue is that transforms with transparent overflow area
|
||||||
# contained junk from previous images, especially on systems with
|
# contained junk from previous images, especially on systems with
|
||||||
|
@ -107,10 +110,16 @@ def test_blank_fill():
|
||||||
# Running by default, but I'd totally understand not doing it in
|
# Running by default, but I'd totally understand not doing it in
|
||||||
# the future
|
# the future
|
||||||
|
|
||||||
foo = [Image.new('RGBA',(1024,1024), (a,a,a,a))
|
foo = [Image.new('RGBA', (1024, 1024), (a, a, a, a))
|
||||||
for a in range(1,65)]
|
for a in range(1, 65)]
|
||||||
|
|
||||||
# Yeah. Watch some JIT optimize this out.
|
# Yeah. Watch some JIT optimize this out.
|
||||||
foo = None
|
foo = None
|
||||||
|
|
||||||
test_mesh()
|
self.test_mesh()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
|
@ -8,27 +8,37 @@ ROTATE_90 = Image.ROTATE_90
|
||||||
ROTATE_180 = Image.ROTATE_180
|
ROTATE_180 = Image.ROTATE_180
|
||||||
ROTATE_270 = Image.ROTATE_270
|
ROTATE_270 = Image.ROTATE_270
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageTranspose(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
assert_no_exception(lambda: im.transpose(FLIP_LEFT_RIGHT))
|
im.transpose(FLIP_LEFT_RIGHT)
|
||||||
assert_no_exception(lambda: im.transpose(FLIP_TOP_BOTTOM))
|
im.transpose(FLIP_TOP_BOTTOM)
|
||||||
|
|
||||||
assert_no_exception(lambda: im.transpose(ROTATE_90))
|
im.transpose(ROTATE_90)
|
||||||
assert_no_exception(lambda: im.transpose(ROTATE_180))
|
im.transpose(ROTATE_180)
|
||||||
assert_no_exception(lambda: im.transpose(ROTATE_270))
|
im.transpose(ROTATE_270)
|
||||||
|
|
||||||
def test_roundtrip():
|
def test_roundtrip(self):
|
||||||
|
|
||||||
im = lena()
|
im = lena()
|
||||||
|
|
||||||
def transpose(first, second):
|
def transpose(first, second):
|
||||||
return im.transpose(first).transpose(second)
|
return im.transpose(first).transpose(second)
|
||||||
|
|
||||||
assert_image_equal(im, transpose(FLIP_LEFT_RIGHT, FLIP_LEFT_RIGHT))
|
self.assert_image_equal(
|
||||||
assert_image_equal(im, transpose(FLIP_TOP_BOTTOM, FLIP_TOP_BOTTOM))
|
im, transpose(FLIP_LEFT_RIGHT, FLIP_LEFT_RIGHT))
|
||||||
|
self.assert_image_equal(
|
||||||
|
im, transpose(FLIP_TOP_BOTTOM, FLIP_TOP_BOTTOM))
|
||||||
|
|
||||||
assert_image_equal(im, transpose(ROTATE_90, ROTATE_270))
|
self.assert_image_equal(im, transpose(ROTATE_90, ROTATE_270))
|
||||||
assert_image_equal(im, transpose(ROTATE_180, ROTATE_180))
|
self.assert_image_equal(im, transpose(ROTATE_180, ROTATE_180))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
from tester import *
|
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
|
|
||||||
success()
|
|
|
@ -1,9 +1,12 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
from PIL import ImageChops
|
from PIL import ImageChops
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageChops(PillowTestCase):
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
im = lena("L")
|
im = lena("L")
|
||||||
|
|
||||||
|
@ -32,7 +35,7 @@ def test_sanity():
|
||||||
ImageChops.offset(im, 10)
|
ImageChops.offset(im, 10)
|
||||||
ImageChops.offset(im, 10, 20)
|
ImageChops.offset(im, 10, 20)
|
||||||
|
|
||||||
def test_logical():
|
def test_logical(self):
|
||||||
|
|
||||||
def table(op, a, b):
|
def table(op, a, b):
|
||||||
out = []
|
out = []
|
||||||
|
@ -43,14 +46,29 @@ def test_logical():
|
||||||
out.append(op(imx, imy).getpixel((0, 0)))
|
out.append(op(imx, imy).getpixel((0, 0)))
|
||||||
return tuple(out)
|
return tuple(out)
|
||||||
|
|
||||||
assert_equal(table(ImageChops.logical_and, 0, 1), (0, 0, 0, 255))
|
self.assertEqual(
|
||||||
assert_equal(table(ImageChops.logical_or, 0, 1), (0, 255, 255, 255))
|
table(ImageChops.logical_and, 0, 1), (0, 0, 0, 255))
|
||||||
assert_equal(table(ImageChops.logical_xor, 0, 1), (0, 255, 255, 0))
|
self.assertEqual(
|
||||||
|
table(ImageChops.logical_or, 0, 1), (0, 255, 255, 255))
|
||||||
|
self.assertEqual(
|
||||||
|
table(ImageChops.logical_xor, 0, 1), (0, 255, 255, 0))
|
||||||
|
|
||||||
assert_equal(table(ImageChops.logical_and, 0, 128), (0, 0, 0, 255))
|
self.assertEqual(
|
||||||
assert_equal(table(ImageChops.logical_or, 0, 128), (0, 255, 255, 255))
|
table(ImageChops.logical_and, 0, 128), (0, 0, 0, 255))
|
||||||
assert_equal(table(ImageChops.logical_xor, 0, 128), (0, 255, 255, 0))
|
self.assertEqual(
|
||||||
|
table(ImageChops.logical_or, 0, 128), (0, 255, 255, 255))
|
||||||
|
self.assertEqual(
|
||||||
|
table(ImageChops.logical_xor, 0, 128), (0, 255, 255, 0))
|
||||||
|
|
||||||
assert_equal(table(ImageChops.logical_and, 0, 255), (0, 0, 0, 255))
|
self.assertEqual(
|
||||||
assert_equal(table(ImageChops.logical_or, 0, 255), (0, 255, 255, 255))
|
table(ImageChops.logical_and, 0, 255), (0, 0, 0, 255))
|
||||||
assert_equal(table(ImageChops.logical_xor, 0, 255), (0, 255, 255, 0))
|
self.assertEqual(
|
||||||
|
table(ImageChops.logical_or, 0, 255), (0, 255, 255, 255))
|
||||||
|
self.assertEqual(
|
||||||
|
table(ImageChops.logical_xor, 0, 255), (0, 255, 255, 0))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,139 +1,189 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule, lena
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from PIL import ImageCms
|
from PIL import ImageCms
|
||||||
ImageCms.core.profile_open
|
ImageCms.core.profile_open
|
||||||
except ImportError:
|
except ImportError as v:
|
||||||
skip()
|
# Skipped via setUp()
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
SRGB = "Tests/icc/sRGB.icm"
|
SRGB = "Tests/icc/sRGB.icm"
|
||||||
|
|
||||||
def test_sanity():
|
|
||||||
|
class TestImageCms(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
try:
|
||||||
|
from PIL import ImageCms
|
||||||
|
except ImportError as v:
|
||||||
|
self.skipTest(v)
|
||||||
|
|
||||||
|
def test_sanity(self):
|
||||||
|
|
||||||
# basic smoke test.
|
# basic smoke test.
|
||||||
# this mostly follows the cms_test outline.
|
# this mostly follows the cms_test outline.
|
||||||
|
|
||||||
v = ImageCms.versions() # should return four strings
|
v = ImageCms.versions() # should return four strings
|
||||||
assert_equal(v[0], '1.0.0 pil')
|
self.assertEqual(v[0], '1.0.0 pil')
|
||||||
assert_equal(list(map(type, v)), [str, str, str, str])
|
self.assertEqual(list(map(type, v)), [str, str, str, str])
|
||||||
|
|
||||||
# internal version number
|
# internal version number
|
||||||
assert_match(ImageCms.core.littlecms_version, "\d+\.\d+$")
|
self.assertRegexpMatches(ImageCms.core.littlecms_version, "\d+\.\d+$")
|
||||||
|
|
||||||
i = ImageCms.profileToProfile(lena(), SRGB, SRGB)
|
i = ImageCms.profileToProfile(lena(), SRGB, SRGB)
|
||||||
assert_image(i, "RGB", (128, 128))
|
self.assert_image(i, "RGB", (128, 128))
|
||||||
|
|
||||||
|
i = lena()
|
||||||
|
ImageCms.profileToProfile(i, SRGB, SRGB, inPlace=True)
|
||||||
|
self.assert_image(i, "RGB", (128, 128))
|
||||||
|
|
||||||
t = ImageCms.buildTransform(SRGB, SRGB, "RGB", "RGB")
|
t = ImageCms.buildTransform(SRGB, SRGB, "RGB", "RGB")
|
||||||
i = ImageCms.applyTransform(lena(), t)
|
i = ImageCms.applyTransform(lena(), t)
|
||||||
assert_image(i, "RGB", (128, 128))
|
self.assert_image(i, "RGB", (128, 128))
|
||||||
|
|
||||||
|
i = lena()
|
||||||
|
t = ImageCms.buildTransform(SRGB, SRGB, "RGB", "RGB")
|
||||||
|
ImageCms.applyTransform(lena(), t, inPlace=True)
|
||||||
|
self.assert_image(i, "RGB", (128, 128))
|
||||||
|
|
||||||
p = ImageCms.createProfile("sRGB")
|
p = ImageCms.createProfile("sRGB")
|
||||||
o = ImageCms.getOpenProfile(SRGB)
|
o = ImageCms.getOpenProfile(SRGB)
|
||||||
t = ImageCms.buildTransformFromOpenProfiles(p, o, "RGB", "RGB")
|
t = ImageCms.buildTransformFromOpenProfiles(p, o, "RGB", "RGB")
|
||||||
i = ImageCms.applyTransform(lena(), t)
|
i = ImageCms.applyTransform(lena(), t)
|
||||||
assert_image(i, "RGB", (128, 128))
|
self.assert_image(i, "RGB", (128, 128))
|
||||||
|
|
||||||
t = ImageCms.buildProofTransform(SRGB, SRGB, SRGB, "RGB", "RGB")
|
t = ImageCms.buildProofTransform(SRGB, SRGB, SRGB, "RGB", "RGB")
|
||||||
assert_equal(t.inputMode, "RGB")
|
self.assertEqual(t.inputMode, "RGB")
|
||||||
assert_equal(t.outputMode, "RGB")
|
self.assertEqual(t.outputMode, "RGB")
|
||||||
i = ImageCms.applyTransform(lena(), t)
|
i = ImageCms.applyTransform(lena(), t)
|
||||||
assert_image(i, "RGB", (128, 128))
|
self.assert_image(i, "RGB", (128, 128))
|
||||||
|
|
||||||
# test PointTransform convenience API
|
# test PointTransform convenience API
|
||||||
im = lena().point(t)
|
lena().point(t)
|
||||||
|
|
||||||
def test_name():
|
def test_name(self):
|
||||||
# get profile information for file
|
# get profile information for file
|
||||||
assert_equal(ImageCms.getProfileName(SRGB).strip(),
|
self.assertEqual(
|
||||||
|
ImageCms.getProfileName(SRGB).strip(),
|
||||||
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
||||||
def x_test_info():
|
|
||||||
assert_equal(ImageCms.getProfileInfo(SRGB).splitlines(),
|
|
||||||
['sRGB IEC61966-2.1', '',
|
|
||||||
'Copyright (c) 1998 Hewlett-Packard Company', '',
|
|
||||||
'WhitePoint : D65 (daylight)', '',
|
|
||||||
'Tests/icc/sRGB.icm'])
|
|
||||||
|
|
||||||
def test_intent():
|
def test_info(self):
|
||||||
assert_equal(ImageCms.getDefaultIntent(SRGB), 0)
|
self.assertEqual(
|
||||||
assert_equal(ImageCms.isIntentSupported(
|
ImageCms.getProfileInfo(SRGB).splitlines(), [
|
||||||
|
'sRGB IEC61966-2.1', '',
|
||||||
|
'Copyright (c) 1998 Hewlett-Packard Company', ''])
|
||||||
|
|
||||||
|
def test_copyright(self):
|
||||||
|
self.assertEqual(
|
||||||
|
ImageCms.getProfileCopyright(SRGB).strip(),
|
||||||
|
'Copyright (c) 1998 Hewlett-Packard Company')
|
||||||
|
|
||||||
|
def test_manufacturer(self):
|
||||||
|
self.assertEqual(
|
||||||
|
ImageCms.getProfileManufacturer(SRGB).strip(),
|
||||||
|
'IEC http://www.iec.ch')
|
||||||
|
|
||||||
|
def test_model(self):
|
||||||
|
self.assertEqual(
|
||||||
|
ImageCms.getProfileModel(SRGB).strip(),
|
||||||
|
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
||||||
|
|
||||||
|
def test_description(self):
|
||||||
|
self.assertEqual(
|
||||||
|
ImageCms.getProfileDescription(SRGB).strip(),
|
||||||
|
'sRGB IEC61966-2.1')
|
||||||
|
|
||||||
|
def test_intent(self):
|
||||||
|
self.assertEqual(ImageCms.getDefaultIntent(SRGB), 0)
|
||||||
|
self.assertEqual(ImageCms.isIntentSupported(
|
||||||
SRGB, ImageCms.INTENT_ABSOLUTE_COLORIMETRIC,
|
SRGB, ImageCms.INTENT_ABSOLUTE_COLORIMETRIC,
|
||||||
ImageCms.DIRECTION_INPUT), 1)
|
ImageCms.DIRECTION_INPUT), 1)
|
||||||
|
|
||||||
def test_profile_object():
|
def test_profile_object(self):
|
||||||
# same, using profile object
|
# same, using profile object
|
||||||
p = ImageCms.createProfile("sRGB")
|
p = ImageCms.createProfile("sRGB")
|
||||||
# assert_equal(ImageCms.getProfileName(p).strip(),
|
# self.assertEqual(ImageCms.getProfileName(p).strip(),
|
||||||
# 'sRGB built-in - (lcms internal)')
|
# 'sRGB built-in - (lcms internal)')
|
||||||
# assert_equal(ImageCms.getProfileInfo(p).splitlines(),
|
# self.assertEqual(ImageCms.getProfileInfo(p).splitlines(),
|
||||||
# ['sRGB built-in', '', 'WhitePoint : D65 (daylight)', '', ''])
|
# ['sRGB built-in', '', 'WhitePoint : D65 (daylight)', '', ''])
|
||||||
assert_equal(ImageCms.getDefaultIntent(p), 0)
|
self.assertEqual(ImageCms.getDefaultIntent(p), 0)
|
||||||
assert_equal(ImageCms.isIntentSupported(
|
self.assertEqual(ImageCms.isIntentSupported(
|
||||||
p, ImageCms.INTENT_ABSOLUTE_COLORIMETRIC,
|
p, ImageCms.INTENT_ABSOLUTE_COLORIMETRIC,
|
||||||
ImageCms.DIRECTION_INPUT), 1)
|
ImageCms.DIRECTION_INPUT), 1)
|
||||||
|
|
||||||
def test_extensions():
|
def test_extensions(self):
|
||||||
# extensions
|
# extensions
|
||||||
|
from io import BytesIO
|
||||||
i = Image.open("Tests/images/rgb.jpg")
|
i = Image.open("Tests/images/rgb.jpg")
|
||||||
p = ImageCms.getOpenProfile(BytesIO(i.info["icc_profile"]))
|
p = ImageCms.getOpenProfile(BytesIO(i.info["icc_profile"]))
|
||||||
assert_equal(ImageCms.getProfileName(p).strip(),
|
self.assertEqual(
|
||||||
|
ImageCms.getProfileName(p).strip(),
|
||||||
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
'IEC 61966-2.1 Default RGB colour space - sRGB')
|
||||||
|
|
||||||
def test_exceptions():
|
def test_exceptions(self):
|
||||||
# the procedural pyCMS API uses PyCMSError for all sorts of errors
|
# the procedural pyCMS API uses PyCMSError for all sorts of errors
|
||||||
assert_exception(ImageCms.PyCMSError, lambda: ImageCms.profileToProfile(lena(), "foo", "bar"))
|
self.assertRaises(
|
||||||
assert_exception(ImageCms.PyCMSError, lambda: ImageCms.buildTransform("foo", "bar", "RGB", "RGB"))
|
ImageCms.PyCMSError,
|
||||||
assert_exception(ImageCms.PyCMSError, lambda: ImageCms.getProfileName(None))
|
lambda: ImageCms.profileToProfile(lena(), "foo", "bar"))
|
||||||
assert_exception(ImageCms.PyCMSError, lambda: ImageCms.isIntentSupported(SRGB, None, None))
|
self.assertRaises(
|
||||||
|
ImageCms.PyCMSError,
|
||||||
|
lambda: ImageCms.buildTransform("foo", "bar", "RGB", "RGB"))
|
||||||
|
self.assertRaises(
|
||||||
|
ImageCms.PyCMSError,
|
||||||
|
lambda: ImageCms.getProfileName(None))
|
||||||
|
self.assertRaises(
|
||||||
|
ImageCms.PyCMSError,
|
||||||
|
lambda: ImageCms.isIntentSupported(SRGB, None, None))
|
||||||
|
|
||||||
|
def test_display_profile(self):
|
||||||
def test_display_profile():
|
|
||||||
# try fetching the profile for the current display device
|
# try fetching the profile for the current display device
|
||||||
assert_no_exception(lambda: ImageCms.get_display_profile())
|
ImageCms.get_display_profile()
|
||||||
|
|
||||||
|
def test_lab_color_profile(self):
|
||||||
|
ImageCms.createProfile("LAB", 5000)
|
||||||
|
ImageCms.createProfile("LAB", 6500)
|
||||||
|
|
||||||
def test_lab_color_profile():
|
def test_simple_lab(self):
|
||||||
pLab = ImageCms.createProfile("LAB", 5000)
|
i = Image.new('RGB', (10, 10), (128, 128, 128))
|
||||||
pLab = ImageCms.createProfile("LAB", 6500)
|
|
||||||
|
|
||||||
def test_simple_lab():
|
|
||||||
i = Image.new('RGB', (10,10), (128,128,128))
|
|
||||||
|
|
||||||
pLab = ImageCms.createProfile("LAB")
|
pLab = ImageCms.createProfile("LAB")
|
||||||
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
||||||
|
|
||||||
i_lab = ImageCms.applyTransform(i, t)
|
i_lab = ImageCms.applyTransform(i, t)
|
||||||
|
|
||||||
|
self.assertEqual(i_lab.mode, 'LAB')
|
||||||
|
|
||||||
assert_equal(i_lab.mode, 'LAB')
|
k = i_lab.getpixel((0, 0))
|
||||||
|
# not a linear luminance map. so L != 128:
|
||||||
k = i_lab.getpixel((0,0))
|
self.assertEqual(k, (137, 128, 128))
|
||||||
assert_equal(k, (137,128,128)) # not a linear luminance map. so L != 128
|
|
||||||
|
|
||||||
L = i_lab.getdata(0)
|
L = i_lab.getdata(0)
|
||||||
a = i_lab.getdata(1)
|
a = i_lab.getdata(1)
|
||||||
b = i_lab.getdata(2)
|
b = i_lab.getdata(2)
|
||||||
|
|
||||||
assert_equal(list(L), [137]*100)
|
self.assertEqual(list(L), [137] * 100)
|
||||||
assert_equal(list(a), [128]*100)
|
self.assertEqual(list(a), [128] * 100)
|
||||||
assert_equal(list(b), [128]*100)
|
self.assertEqual(list(b), [128] * 100)
|
||||||
|
|
||||||
|
def test_lab_color(self):
|
||||||
def test_lab_color():
|
|
||||||
pLab = ImageCms.createProfile("LAB")
|
pLab = ImageCms.createProfile("LAB")
|
||||||
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
||||||
# need to add a type mapping for some PIL type to TYPE_Lab_8 in findLCMSType,
|
# Need to add a type mapping for some PIL type to TYPE_Lab_8 in
|
||||||
# and have that mapping work back to a PIL mode. (likely RGB)
|
# findLCMSType, and have that mapping work back to a PIL mode
|
||||||
|
# (likely RGB).
|
||||||
i = ImageCms.applyTransform(lena(), t)
|
i = ImageCms.applyTransform(lena(), t)
|
||||||
assert_image(i, "LAB", (128, 128))
|
self.assert_image(i, "LAB", (128, 128))
|
||||||
|
|
||||||
# i.save('temp.lab.tif') # visually verified vs PS.
|
# i.save('temp.lab.tif') # visually verified vs PS.
|
||||||
|
|
||||||
target = Image.open('Tests/images/lena.Lab.tif')
|
target = Image.open('Tests/images/lena.Lab.tif')
|
||||||
|
|
||||||
assert_image_similar(i, target, 30)
|
self.assert_image_similar(i, target, 30)
|
||||||
|
|
||||||
def test_lab_srgb():
|
def test_lab_srgb(self):
|
||||||
pLab = ImageCms.createProfile("LAB")
|
pLab = ImageCms.createProfile("LAB")
|
||||||
t = ImageCms.buildTransform(pLab, SRGB, "LAB", "RGB")
|
t = ImageCms.buildTransform(pLab, SRGB, "LAB", "RGB")
|
||||||
|
|
||||||
|
@ -143,9 +193,9 @@ def test_lab_srgb():
|
||||||
|
|
||||||
# img_srgb.save('temp.srgb.tif') # visually verified vs ps.
|
# img_srgb.save('temp.srgb.tif') # visually verified vs ps.
|
||||||
|
|
||||||
assert_image_similar(lena(), img_srgb, 30)
|
self.assert_image_similar(lena(), img_srgb, 30)
|
||||||
|
|
||||||
def test_lab_roundtrip():
|
def test_lab_roundtrip(self):
|
||||||
# check to see if we're at least internally consistent.
|
# check to see if we're at least internally consistent.
|
||||||
pLab = ImageCms.createProfile("LAB")
|
pLab = ImageCms.createProfile("LAB")
|
||||||
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
t = ImageCms.buildTransform(SRGB, pLab, "RGB", "LAB")
|
||||||
|
@ -155,6 +205,10 @@ def test_lab_roundtrip():
|
||||||
i = ImageCms.applyTransform(lena(), t)
|
i = ImageCms.applyTransform(lena(), t)
|
||||||
out = ImageCms.applyTransform(i, t2)
|
out = ImageCms.applyTransform(i, t2)
|
||||||
|
|
||||||
assert_image_similar(lena(), out, 2)
|
self.assert_image_similar(lena(), out, 2)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|
|
@ -1,54 +1,71 @@
|
||||||
from tester import *
|
from helper import unittest, PillowTestCase, tearDownModule
|
||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
from PIL import ImageColor
|
from PIL import ImageColor
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
|
||||||
# sanity
|
|
||||||
|
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("#f00"))
|
class TestImageColor(PillowTestCase):
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("#ff0000"))
|
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("rgb(255,0,0)"))
|
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("rgb(255, 0, 0)"))
|
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("rgb(100%,0%,0%)"))
|
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("hsl(0, 100%, 50%)"))
|
|
||||||
assert_equal((255, 0, 0, 0), ImageColor.getrgb("rgba(255,0,0,0)"))
|
|
||||||
assert_equal((255, 0, 0, 0), ImageColor.getrgb("rgba(255, 0, 0, 0)"))
|
|
||||||
assert_equal((255, 0, 0), ImageColor.getrgb("red"))
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
def test_sanity(self):
|
||||||
# look for rounding errors (based on code by Tim Hatch)
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("#f00"))
|
||||||
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("#ff0000"))
|
||||||
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("rgb(255,0,0)"))
|
||||||
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("rgb(255, 0, 0)"))
|
||||||
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("rgb(100%,0%,0%)"))
|
||||||
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("hsl(0, 100%, 50%)"))
|
||||||
|
self.assertEqual((255, 0, 0, 0), ImageColor.getrgb("rgba(255,0,0,0)"))
|
||||||
|
self.assertEqual(
|
||||||
|
(255, 0, 0, 0), ImageColor.getrgb("rgba(255, 0, 0, 0)"))
|
||||||
|
self.assertEqual((255, 0, 0), ImageColor.getrgb("red"))
|
||||||
|
|
||||||
for color in list(ImageColor.colormap.keys()):
|
# look for rounding errors (based on code by Tim Hatch)
|
||||||
expected = Image.new("RGB", (1, 1), color).convert("L").getpixel((0, 0))
|
def test_rounding_errors(self):
|
||||||
|
|
||||||
|
for color in list(ImageColor.colormap.keys()):
|
||||||
|
expected = Image.new(
|
||||||
|
"RGB", (1, 1), color).convert("L").getpixel((0, 0))
|
||||||
actual = Image.new("L", (1, 1), color).getpixel((0, 0))
|
actual = Image.new("L", (1, 1), color).getpixel((0, 0))
|
||||||
assert_equal(expected, actual)
|
self.assertEqual(expected, actual)
|
||||||
|
|
||||||
assert_equal((0, 0, 0), ImageColor.getcolor("black", "RGB"))
|
self.assertEqual((0, 0, 0), ImageColor.getcolor("black", "RGB"))
|
||||||
assert_equal((255, 255, 255), ImageColor.getcolor("white", "RGB"))
|
self.assertEqual((255, 255, 255), ImageColor.getcolor("white", "RGB"))
|
||||||
assert_equal((0, 255, 115), ImageColor.getcolor("rgba(0, 255, 115, 33)", "RGB"))
|
self.assertEqual(
|
||||||
Image.new("RGB", (1, 1), "white")
|
(0, 255, 115), ImageColor.getcolor("rgba(0, 255, 115, 33)", "RGB"))
|
||||||
|
Image.new("RGB", (1, 1), "white")
|
||||||
|
|
||||||
assert_equal((0, 0, 0, 255), ImageColor.getcolor("black", "RGBA"))
|
self.assertEqual((0, 0, 0, 255), ImageColor.getcolor("black", "RGBA"))
|
||||||
assert_equal((255, 255, 255, 255), ImageColor.getcolor("white", "RGBA"))
|
self.assertEqual(
|
||||||
assert_equal((0, 255, 115, 33), ImageColor.getcolor("rgba(0, 255, 115, 33)", "RGBA"))
|
(255, 255, 255, 255), ImageColor.getcolor("white", "RGBA"))
|
||||||
Image.new("RGBA", (1, 1), "white")
|
self.assertEqual(
|
||||||
|
(0, 255, 115, 33),
|
||||||
|
ImageColor.getcolor("rgba(0, 255, 115, 33)", "RGBA"))
|
||||||
|
Image.new("RGBA", (1, 1), "white")
|
||||||
|
|
||||||
assert_equal(0, ImageColor.getcolor("black", "L"))
|
self.assertEqual(0, ImageColor.getcolor("black", "L"))
|
||||||
assert_equal(255, ImageColor.getcolor("white", "L"))
|
self.assertEqual(255, ImageColor.getcolor("white", "L"))
|
||||||
assert_equal(162, ImageColor.getcolor("rgba(0, 255, 115, 33)", "L"))
|
self.assertEqual(
|
||||||
Image.new("L", (1, 1), "white")
|
162, ImageColor.getcolor("rgba(0, 255, 115, 33)", "L"))
|
||||||
|
Image.new("L", (1, 1), "white")
|
||||||
|
|
||||||
assert_equal(0, ImageColor.getcolor("black", "1"))
|
self.assertEqual(0, ImageColor.getcolor("black", "1"))
|
||||||
assert_equal(255, ImageColor.getcolor("white", "1"))
|
self.assertEqual(255, ImageColor.getcolor("white", "1"))
|
||||||
# The following test is wrong, but is current behavior
|
# The following test is wrong, but is current behavior
|
||||||
# The correct result should be 255 due to the mode 1
|
# The correct result should be 255 due to the mode 1
|
||||||
assert_equal(162, ImageColor.getcolor("rgba(0, 255, 115, 33)", "1"))
|
self.assertEqual(
|
||||||
# Correct behavior
|
162, ImageColor.getcolor("rgba(0, 255, 115, 33)", "1"))
|
||||||
# assert_equal(255, ImageColor.getcolor("rgba(0, 255, 115, 33)", "1"))
|
# Correct behavior
|
||||||
Image.new("1", (1, 1), "white")
|
# self.assertEqual(
|
||||||
|
# 255, ImageColor.getcolor("rgba(0, 255, 115, 33)", "1"))
|
||||||
|
Image.new("1", (1, 1), "white")
|
||||||
|
|
||||||
assert_equal((0, 255), ImageColor.getcolor("black", "LA"))
|
self.assertEqual((0, 255), ImageColor.getcolor("black", "LA"))
|
||||||
assert_equal((255, 255), ImageColor.getcolor("white", "LA"))
|
self.assertEqual((255, 255), ImageColor.getcolor("white", "LA"))
|
||||||
assert_equal((162, 33), ImageColor.getcolor("rgba(0, 255, 115, 33)", "LA"))
|
self.assertEqual(
|
||||||
Image.new("LA", (1, 1), "white")
|
(162, 33), ImageColor.getcolor("rgba(0, 255, 115, 33)", "LA"))
|
||||||
|
Image.new("LA", (1, 1), "white")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
||||||
|
|
||||||
|
# End of file
|
||||||
|
|