Check for Div0 and added unit test cases

This commit is contained in:
Ian Knight 2016-05-16 22:05:58 +09:30
parent 3cdbaff2a6
commit a7466f1ea7
2 changed files with 57 additions and 2 deletions

View File

@ -179,14 +179,20 @@ def create_thumb(image_path, thumb_path, return_icon=True, size=None):
reader = QtGui.QImageReader(image_path) reader = QtGui.QImageReader(image_path)
if size is None: if size is None:
# No size given; use default height of 88 # No size given; use default height of 88
ratio = reader.size().width() / reader.size().height() if reader.size().isEmpty():
ratio = 1
else:
ratio = reader.size().width() / reader.size().height()
reader.setScaledSize(QtCore.QSize(int(ratio * 88), 88)) reader.setScaledSize(QtCore.QSize(int(ratio * 88), 88))
elif size.isValid(): elif size.isValid():
# Complete size given # Complete size given
reader.setScaledSize(size) reader.setScaledSize(size)
else: else:
# Invalid size given # Invalid size given
ratio = reader.size().width() / reader.size().height() if reader.size().isEmpty():
ratio = 1
else:
ratio = reader.size().width() / reader.size().height()
if size.width() >= 0: if size.width() >= 0:
# Valid width; scale height # Valid width; scale height
reader.setScaledSize(QtCore.QSize(size.width(), int(size.width() / ratio))) reader.setScaledSize(QtCore.QSize(size.width(), int(size.width() / ratio)))

View File

@ -421,6 +421,55 @@ class TestLib(TestCase):
except: except:
pass pass
def create_thumb_empty_img_test(self):
"""
Test the create_thumb() function with a size of only height specified.
"""
# GIVEN: An image to create a thumb of.
image_path = os.path.join(TEST_PATH, 'church.jpg')
thumb_path = os.path.join(TEST_PATH, 'church_thumb.jpg')
thumb_size = QtCore.QSize(-1, 100)
expected_size_1 = QtCore.QSize(88, 88)
expected_size_2 = QtCore.QSize(100, 100)
# Remove the thumb so that the test actually tests if the thumb will be created. Maybe it was not deleted in the
# last test.
try:
os.remove(thumb_path)
except:
pass
# Only continue when the thumb does not exist.
self.assertFalse(os.path.exists(thumb_path), 'Test was not run, because the thumb already exists.')
# WHEN: Create the thumb.
with patch('openlp.core.lib.QtGui.QImageReader.size') as mocked_size:
mocked_size.return_value = QtCore.QSize(0, 0)
icon = create_thumb(image_path, thumb_path, size=None)
# THEN: Check if the thumb was created with aspect ratio of 1.
self.assertTrue(os.path.exists(thumb_path), 'Test was not ran, because the thumb already exists')
self.assertIsInstance(icon, QtGui.QIcon, 'The icon should be a QIcon')
self.assertFalse(icon.isNull(), 'The icon should not be null')
self.assertEqual(expected_size_1, QtGui.QImageReader(thumb_path).size(), 'The thumb should have the given size')
# WHEN: Create the thumb.
with patch('openlp.core.lib.QtGui.QImageReader.size') as mocked_size:
mocked_size.return_value = QtCore.QSize(0, 0)
icon = create_thumb(image_path, thumb_path, size=thumb_size)
# THEN: Check if the thumb was created with aspect ratio of 1.
self.assertIsInstance(icon, QtGui.QIcon, 'The icon should be a QIcon')
self.assertFalse(icon.isNull(), 'The icon should not be null')
self.assertEqual(expected_size_2, QtGui.QImageReader(thumb_path).size(), 'The thumb should have the given size')
# Remove the thumb so that the test actually tests if the thumb will be created.
try:
os.remove(thumb_path)
except:
pass
def check_item_selected_true_test(self): def check_item_selected_true_test(self):
""" """
Test that the check_item_selected() function returns True when there are selected indexes Test that the check_item_selected() function returns True when there are selected indexes