Merge pull request #1166 from radarhere/health

83% Health
This commit is contained in:
Hugo 2015-04-25 22:58:10 +03:00
commit 86616dfc0a
61 changed files with 234 additions and 245 deletions

View File

@ -248,7 +248,7 @@ class EpsImageFile(ImageFile.ImageFile):
# Note: The DSC spec says that BoundingBox # Note: The DSC spec says that BoundingBox
# fields should be integers, but some drivers # fields should be integers, but some drivers
# put floating point values there anyway. # put floating point values there anyway.
box = [int(float(s)) for s in v.split()] box = [int(float(i)) for i in v.split()]
self.size = box[2] - box[0], box[3] - box[1] self.size = box[2] - box[0], box[3] - box[1]
self.tile = [("eps", (0, 0) + self.size, offset, self.tile = [("eps", (0, 0) + self.size, offset,
(length, box))] (length, box))]
@ -288,7 +288,7 @@ class EpsImageFile(ImageFile.ImageFile):
if s[:11] == "%ImageData:": if s[:11] == "%ImageData:":
# Encoded bitmapped image. # Encoded bitmapped image.
[x, y, bi, mo, z3, z4, en, id] = s[11:].split(None, 7) x, y, bi, mo = s[11:].split(None, 7)[:4]
if int(bi) != 8: if int(bi) != 8:
break break

View File

@ -17,11 +17,6 @@
import os import os
from PIL import Image, _binary from PIL import Image, _binary
try:
import zlib
except ImportError:
zlib = None
WIDTH = 800 WIDTH = 800
@ -83,7 +78,8 @@ class FontFile:
glyph = self[i] glyph = self[i]
if glyph: if glyph:
d, dst, src, im = glyph d, dst, src, im = glyph
xx, yy = src[2] - src[0], src[3] - src[1] xx = src[2] - src[0]
# yy = src[3] - src[1]
x0, y0 = x, y x0, y0 = x, y
x = x + xx x = x + xx
if x > WIDTH: if x > WIDTH:

View File

@ -39,8 +39,8 @@ class GbrImageFile(ImageFile.ImageFile):
width = i32(self.fp.read(4)) width = i32(self.fp.read(4))
height = i32(self.fp.read(4)) height = i32(self.fp.read(4))
bytes = i32(self.fp.read(4)) color_depth = i32(self.fp.read(4))
if width <= 0 or height <= 0 or bytes != 1: if width <= 0 or height <= 0 or color_depth != 1:
raise SyntaxError("not a GIMP brush") raise SyntaxError("not a GIMP brush")
comment = self.fp.read(header_size - 20)[:-1] comment = self.fp.read(header_size - 20)[:-1]

View File

@ -94,7 +94,7 @@ def read_32(fobj, start_length, size):
def read_mk(fobj, start_length, size): def read_mk(fobj, start_length, size):
# Alpha masks seem to be uncompressed # Alpha masks seem to be uncompressed
(start, length) = start_length start = start_length[0]
fobj.seek(start) fobj.seek(start)
pixel_size = (size[0] * size[2], size[1] * size[2]) pixel_size = (size[0] * size[2], size[1] * size[2])
sizesq = pixel_size[0] * pixel_size[1] sizesq = pixel_size[0] * pixel_size[1]

View File

