Merge pull request #2894 from hugovk/avoid-random-noise-failure

Test: avoid random noise failure
This commit is contained in:
wiredfool 2017-12-20 09:26:49 +00:00 committed by GitHub
commit c4a91f05ef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 36 additions and 21 deletions

View File

@ -20,6 +20,7 @@ try:
except ImportError:
pass
def convert_to_comparable(a, b):
new_a, new_b = a, b
if a.mode == 'P':
@ -161,6 +162,12 @@ class PillowTestCase(unittest.TestCase):
self.assertTrue(found)
return result
def assert_all_same(self, items, msg=None):
self.assertTrue(items.count(items[0]) == len(items), msg)
def assert_not_all_same(self, items, msg=None):
self.assertFalse(items.count(items[0]) == len(items), msg)
def skipKnownBadTest(self, msg=None, platform=None,
travis=None, interpreter=None):
# Skip if platform/travis matches, and
@ -201,6 +208,7 @@ class PillowTestCase(unittest.TestCase):
return Image.open(outfile)
raise IOError()
@unittest.skipIf(sys.platform.startswith('win32'), "requires Unix or MacOS")
class PillowLeakTestCase(PillowTestCase):
# requires unix/osx
@ -215,7 +223,7 @@ class PillowLeakTestCase(PillowTestCase):
:returns; memory usage in kilobytes
"""
from resource import getpagesize, getrusage, RUSAGE_SELF
from resource import getrusage, RUSAGE_SELF
mem = getrusage(RUSAGE_SELF).ru_maxrss
if sys.platform == 'darwin':
# man 2 getrusage:
@ -309,6 +317,7 @@ def imagemagick_available():
def on_appveyor():
return 'APPVEYOR' in os.environ
if sys.platform == 'win32':
IMCONVERT = os.environ.get('MAGICK_HOME', '')
if IMCONVERT:

View File

@ -22,7 +22,7 @@ class TestImage(PillowTestCase):
'BGR;15', 'BGR;16', 'BGR;24', 'BGR;32'
]:
with self.assertRaises(ValueError) as e:
Image.new(mode, (1, 1));
Image.new(mode, (1, 1))
self.assertEqual(str(e.exception), 'unrecognized image mode')
def test_sanity(self):
@ -277,7 +277,8 @@ class TestImage(PillowTestCase):
self.assertRaises(ValueError,
source.alpha_composite, over, "invalid source")
self.assertRaises(ValueError,
source.alpha_composite, over, (0, 0), "invalid destination")
source.alpha_composite, over, (0, 0),
"invalid destination")
self.assertRaises(ValueError,
source.alpha_composite, over, (0))
self.assertRaises(ValueError,
@ -354,7 +355,12 @@ class TestImage(PillowTestCase):
# Assert
self.assertEqual(im.size, (100, 100))
self.assertEqual(im.mode, "L")
self.assertNotEqual(im.getpixel((0, 0)), im.getpixel((0, 1)))
p0 = im.getpixel((0, 0))
p1 = im.getpixel((0, 1))
p2 = im.getpixel((0, 2))
p3 = im.getpixel((0, 3))
p4 = im.getpixel((0, 4))
self.assert_not_all_same([p0, p1, p2, p3, p4])
def test_effect_spread(self):
# Arrange