@ -313,7 +313,7 @@ SAVE = {
def _save(im, fp, filename, check=0): def _save(im, fp, filename, check=0):
try: try:
type, rawmode = SAVE[im.mode] image_type, rawmode = SAVE[im.mode]
except KeyError: except KeyError:
raise ValueError("Cannot save %s images as IM" % im.mode) raise ValueError("Cannot save %s images as IM" % im.mode)
@ -325,7 +325,7 @@ def _save(im, fp, filename, check=0):
if check: if check:
return check return check
fp.write(("Image type: %s image\r\n" % type).encode('ascii')) fp.write(("Image type: %s image\r\n" % image_type).encode('ascii'))
if filename: if filename:
fp.write(("Name: %s\r\n" % filename).encode('ascii')) fp.write(("Name: %s\r\n" % filename).encode('ascii'))
fp.write(("Image size (x*y): %d*%d\r\n" % im.size).encode('ascii')) fp.write(("Image size (x*y): %d*%d\r\n" % im.size).encode('ascii'))

View File

@ -322,6 +322,7 @@ class Parser:
image = None image = None
data = None data = None
decoder = None decoder = None
offset = 0
finished = 0 finished = 0
def reset(self): def reset(self):

View File

@ -15,7 +15,7 @@
# See the README file for information on usage and redistribution. # See the README file for information on usage and redistribution.
# #
from functools import reduce import functools
class Filter(object): class Filter(object):
@ -43,7 +43,7 @@ class Kernel(Filter):
def __init__(self, size, kernel, scale=None, offset=0): def __init__(self, size, kernel, scale=None, offset=0):
if scale is None: if scale is None:
# default scale is sum of kernel # default scale is sum of kernel
scale = reduce(lambda a, b: a+b, kernel) scale = functools.reduce(lambda a, b: a+b, kernel)
if size[0] * size[1] != len(kernel): if size[0] * size[1] != len(kernel):
raise ValueError("not enough coefficients in kernel") raise ValueError("not enough coefficients in kernel")
self.filterargs = size, scale, offset, kernel self.filterargs = size, scale, offset, kernel

View File

@ -20,7 +20,7 @@
from PIL import Image from PIL import Image
from PIL._util import isStringType from PIL._util import isStringType
import operator import operator
from functools import reduce import functools
# #
@ -213,7 +213,7 @@ def equalize(image, mask=None):
if len(histo) <= 1: if len(histo) <= 1:
lut.extend(list(range(256))) lut.extend(list(range(256)))
else: else:
step = (reduce(operator.add, histo) - histo[-1]) // 255 step = (functools.reduce(operator.add, histo) - histo[-1]) // 255
if not step: if not step:
lut.extend(list(range(256))) lut.extend(list(range(256)))
else: else:
@ -233,7 +233,6 @@ def expand(image, border=0, fill=0):
:param fill: Pixel fill value (a color value). Default is 0 (black). :param fill: Pixel fill value (a color value). Default is 0 (black).
:return: An image. :return: An image.
""" """
"Add border to image"
left, top, right, bottom = _border(border) left, top, right, bottom = _border(border)
width = left + image.size[0] + right width = left + image.size[0] + right
height = top + image.size[1] + bottom height = top + image.size[1] + bottom

View File

@ -225,8 +225,8 @@ def load(filename):
p = PaletteFile.PaletteFile(fp) p = PaletteFile.PaletteFile(fp)
lut = p.getpalette() lut = p.getpalette()
except (SyntaxError, ValueError): except (SyntaxError, ValueError):
import traceback #import traceback
traceback.print_exc() #traceback.print_exc()
pass pass
if not lut: if not lut:

View File

@ -23,7 +23,7 @@
import math import math
import operator import operator
from functools import reduce import functools
class Stat: class Stat:
@ -71,7 +71,7 @@ class Stat:
v = [] v = []
for i in range(0, len(self.h), 256): for i in range(0, len(self.h), 256):
v.append(reduce(operator.add, self.h[i:i+256])) v.append(functools.reduce(operator.add, self.h[i:i+256]))
return v return v
def _getsum(self): def _getsum(self):
@ -79,10 +79,10 @@ class Stat:
v = [] v = []
for i in range(0, len(self.h), 256): for i in range(0, len(self.h), 256):
sum = 0.0 layerSum = 0.0
for j in range(256): for j in range(256):
sum += j * self.h[i + j] layerSum += j * self.h[i + j]
v.append(sum) v.append(layerSum)
return v return v
def _getsum2(self): def _getsum2(self):

View File

@ -222,7 +222,7 @@ def getiptcinfo(im):
offset += 2 offset += 2
# resource name (usually empty) # resource name (usually empty)
name_len = i8(app[offset]) name_len = i8(app[offset])
name = app[offset+1:offset+1+name_len] # name = app[offset+1:offset+1+name_len]
offset = 1 + offset + name_len offset = 1 + offset + name_len
if offset & 1: if offset & 1:
offset += 1 offset += 1

View File

@ -454,13 +454,13 @@ def _getmp(self):
data = self.info["mp"] data = self.info["mp"]
except KeyError: except KeyError:
return None return None
file = io.BytesIO(data) file_contents = io.BytesIO(data)
head = file.read(8) head = file_contents.read(8)
endianness = '>' if head[:4] == b'\x4d\x4d\x00\x2a' else '<' endianness = '>' if head[:4] == b'\x4d\x4d\x00\x2a' else '<'
mp = {} mp = {}
# process dictionary # process dictionary
info = TiffImagePlugin.ImageFileDirectory(head) info = TiffImagePlugin.ImageFileDirectory(head)
info.load(file) info.load(file_contents)
for key, value in info.items(): for key, value in info.items():
mp[key] = _fixup(value) mp[key] = _fixup(value)
# it's an error not to have a number of images # it's an error not to have a number of images

View File

@ -21,7 +21,7 @@ __version__ = "0.1"
from PIL import Image, TiffImagePlugin from PIL import Image, TiffImagePlugin
from PIL.OleFileIO import * from PIL.OleFileIO import MAGIC, OleFileIO
# #
@ -54,9 +54,9 @@ class MicImageFile(TiffImagePlugin.TiffImageFile):
# best way to identify MIC files, but what the... ;-) # best way to identify MIC files, but what the... ;-)
self.images = [] self.images = []
for file in self.ole.listdir(): for path in self.ole.listdir():
if file[1:] and file[0][-4:] == ".ACI" and file[1] == "Image": if path[1:] and path[0][-4:] == ".ACI" and path[1] == "Image":
self.images.append(file) self.images.append(path)
# if we didn't find any images, this is probably not # if we didn't find any images, this is probably not
# an MIC file. # an MIC file.

View File

@ -49,10 +49,10 @@ class MspImageFile(ImageFile.ImageFile):
raise SyntaxError("not an MSP file") raise SyntaxError("not an MSP file")
# Header checksum # Header checksum
sum = 0 checksum = 0
for i in range(0, 32, 2): for i in range(0, 32, 2):
sum = sum ^ i16(s[i:i+2]) checksum = checksum ^ i16(s[i:i+2])
if sum != 0: if checksum != 0:
raise SyntaxError("bad MSP checksum") raise SyntaxError("bad MSP checksum")
self.mode = "1" self.mode = "1"
@ -83,10 +83,10 @@ def _save(im, fp, filename):
header[6], header[7] = 1, 1 header[6], header[7] = 1, 1
header[8], header[9] = im.size header[8], header[9] = im.size
sum = 0 checksum = 0
for h in header: for h in header:
sum = sum ^ h checksum = checksum ^ h
header[12] = sum # FIXME: is this the right field? header[12] = checksum # FIXME: is this the right field?
# header # header
for h in header: for h in header:

View File

@ -360,12 +360,12 @@ WORD_CLSID = "00020900-0000-0000-C000-000000000046"
#TODO: check Excel, PPT, ... #TODO: check Excel, PPT, ...
#[PL]: Defect levels to classify parsing errors - see OleFileIO._raise_defect() #[PL]: Defect levels to classify parsing errors - see OleFileIO._raise_defect()
DEFECT_UNSURE = 10 # a case which looks weird, but not sure it's a defect DEFECT_UNSURE = 10 # a case which looks weird, but not sure it's a defect
DEFECT_POTENTIAL = 20 # a potential defect DEFECT_POTENTIAL = 20 # a potential defect
DEFECT_INCORRECT = 30 # an error according to specifications, but parsing DEFECT_INCORRECT = 30 # an error according to specifications, but parsing
# can go on # can go on
DEFECT_FATAL = 40 # an error which cannot be ignored, parsing is DEFECT_FATAL = 40 # an error which cannot be ignored, parsing is
# impossible # impossible
#[PL] add useful constants to __all__: #[PL] add useful constants to __all__:
for key in list(vars().keys()): for key in list(vars().keys()):
@ -468,14 +468,14 @@ def _unicode(s, errors='replace'):
def filetime2datetime(filetime): def filetime2datetime(filetime):
""" """
convert FILETIME (64 bits int) to Python datetime.datetime convert FILETIME (64 bits int) to Python datetime.datetime
""" """
# TODO: manage exception when microseconds is too large # TODO: manage exception when microseconds is too large
# inspired from http://code.activestate.com/recipes/511425-filetime-to-datetime/ # inspired from http://code.activestate.com/recipes/511425-filetime-to-datetime/
_FILETIME_null_date = datetime.datetime(1601, 1, 1, 0, 0, 0) _FILETIME_null_date = datetime.datetime(1601, 1, 1, 0, 0, 0)
#debug('timedelta days=%d' % (filetime//(10*1000000*3600*24))) #debug('timedelta days=%d' % (filetime//(10*1000000*3600*24)))
return _FILETIME_null_date + datetime.timedelta(microseconds=filetime//10) return _FILETIME_null_date + datetime.timedelta(microseconds=filetime//10)
#=== CLASSES ================================================================== #=== CLASSES ==================================================================

View File

@ -204,7 +204,7 @@ class PcfFontFile(FontFile.FontFile):
for i in range(4): for i in range(4):
bitmapSizes.append(i32(fp.read(4))) bitmapSizes.append(i32(fp.read(4)))
byteorder = format & 4 # non-zero => MSB # byteorder = format & 4 # non-zero => MSB
bitorder = format & 8 # non-zero => MSB bitorder = format & 8 # non-zero => MSB
padindex = format & 3 padindex = format & 3

View File

@ -194,7 +194,7 @@ class _PyAccessI16_L(PyAccess):
pixel = self.pixels[y][x] pixel = self.pixels[y][x]
try: try:
color = min(color, 65535) color = min(color, 65535)
except: except TypeError:
color = min(color[0], 65535) color = min(color[0], 65535)
pixel.l = color & 0xFF pixel.l = color & 0xFF

View File

@ -48,7 +48,7 @@ def isInt(f):
return 1 return 1
else: else:
return 0 return 0
except: except ValueError:
return 0 return 0
iforms = [1, 3, -11, -12, -21, -22] iforms = [1, 3, -11, -12, -21, -22]
@ -173,11 +173,11 @@ class SpiderImageFile(ImageFile.ImageFile):
# returns a byte image after rescaling to 0..255 # returns a byte image after rescaling to 0..255
def convert2byte(self, depth=255): def convert2byte(self, depth=255):
(min, max) = self.getextrema() (minimum, maximum) = self.getextrema()
m = 1 m = 1
if max != min: if maximum != minimum:
m = depth / (max-min) m = depth / (maximum-minimum)
b = -m * min b = -m * minimum
return self.point(lambda i, m=m, b=b: i * m + b).convert("L") return self.point(lambda i, m=m, b=b: i * m + b).convert("L")
# returns a ImageTk.PhotoImage object, after rescaling to 0..255 # returns a ImageTk.PhotoImage object, after rescaling to 0..255
@ -271,7 +271,7 @@ def _save(im, fp, filename):
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) ext = os.path.splitext(filename)[1]
Image.register_extension("SPIDER", ext) Image.register_extension("SPIDER", ext)
_save(im, fp, filename) _save(im, fp, filename)

View File

@ -731,8 +731,8 @@ class TiffImageFile(ImageFile.ImageFile):
# (self._compression, (extents tuple), # (self._compression, (extents tuple),
# 0, (rawmode, self._compression, fp)) # 0, (rawmode, self._compression, fp))
ignored, extents, ignored_2, args = self.tile[0] extents = self.tile[0][1]
args = args + (self.ifd.offset,) args = self.tile[0][3] + (self.ifd.offset,)
decoder = Image._getdecoder(self.mode, 'libtiff', args, decoder = Image._getdecoder(self.mode, 'libtiff', args,
self.decoderconfig) self.decoderconfig)
try: try:
@ -978,7 +978,7 @@ class TiffImageFile(ImageFile.ImageFile):
# fixup palette descriptor # fixup palette descriptor
if self.mode == "P": if self.mode == "P":
palette = [o8(a // 256) for a in self.tag[COLORMAP]] palette = [o8(b // 256) for b in self.tag[COLORMAP]]
self.palette = ImagePalette.raw("RGB;L", b"".join(palette)) self.palette = ImagePalette.raw("RGB;L", b"".join(palette))
# #
# -------------------------------------------------------------------- # --------------------------------------------------------------------

View File

@ -8,9 +8,9 @@
# #
try: try:
from tkinter import * from tkinter import Tk, Toplevel, Frame, Label, Scale, HORIZONTAL
except ImportError: except ImportError:
from Tkinter import * from Tkinter import Tk, Toplevel, Frame, Label, Scale, HORIZONTAL
from PIL import Image, ImageTk, ImageEnhance from PIL import Image, ImageTk, ImageEnhance
import sys import sys

View File

@ -10,9 +10,9 @@
# #
try: try:
from tkinter import * from tkinter import Tk, Canvas, NW
except ImportError: except ImportError:
from Tkinter import * from Tkinter import Tk, Canvas, NW
from PIL import Image, ImageTk from PIL import Image, ImageTk
import sys import sys

View File

@ -49,7 +49,7 @@ except getopt.error as v:
print(v) print(v)
sys.exit(1) sys.exit(1)
format = None output_format = None
convert = None convert = None
options = {} options = {}
@ -68,7 +68,7 @@ for o, a in opt:
sys.exit(1) sys.exit(1)
elif o == "-c": elif o == "-c":
format = a output_format = a
if o == "-g": if o == "-g":
convert = "L" convert = "L"
@ -90,8 +90,8 @@ try:
if convert and im.mode != convert: if convert and im.mode != convert:
im.draft(convert, im.size) im.draft(convert, im.size)
im = im.convert(convert) im = im.convert(convert)
if format: if output_format:
im.save(argv[1], format, **options) im.save(argv[1], output_format, **options)
else: else:
im.save(argv[1], **options) im.save(argv[1], **options)
except: except:

View File

@ -19,7 +19,6 @@
from __future__ import print_function from __future__ import print_function
import site
import getopt import getopt
import glob import glob
import sys import sys

View File

@ -24,8 +24,8 @@ from PIL import PSDraw
letter = (1.0*72, 1.0*72, 7.5*72, 10.0*72) letter = (1.0*72, 1.0*72, 7.5*72, 10.0*72)
def description(file, image): def description(filepath, image):
title = os.path.splitext(os.path.split(file)[1])[0] title = os.path.splitext(os.path.split(filepath)[1])[0]
format = " (%dx%d " format = " (%dx%d "
if image.format: if image.format:
format = " (" + image.format + " %dx%d " format = " (" + image.format + " %dx%d "
@ -65,12 +65,12 @@ for o, a in opt:
# printer channel # printer channel
printer = "lpr -P%s" % a printer = "lpr -P%s" % a
for file in argv: for filepath in argv:
try: try:
im = Image.open(file) im = Image.open(filepath)
title = description(file, im) title = description(filepath, im)
if monochrome and im.mode not in ["1", "L"]: if monochrome and im.mode not in ["1", "L"]:
im.draft("L", im.size) im.draft("L", im.size)

View File

@ -32,7 +32,7 @@ class UI(Frame):
self.canvas.pack() self.canvas.pack()
scale = Scale(self, orient=HORIZONTAL, from_=0, to=255, scale = Scale(self, orient=HORIZONTAL, from_=0, to=255,
resolution=1, command=self.update, length=256) resolution=1, command=self.update_scale, length=256)
scale.set(value) scale.set(value)
scale.bind("<ButtonRelease-1>", self.redraw) scale.bind("<ButtonRelease-1>", self.redraw)
scale.pack() scale.pack()
@ -41,7 +41,7 @@ class UI(Frame):
# be too slow on some platforms) # be too slow on some platforms)
# self.redraw() # self.redraw()
def update(self, value): def update_scale(self, value):
self.value = eval(value) self.value = eval(value)
self.redraw() self.redraw()

View File

@ -7,9 +7,9 @@
from __future__ import print_function from __future__ import print_function
try: try:
from tkinter import * from tkinter import Tk, Label
except ImportError: except ImportError:
from Tkinter import * from Tkinter import Tk, Label
from PIL import Image, ImageTk from PIL import Image, ImageTk

View File

@ -10,7 +10,7 @@ def bench(mode):
get = im.im.getpixel get = im.im.getpixel
xy = 50, 50 # position shouldn't really matter xy = 50, 50 # position shouldn't really matter
t0 = timeit.default_timer() t0 = timeit.default_timer()
for i in range(1000000): for _ in range(1000000):
get(xy) get(xy)
print(mode, timeit.default_timer() - t0, "us") print(mode, timeit.default_timer() - t0, "us")

View File

@ -21,7 +21,7 @@ class TestJpegLeaks(PillowTestCase):
from resource import setrlimit, RLIMIT_AS, RLIMIT_STACK from resource import setrlimit, RLIMIT_AS, RLIMIT_STACK
setrlimit(RLIMIT_STACK, (stack_size, stack_size)) setrlimit(RLIMIT_STACK, (stack_size, stack_size))
setrlimit(RLIMIT_AS, (mem_limit, mem_limit)) setrlimit(RLIMIT_AS, (mem_limit, mem_limit))
for count in range(iterations): for _ in range(iterations):
with Image.open(test_file) as im: with Image.open(test_file) as im:
im.load() im.load()
@ -29,13 +29,13 @@ class TestJpegLeaks(PillowTestCase):
from resource import setrlimit, RLIMIT_AS, RLIMIT_STACK from resource import setrlimit, RLIMIT_AS, RLIMIT_STACK
setrlimit(RLIMIT_STACK, (stack_size, stack_size)) setrlimit(RLIMIT_STACK, (stack_size, stack_size))
setrlimit(RLIMIT_AS, (mem_limit, mem_limit)) setrlimit(RLIMIT_AS, (mem_limit, mem_limit))
for count in range(iterations): for _ in range(iterations):
with Image.open(test_file) as im: with Image.open(test_file) as im:
im.load() im.load()
test_output = BytesIO() test_output = BytesIO()
im.save(test_output, "JPEG2000") im.save(test_output, "JPEG2000")
test_output.seek(0) test_output.seek(0)
output = test_output.read() test_output.read()
if __name__ == '__main__': if __name__ == '__main__':

View File

@ -1,5 +1,4 @@
from helper import unittest, PillowTestCase, hopper from helper import unittest, PillowTestCase, hopper
from PIL import Image
from io import BytesIO from io import BytesIO
import sys import sys
@ -102,7 +101,7 @@ post-patch:
qtables = [standard_l_qtable, qtables = [standard_l_qtable,
standard_chrominance_qtable] standard_chrominance_qtable]
for count in range(iterations): for _ in range(iterations):
test_output = BytesIO() test_output = BytesIO()
im.save(test_output, "JPEG", qtables=qtables) im.save(test_output, "JPEG", qtables=qtables)
@ -166,11 +165,12 @@ post patch:
im = hopper('RGB') im = hopper('RGB')
exif = b'12345678'*4096 exif = b'12345678'*4096
for count in range(iterations): for _ in range(iterations):
test_output = BytesIO() test_output = BytesIO()
im.save(test_output, "JPEG", exif=exif) im.save(test_output, "JPEG", exif=exif)
""" def test_base_save(self):
"""
base case: base case:
MB MB
20.99^ ::::: :::::::::::::::::::::::::::::::::::::::::::@::: 20.99^ ::::: :::::::::::::::::::::::::::::::::::::::::::@:::
@ -196,11 +196,9 @@ base case:
0 +----------------------------------------------------------------------->Gi 0 +----------------------------------------------------------------------->Gi
0 7.882 0 7.882
""" """
def test_base_save(self):
im = hopper('RGB') im = hopper('RGB')
for count in range(iterations): for _ in range(iterations):
test_output = BytesIO() test_output = BytesIO()
im.save(test_output, "JPEG") im.save(test_output, "JPEG")

View File

@ -28,7 +28,7 @@ class TestWebPLeaks(PillowTestCase):
with open(test_file, 'rb') as f: with open(test_file, 'rb') as f:
im_data = f.read() im_data = f.read()
start_mem = self._get_mem_usage() start_mem = self._get_mem_usage()
for count in range(iterations): for _ in range(iterations):
with Image.open(BytesIO(im_data)) as im: with Image.open(BytesIO(im_data)) as im:
im.load() im.load()
mem = (self._get_mem_usage() - start_mem) mem = (self._get_mem_usage() - start_mem)

View File

@ -58,10 +58,10 @@ class TestBmpReference(PillowTestCase):
} }
def get_compare(f): def get_compare(f):
(head, name) = os.path.split(f) name = os.path.split(f)[1]
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 = os.path.splitext(name)[0]
return os.path.join(base, 'html', "%s.png" % name) return os.path.join(base, 'html', "%s.png" % name)
for f in self.get_files('g'): for f in self.get_files('g'):

View File

@ -49,10 +49,10 @@ class TestCffi(PillowTestCase):
self.skipTest("No cffi") self.skipTest("No cffi")
def _test_get_access(self, im): 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 Using private interfaces, forcing a capi access and
a pyaccess for the same image """ 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)
@ -90,10 +90,10 @@ class TestCffi(PillowTestCase):
# self._test_get_access(im) # self._test_get_access(im)
def _test_set_access(self, im, color): def _test_set_access(self, 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 Using private interfaces, forcing a capi access and
a pyaccess for the same image """ 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)

View File

@ -5,14 +5,14 @@ from PIL import Image
# sample ppm stream # sample ppm stream
# created as an export of a palette image from Gimp2.6 # created as an export of a palette image from Gimp2.6
# save as...-> hopper.fli, default options. # save as...-> hopper.fli, default options.
file = "Tests/images/hopper.fli" test_file = "Tests/images/hopper.fli"
data = open(file, "rb").read() data = open(test_file, "rb").read()
class TestFileFli(PillowTestCase): class TestFileFli(PillowTestCase):
def test_sanity(self): def test_sanity(self):
im = Image.open(file) im = Image.open(test_file)
im.load() im.load()
self.assertEqual(im.mode, "P") self.assertEqual(im.mode, "P")
self.assertEqual(im.size, (128, 128)) self.assertEqual(im.size, (128, 128))

View File

@ -36,9 +36,9 @@ class TestFileGif(PillowTestCase):
def test_bilevel(optimize): def test_bilevel(optimize):
im = Image.new("1", (1, 1), 0) im = Image.new("1", (1, 1), 0)
file = BytesIO() test_file = BytesIO()
im.save(file, "GIF", optimize=optimize) im.save(test_file, "GIF", optimize=optimize)
return len(file.getvalue()) return len(test_file.getvalue())
self.assertEqual(test_grayscale(0), 800) self.assertEqual(test_grayscale(0), 800)
self.assertEqual(test_grayscale(1), 38) self.assertEqual(test_grayscale(1), 38)
@ -49,8 +49,8 @@ class TestFileGif(PillowTestCase):
from io import BytesIO from io import BytesIO
im = Image.frombytes("L", (16, 16), bytes(bytearray(range(256)))) im = Image.frombytes("L", (16, 16), bytes(bytearray(range(256))))
file = BytesIO() test_file = BytesIO()
im.save(file, "GIF", optimize=True) im.save(test_file, "GIF", optimize=True)
self.assertEqual(im.mode, "L") self.assertEqual(im.mode, "L")
def test_roundtrip(self): def test_roundtrip(self):

View File

@ -5,8 +5,8 @@ from PIL import Image
import sys import sys
# sample icon file # sample icon file
file = "Tests/images/pillow.icns" test_file = "Tests/images/pillow.icns"
data = open(file, "rb").read() data = open(test_file, "rb").read()
enable_jpeg2k = hasattr(Image.core, 'jp2klib_version') enable_jpeg2k = hasattr(Image.core, 'jp2klib_version')
@ -16,7 +16,7 @@ class TestFileIcns(PillowTestCase):
def test_sanity(self): 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(test_file)
im.load() im.load()
self.assertEqual(im.mode, "RGBA") self.assertEqual(im.mode, "RGBA")
self.assertEqual(im.size, (1024, 1024)) self.assertEqual(im.size, (1024, 1024))
@ -39,11 +39,11 @@ class TestFileIcns(PillowTestCase):
def test_sizes(self): 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(test_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(test_file)
im2.size = (w, h, r) im2.size = (w, h, r)
im2.load() im2.load()
self.assertEqual(im2.mode, 'RGBA') self.assertEqual(im2.mode, 'RGBA')

View File

@ -23,10 +23,10 @@ class TestFileJpeg(PillowTestCase):
def roundtrip(self, im, **options): def roundtrip(self, im, **options):
out = BytesIO() out = BytesIO()
im.save(out, "JPEG", **options) im.save(out, "JPEG", **options)
bytes = out.tell() test_bytes = out.tell()
out.seek(0) out.seek(0)
im = Image.open(out) im = Image.open(out)
im.bytes = bytes # for testing only im.bytes = test_bytes # for testing only
return im return im
def test_sanity(self): def test_sanity(self):

View File

@ -22,10 +22,10 @@ class TestFileJpeg2k(PillowTestCase):
def roundtrip(self, im, **options): def roundtrip(self, im, **options):
out = BytesIO() out = BytesIO()
im.save(out, "JPEG2000", **options) im.save(out, "JPEG2000", **options)
bytes = out.tell() test_bytes = out.tell()
out.seek(0) out.seek(0)
im = Image.open(out) im = Image.open(out)
im.bytes = bytes # for testing only im.bytes = test_bytes # for testing only
im.load() im.load()
return im return im

View File

@ -39,22 +39,22 @@ class TestFileLibTiff(LibTiffTestCase):
def test_g4_tiff(self): def test_g4_tiff(self):
"""Test the ordinary file path load path""" """Test the ordinary file path load path"""
file = "Tests/images/hopper_g4_500.tif" test_file = "Tests/images/hopper_g4_500.tif"
im = Image.open(file) im = Image.open(test_file)
self.assertEqual(im.size, (500, 500)) self.assertEqual(im.size, (500, 500))
self._assert_noerr(im) self._assert_noerr(im)
def test_g4_large(self): def test_g4_large(self):
file = "Tests/images/pport_g4.tif" test_file = "Tests/images/pport_g4.tif"
im = Image.open(file) im = Image.open(test_file)
self._assert_noerr(im) self._assert_noerr(im)
def test_g4_tiff_file(self): def test_g4_tiff_file(self):
"""Testing the string load path""" """Testing the string load path"""
file = "Tests/images/hopper_g4_500.tif" test_file = "Tests/images/hopper_g4_500.tif"
with open(file, 'rb') as f: with open(test_file, 'rb') as f:
im = Image.open(f) im = Image.open(f)
self.assertEqual(im.size, (500, 500)) self.assertEqual(im.size, (500, 500))
@ -62,9 +62,9 @@ class TestFileLibTiff(LibTiffTestCase):
def test_g4_tiff_bytesio(self): def test_g4_tiff_bytesio(self):
"""Testing the stringio loading code path""" """Testing the stringio loading code path"""
file = "Tests/images/hopper_g4_500.tif" test_file = "Tests/images/hopper_g4_500.tif"
s = io.BytesIO() s = io.BytesIO()
with open(file, 'rb') as f: with open(test_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)
@ -89,8 +89,8 @@ class TestFileLibTiff(LibTiffTestCase):
def test_g4_write(self): 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/hopper_g4_500.tif" test_file = "Tests/images/hopper_g4_500.tif"
orig = Image.open(file) orig = Image.open(test_file)
out = self.tempfile("temp.tif") out = self.tempfile("temp.tif")
rot = orig.transpose(Image.ROTATE_90) rot = orig.transpose(Image.ROTATE_90)
@ -108,8 +108,8 @@ class TestFileLibTiff(LibTiffTestCase):
self.assertNotEqual(orig.tobytes(), reread.tobytes()) self.assertNotEqual(orig.tobytes(), reread.tobytes())
def test_adobe_deflate_tiff(self): def test_adobe_deflate_tiff(self):
file = "Tests/images/tiff_adobe_deflate.tif" test_file = "Tests/images/tiff_adobe_deflate.tif"
im = Image.open(file) im = Image.open(test_file)
self.assertEqual(im.mode, "RGB") self.assertEqual(im.mode, "RGB")
self.assertEqual(im.size, (278, 374)) self.assertEqual(im.size, (278, 374))
@ -215,8 +215,8 @@ class TestFileLibTiff(LibTiffTestCase):
def test_g4_string_info(self): def test_g4_string_info(self):
"""Tests String data in info directory""" """Tests String data in info directory"""
file = "Tests/images/hopper_g4_500.tif" test_file = "Tests/images/hopper_g4_500.tif"
orig = Image.open(file) orig = Image.open(test_file)
out = self.tempfile("temp.tif") out = self.tempfile("temp.tif")

View File

@ -18,8 +18,8 @@ class TestFileLibTiffSmall(LibTiffTestCase):
def test_g4_hopper_file(self): def test_g4_hopper_file(self):
"""Testing the open file load path""" """Testing the open file load path"""
file = "Tests/images/hopper_g4.tif" test_file = "Tests/images/hopper_g4.tif"
with open(file, 'rb') as f: with open(test_file, 'rb') as f:
im = Image.open(f) im = Image.open(f)
self.assertEqual(im.size, (128, 128)) self.assertEqual(im.size, (128, 128))
@ -28,9 +28,9 @@ class TestFileLibTiffSmall(LibTiffTestCase):
def test_g4_hopper_bytesio(self): def test_g4_hopper_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/hopper_g4.tif" test_file = "Tests/images/hopper_g4.tif"
s = BytesIO() s = BytesIO()
with open(file, 'rb') as f: with open(test_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)
@ -41,8 +41,8 @@ class TestFileLibTiffSmall(LibTiffTestCase):
def test_g4_hopper(self): def test_g4_hopper(self):
"""The 128x128 lena image failed for some reason.""" """The 128x128 lena image failed for some reason."""
file = "Tests/images/hopper_g4.tif" test_file = "Tests/images/hopper_g4.tif"
im = Image.open(file) im = Image.open(test_file)
self.assertEqual(im.size, (128, 128)) self.assertEqual(im.size, (128, 128))
self._assert_noerr(im) self._assert_noerr(im)

View File

@ -17,10 +17,10 @@ class TestFileMpo(PillowTestCase):
# Note that for now, there is no MPO saving functionality # Note that for now, there is no MPO saving functionality
out = BytesIO() out = BytesIO()
im.save(out, "MPO", **options) im.save(out, "MPO", **options)
bytes = out.tell() test_bytes = out.tell()
out.seek(0) out.seek(0)
im = Image.open(out) im = Image.open(out)
im.bytes = bytes # for testing only im.bytes = test_bytes # for testing only
return im return im
def test_sanity(self): def test_sanity(self):

View File

@ -31,8 +31,8 @@ class TestFilePcx(PillowTestCase):
def test_pil184(self): def test_pil184(self):
# 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" test_file = "Tests/images/pil184.pcx"
im = Image.open(file) im = Image.open(test_file)
self.assertEqual(im.size, (447, 144)) self.assertEqual(im.size, (447, 144))
self.assertEqual(im.tile[0][1], (0, 0, 447, 144)) self.assertEqual(im.tile[0][1], (0, 0, 447, 144))

View File

@ -19,9 +19,9 @@ MAGIC = PngImagePlugin._MAGIC
def chunk(cid, *data): def chunk(cid, *data):
file = BytesIO() test_file = BytesIO()
PngImagePlugin.putchunk(*(file, cid) + data) PngImagePlugin.putchunk(*(test_file, cid) + data)
return file.getvalue() return test_file.getvalue()
o32 = PngImagePlugin.o32 o32 = PngImagePlugin.o32
@ -56,37 +56,37 @@ class TestFilePng(PillowTestCase):
self.assertRegexpMatches( self.assertRegexpMatches(
Image.core.zlib_version, "\d+\.\d+\.\d+(\.\d+)?$") Image.core.zlib_version, "\d+\.\d+\.\d+(\.\d+)?$")
file = self.tempfile("temp.png") test_file = self.tempfile("temp.png")
hopper("RGB").save(file) hopper("RGB").save(test_file)
im = Image.open(file) im = Image.open(test_file)
im.load() im.load()
self.assertEqual(im.mode, "RGB") self.assertEqual(im.mode, "RGB")
self.assertEqual(im.size, (128, 128)) self.assertEqual(im.size, (128, 128))
self.assertEqual(im.format, "PNG") self.assertEqual(im.format, "PNG")
hopper("1").save(file) hopper("1").save(test_file)
im = Image.open(file) im = Image.open(test_file)
hopper("L").save(file) hopper("L").save(test_file)
im = Image.open(file) im = Image.open(test_file)
hopper("P").save(file) hopper("P").save(test_file)
im = Image.open(file) im = Image.open(test_file)
hopper("RGB").save(file) hopper("RGB").save(test_file)
im = Image.open(file) im = Image.open(test_file)
hopper("I").save(file) hopper("I").save(test_file)
im = Image.open(file) im = Image.open(test_file)
def test_broken(self): def test_broken(self):
# 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" test_file = "Tests/images/broken.png"
self.assertRaises(IOError, lambda: Image.open(file)) self.assertRaises(IOError, lambda: Image.open(test_file))
def test_bad_text(self): def test_bad_text(self):
# Make sure PIL can read malformed tEXt chunks (@PIL152) # Make sure PIL can read malformed tEXt chunks (@PIL152)
@ -167,16 +167,16 @@ class TestFilePng(PillowTestCase):
def test_interlace(self): def test_interlace(self):
file = "Tests/images/pil123p.png" test_file = "Tests/images/pil123p.png"
im = Image.open(file) im = Image.open(test_file)
self.assert_image(im, "P", (162, 150)) self.assert_image(im, "P", (162, 150))
self.assertTrue(im.info.get("interlace")) self.assertTrue(im.info.get("interlace"))
im.load() im.load()
file = "Tests/images/pil123rgba.png" test_file = "Tests/images/pil123rgba.png"
im = Image.open(file) im = Image.open(test_file)
self.assert_image(im, "RGBA", (162, 150)) self.assert_image(im, "RGBA", (162, 150))
self.assertTrue(im.info.get("interlace")) self.assertTrue(im.info.get("interlace"))
@ -184,8 +184,8 @@ class TestFilePng(PillowTestCase):
im.load() im.load()
def test_load_transparent_p(self): def test_load_transparent_p(self):
file = "Tests/images/pil123p.png" test_file = "Tests/images/pil123p.png"
im = Image.open(file) im = Image.open(test_file)
self.assert_image(im, "P", (162, 150)) self.assert_image(im, "P", (162, 150))
im = im.convert("RGBA") im = im.convert("RGBA")
@ -195,8 +195,8 @@ class TestFilePng(PillowTestCase):
self.assertEqual(len(im.split()[3].getcolors()), 124) self.assertEqual(len(im.split()[3].getcolors()), 124)
def test_load_transparent_rgb(self): def test_load_transparent_rgb(self):
file = "Tests/images/rgb_trns.png" test_file = "Tests/images/rgb_trns.png"
im = Image.open(file) im = Image.open(test_file)
self.assert_image(im, "RGB", (64, 64)) self.assert_image(im, "RGB", (64, 64))
im = im.convert("RGBA") im = im.convert("RGBA")
@ -209,22 +209,22 @@ class TestFilePng(PillowTestCase):
in_file = "Tests/images/pil123p.png" in_file = "Tests/images/pil123p.png"
im = Image.open(in_file) im = Image.open(in_file)
file = self.tempfile("temp.png") test_file = self.tempfile("temp.png")
im.save(file) im.save(test_file)
def test_save_p_single_transparency(self): 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 = self.tempfile("temp.png") test_file = self.tempfile("temp.png")
im.save(file) im.save(test_file)
def test_save_l_transparency(self): 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 = self.tempfile("temp.png") test_file = self.tempfile("temp.png")
im.save(file) im.save(test_file)
# There are 559 transparent pixels. # There are 559 transparent pixels.
im = im.convert('RGBA') im = im.convert('RGBA')
@ -234,8 +234,8 @@ class TestFilePng(PillowTestCase):
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 = self.tempfile("temp.png") test_file = self.tempfile("temp.png")
im.save(file) im.save(test_file)
def test_load_verify(self): def test_load_verify(self):
# Check open/load/verify exception (@PIL150) # Check open/load/verify exception (@PIL150)
@ -245,7 +245,7 @@ class TestFilePng(PillowTestCase):
im = Image.open(TEST_PNG_FILE) im = Image.open(TEST_PNG_FILE)
im.load() im.load()
self.assertRaises(RuntimeError, lambda: im.verify()) self.assertRaises(RuntimeError, im.verify)
def test_roundtrip_dpi(self): def test_roundtrip_dpi(self):
# Check dpi roundtripping # Check dpi roundtripping
@ -329,8 +329,8 @@ class TestFilePng(PillowTestCase):
# 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" test_file = "Tests/images/caption_6_33_22.png"
im = Image.open(file) im = Image.open(test_file)
self.assertEqual(im.info["transparency"], (248, 248, 248)) self.assertEqual(im.info["transparency"], (248, 248, 248))
# check saving transparency by default # check saving transparency by default

View File

@ -3,14 +3,14 @@ from helper import unittest, PillowTestCase
from PIL import Image from PIL import Image
# sample ppm stream # sample ppm stream
file = "Tests/images/hopper.ppm" test_file = "Tests/images/hopper.ppm"
data = open(file, "rb").read() data = open(test_file, "rb").read()
class TestFilePpm(PillowTestCase): class TestFilePpm(PillowTestCase):
def test_sanity(self): def test_sanity(self):
im = Image.open(file) im = Image.open(test_file)
im.load() im.load()
self.assertEqual(im.mode, "RGB") self.assertEqual(im.mode, "RGB")
self.assertEqual(im.size, (128, 128)) self.assertEqual(im.size, (128, 128))

View File

@ -3,14 +3,14 @@ from helper import unittest, PillowTestCase
from PIL import Image from PIL import Image
# sample ppm stream # sample ppm stream
file = "Tests/images/hopper.psd" test_file = "Tests/images/hopper.psd"
data = open(file, "rb").read() data = open(test_file, "rb").read()
class TestImagePsd(PillowTestCase): class TestImagePsd(PillowTestCase):
def test_sanity(self): def test_sanity(self):
im = Image.open(file) im = Image.open(test_file)
im.load() im.load()
self.assertEqual(im.mode, "RGB") self.assertEqual(im.mode, "RGB")
self.assertEqual(im.size, (128, 128)) self.assertEqual(im.size, (128, 128))

View File

@ -41,12 +41,12 @@ class TestFileWebpMetadata(PillowTestCase):
image = Image.open(file_path) image = Image.open(file_path)
expected_exif = image.info['exif'] expected_exif = image.info['exif']
buffer = BytesIO() test_buffer = BytesIO()
image.save(buffer, "webp", exif=expected_exif) image.save(test_buffer, "webp", exif=expected_exif)
buffer.seek(0) test_buffer.seek(0)
webp_image = Image.open(buffer) webp_image = Image.open(test_buffer)
webp_exif = webp_image.info.get('exif', None) webp_exif = webp_image.info.get('exif', None)
self.assertTrue(webp_exif) self.assertTrue(webp_exif)
@ -76,12 +76,12 @@ class TestFileWebpMetadata(PillowTestCase):
image = Image.open(file_path) image = Image.open(file_path)
expected_icc_profile = image.info['icc_profile'] expected_icc_profile = image.info['icc_profile']
buffer = BytesIO() test_buffer = BytesIO()
image.save(buffer, "webp", icc_profile=expected_icc_profile) image.save(test_buffer, "webp", icc_profile=expected_icc_profile)
buffer.seek(0) test_buffer.seek(0)
webp_image = Image.open(buffer) webp_image = Image.open(test_buffer)
webp_icc_profile = webp_image.info.get('icc_profile', None) webp_icc_profile = webp_image.info.get('icc_profile', None)
@ -96,14 +96,14 @@ class TestFileWebpMetadata(PillowTestCase):
file_path = "Tests/images/flower.jpg" file_path = "Tests/images/flower.jpg"
image = Image.open(file_path) image = Image.open(file_path)
image.info['exif'] self.assertTrue('exif' in image.info)
buffer = BytesIO() test_buffer = BytesIO()
image.save(buffer, "webp") image.save(test_buffer, "webp")
buffer.seek(0) test_buffer.seek(0)
webp_image = Image.open(buffer) webp_image = Image.open(test_buffer)
self.assertFalse(webp_image._getexif()) self.assertFalse(webp_image._getexif())

View File

@ -9,8 +9,8 @@ class TestFontBdf(PillowTestCase):
def test_sanity(self): def test_sanity(self):
file = open(filename, "rb") test_file = open(filename, "rb")
font = BdfFontFile.BdfFontFile(file) font = BdfFontFile.BdfFontFile(test_file)
self.assertIsInstance(font, FontFile.FontFile) self.assertIsInstance(font, FontFile.FontFile)
self.assertEqual(len([_f for _f in font.glyph if _f]), 190) self.assertEqual(len([_f for _f in font.glyph if _f]), 190)

View File

@ -17,8 +17,8 @@ class TestFontPcf(PillowTestCase):
self.skipTest("zlib support not available") self.skipTest("zlib support not available")
def save_font(self): def save_font(self):
file = open(fontname, "rb") test_file = open(fontname, "rb")
font = PcfFontFile.PcfFontFile(file) font = PcfFontFile.PcfFontFile(test_file)
self.assertIsInstance(font, FontFile.FontFile) self.assertIsInstance(font, FontFile.FontFile)
self.assertEqual(len([_f for _f in font.glyph if _f]), 192) self.assertEqual(len([_f for _f in font.glyph if _f]), 192)

View File

@ -1,7 +1,6 @@
from helper import unittest, PillowTestCase, hopper from helper import unittest, PillowTestCase, hopper
from PIL import Image from PIL import Image
import sys
class TestImage(PillowTestCase): class TestImage(PillowTestCase):
@ -42,8 +41,8 @@ class TestImage(PillowTestCase):
im.paste(0, (0, 0, 100, 100)) im.paste(0, (0, 0, 100, 100))
self.assertFalse(im.readonly) self.assertFalse(im.readonly)
file = self.tempfile("temp.ppm") test_file = self.tempfile("temp.ppm")
im._dump(file) im._dump(test_file)
def test_comparison_with_other_type(self): def test_comparison_with_other_type(self):
# Arrange # Arrange

View File

@ -76,10 +76,10 @@ class TestImageFilter(PillowTestCase):
# 0 1 2 # 0 1 2
# 3 4 5 # 3 4 5
# 6 7 8 # 6 7 8
min = im.filter(ImageFilter.MinFilter).getpixel((1, 1)) minimum = im.filter(ImageFilter.MinFilter).getpixel((1, 1))
med = im.filter(ImageFilter.MedianFilter).getpixel((1, 1)) med = im.filter(ImageFilter.MedianFilter).getpixel((1, 1))
max = im.filter(ImageFilter.MaxFilter).getpixel((1, 1)) maximum = im.filter(ImageFilter.MaxFilter).getpixel((1, 1))
return min, med, max return minimum, med, maximum
self.assertEqual(rankfilter("1"), (0, 4, 8)) self.assertEqual(rankfilter("1"), (0, 4, 8))
self.assertEqual(rankfilter("L"), (0, 4, 8)) self.assertEqual(rankfilter("L"), (0, 4, 8))

View File

@ -18,7 +18,7 @@ class TestImageLoad(PillowTestCase):
def test_close(self): def test_close(self):
im = Image.open("Tests/images/hopper.gif") im = Image.open("Tests/images/hopper.gif")
im.close() im.close()
self.assertRaises(ValueError, lambda: im.load()) self.assertRaises(ValueError, im.load)
self.assertRaises(ValueError, lambda: im.getpixel((0, 0))) self.assertRaises(ValueError, lambda: im.getpixel((0, 0)))
def test_contextmanager(self): def test_contextmanager(self):

View File

@ -45,13 +45,13 @@ class TestImageSplit(PillowTestCase):
codecs = dir(Image.core) codecs = dir(Image.core)
if 'zip_encoder' in codecs: if 'zip_encoder' in codecs:
file = self.tempfile("temp.png") test_file = self.tempfile("temp.png")
else: else:
file = self.tempfile("temp.pcx") test_file = self.tempfile("temp.pcx")
def split_open(mode): def split_open(mode):
hopper(mode).save(file) hopper(mode).save(test_file)
im = Image.open(file) im = Image.open(test_file)
return len(im.split()) return len(im.split())
self.assertEqual(split_open("1"), 1) self.assertEqual(split_open("1"), 1)
self.assertEqual(split_open("L"), 1) self.assertEqual(split_open("L"), 1)

View File

@ -1,4 +1,5 @@
from helper import unittest, PillowTestCase, hopper import helper
from helper import unittest, PillowTestCase
from PIL.Image import (FLIP_LEFT_RIGHT, FLIP_TOP_BOTTOM, ROTATE_90, ROTATE_180, from PIL.Image import (FLIP_LEFT_RIGHT, FLIP_TOP_BOTTOM, ROTATE_90, ROTATE_180,
ROTATE_270, TRANSPOSE) ROTATE_270, TRANSPOSE)
@ -7,8 +8,8 @@ from PIL.Image import (FLIP_LEFT_RIGHT, FLIP_TOP_BOTTOM, ROTATE_90, ROTATE_180,
class TestImageTranspose(PillowTestCase): class TestImageTranspose(PillowTestCase):
hopper = { hopper = {
'L': hopper('L').crop((0, 0, 121, 127)).copy(), 'L': helper.hopper('L').crop((0, 0, 121, 127)).copy(),
'RGB': hopper('RGB').crop((0, 0, 121, 127)).copy(), 'RGB': helper.hopper('RGB').crop((0, 0, 121, 127)).copy(),
} }
def test_flip_left_right(self): def test_flip_left_right(self):

View File

@ -24,11 +24,11 @@ class TestImageFile(PillowTestCase):
if format in ("MSP", "XBM"): if format in ("MSP", "XBM"):
im = im.convert("1") im = im.convert("1")
file = BytesIO() test_file = BytesIO()
im.save(file, format) im.save(test_file, format)
data = file.getvalue() data = test_file.getvalue()
parser = ImageFile.Parser() parser = ImageFile.Parser()
parser.feed(data) parser.feed(data)

View File

@ -94,7 +94,8 @@ try:
def _render(self, font): def _render(self, font):
txt = "Hello World!" txt = "Hello World!"
ttf = ImageFont.truetype(font, FONT_SIZE) ttf = ImageFont.truetype(font, FONT_SIZE)
w, h = ttf.getsize(txt) ttf.getsize(txt)
img = Image.new("RGB", (256, 64), "white") img = Image.new("RGB", (256, 64), "white")
d = ImageDraw.Draw(img) d = ImageDraw.Draw(img)
d.text((10, 10), txt, font=ttf, fill='black') d.text((10, 10), txt, font=ttf, fill='black')

View File

@ -17,11 +17,11 @@ class TestImagePalette(PillowTestCase):
palette = ImagePalette() palette = ImagePalette()
map = {} test_map = {}
for i in range(256): for i in range(256):
map[palette.getcolor((i, i, i))] = i test_map[palette.getcolor((i, i, i))] = i
self.assertEqual(len(map), 256) self.assertEqual(len(test_map), 256)
self.assertRaises(ValueError, lambda: palette.getcolor((1, 2, 3))) self.assertRaises(ValueError, lambda: palette.getcolor((1, 2, 3)))
def test_file(self): def test_file(self):
@ -117,7 +117,7 @@ class TestImagePalette(PillowTestCase):
palette = raw("RGB", list(range(256))*3) palette = raw("RGB", list(range(256))*3)
# Act / Assert # Act / Assert
self.assertRaises(ValueError, lambda: palette.tobytes()) self.assertRaises(ValueError, palette.tobytes)
self.assertRaises(ValueError, lambda: palette.getcolor((1, 2, 3))) self.assertRaises(ValueError, lambda: palette.getcolor((1, 2, 3)))
f = self.tempfile("temp.lut") f = self.tempfile("temp.lut")
self.assertRaises(ValueError, lambda: palette.save(f)) self.assertRaises(ValueError, lambda: palette.save(f))

View File

@ -7,10 +7,10 @@ class TestImageSequence(PillowTestCase):
def test_sanity(self): def test_sanity(self):
file = self.tempfile("temp.im") test_file = self.tempfile("temp.im")
im = hopper("RGB") im = hopper("RGB")
im.save(file) im.save(test_file)
seq = ImageSequence.Iterator(im) seq = ImageSequence.Iterator(im)

View File

@ -9,7 +9,6 @@ class TestImageShow(PillowTestCase):
def test_sanity(self): def test_sanity(self):
dir(Image) dir(Image)
dir(ImageShow) dir(ImageShow)
pass
if __name__ == '__main__': if __name__ == '__main__':

View File

@ -8,7 +8,6 @@ class TestImageWin(PillowTestCase):
def test_sanity(self): def test_sanity(self):
dir(ImageWin) dir(ImageWin)
pass
def test_hdc(self): def test_hdc(self):
# Arrange # Arrange
@ -101,8 +100,8 @@ class TestImageWinDib(PillowTestCase):
# Act # Act
# Make one the same as the using tobytes()/frombytes() # Make one the same as the using tobytes()/frombytes()
buffer = dib1.tobytes() test_buffer = dib1.tobytes()
dib2.frombytes(buffer) dib2.frombytes(test_buffer)
# Assert # Assert
# Confirm they're the same # Confirm they're the same
@ -112,11 +111,11 @@ class TestImageWinDib(PillowTestCase):
# Arrange # Arrange
im = hopper() im = hopper()
dib = ImageWin.Dib(im) dib = ImageWin.Dib(im)
buffer = dib.tobytes() test_buffer = dib.tobytes()
# Act/Assert # Act/Assert
self.assert_warning(DeprecationWarning, lambda: dib.tostring()) self.assert_warning(DeprecationWarning, dib.tostring)
self.assert_warning(DeprecationWarning, lambda: dib.fromstring(buffer)) self.assert_warning(DeprecationWarning, lambda: dib.fromstring(test_buffer))
if __name__ == '__main__': if __name__ == '__main__':

View File

@ -64,15 +64,15 @@ class TestModeI16(PillowTestCase):
self.assertEqual(imIn.getpixel((0, 0)), 2) self.assertEqual(imIn.getpixel((0, 0)), 2)
if mode == "L": if mode == "L":
max = 255 maximum = 255
else: else:
max = 32767 maximum = 32767
imIn = Image.new(mode, (1, 1), 256) imIn = Image.new(mode, (1, 1), 256)
self.assertEqual(imIn.getpixel((0, 0)), min(256, max)) self.assertEqual(imIn.getpixel((0, 0)), min(256, maximum))
imIn.putpixel((0, 0), 512) imIn.putpixel((0, 0), 512)
self.assertEqual(imIn.getpixel((0, 0)), min(512, max)) self.assertEqual(imIn.getpixel((0, 0)), min(512, maximum))
basic("L") basic("L")

View File

@ -60,7 +60,7 @@ class TestPickle(PillowTestCase):
import pickle import pickle
# Act / Assert # Act / Assert
for file in [ for test_file in [
"Tests/images/test-card.png", "Tests/images/test-card.png",
"Tests/images/zero_bb.png", "Tests/images/zero_bb.png",
"Tests/images/zero_bb_scale2.png", "Tests/images/zero_bb_scale2.png",
@ -69,7 +69,7 @@ class TestPickle(PillowTestCase):
"Tests/images/p_trns_single.png", "Tests/images/p_trns_single.png",
"Tests/images/pil123p.png" "Tests/images/pil123p.png"
]: ]:
self.helper_pickle_string(pickle, file=file) self.helper_pickle_string(pickle, file=test_file)
def test_pickle_l_mode(self): def test_pickle_l_mode(self):
# Arrange # Arrange

View File

@ -6,10 +6,7 @@ import sys
import threading import threading
import time import time
try: test_format = sys.argv[1] if len(sys.argv) > 1 else "PNG"
format = sys.argv[1]
except:
format = "PNG"
im = Image.open("Tests/images/hopper.ppm") im = Image.open("Tests/images/hopper.ppm")
im.load() im.load()
@ -28,7 +25,7 @@ class Worker(threading.Thread):
sys.stdout.write("x") sys.stdout.write("x")
break break
f = io.BytesIO() f = io.BytesIO()
im.save(f, format, optimize=1) im.save(f, test_format, optimize=1)
data = f.getvalue() data = f.getvalue()
result.append(len(data)) result.append(len(data))
im = Image.open(io.BytesIO(data)) im = Image.open(io.BytesIO(data))