mapnik/tests/python_tests/webp_encoding_test.py

160 lines
6.3 KiB
Python
Raw Normal View History

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os, mapnik
from nose.tools import raises,eq_
from utilities import execution_path, run_all
def setup():
# All of the paths used are relative, if we run the tests
# from another directory we need to chdir()
os.chdir(execution_path('.'))
if mapnik.has_webp():
tmp_dir = '/tmp/mapnik-webp/'
if not os.path.exists(tmp_dir):
os.makedirs(tmp_dir)
opts = [
2013-09-30 13:30:16 -07:00
'webp',
'webp:method=0',
'webp:method=6',
2013-09-30 13:30:16 -07:00
'webp:quality=64',
'webp:alpha=false',
'webp:partitions=3',
'webp:preprocessing=1',
'webp:partition_limit=50',
'webp:pass=10',
'webp:alpha_quality=50',
'webp:alpha_filtering=2',
'webp:alpha_compression=0',
'webp:autofilter=0',
'webp:filter_type=1:autofilter=1',
'webp:filter_sharpness=4',
'webp:filter_strength=50',
'webp:sns_strength=50',
'webp:segments=3',
'webp:target_PSNR=.5',
'webp:target_size=100'
]
def gen_filepath(name,format):
return os.path.join('images/support/encoding-opts',name+'-'+format.replace(":","+")+'.webp')
def test_quality_threshold():
im = mapnik.Image(256,256)
im.tostring('webp:quality=99.99000')
im.tostring('webp:quality=0')
im.tostring('webp:quality=0.001')
@raises(RuntimeError)
def test_quality_threshold_invalid():
im = mapnik.Image(256,256)
im.tostring('webp:quality=101')
@raises(RuntimeError)
def test_quality_threshold_invalid2():
im = mapnik.Image(256,256)
im.tostring('webp:quality=-1')
generate = os.environ.get('UPDATE')
def test_expected_encodings():
fails = []
try:
for opt in opts:
im = mapnik.Image(256,256)
expected = gen_filepath('blank',opt)
actual = os.path.join(tmp_dir,os.path.basename(expected))
if generate or not os.path.exists(expected):
print 'generating expected image %s' % expected
im.save(expected,opt)
im.save(actual,opt)
try:
expected_bytes = mapnik.Image.open(expected).tostring()
except RuntimeError:
# this will happen if libweb is old, since it cannot open images created by more recent webp
print 'warning, cannot open webp expected image (your libwebp is likely too old)'
continue
if mapnik.Image.open(actual).tostring() != expected_bytes:
fails.append('%s (actual) not == to %s (expected)' % (actual,expected))
for opt in opts:
im = mapnik.Image(256,256)
im.fill(mapnik.Color('green'))
expected = gen_filepath('solid',opt)
actual = os.path.join(tmp_dir,os.path.basename(expected))
if generate or not os.path.exists(expected):
print 'generating expected image %s' % expected
im.save(expected,opt)
im.save(actual,opt)
try:
expected_bytes = mapnik.Image.open(expected).tostring()
except RuntimeError:
# this will happen if libweb is old, since it cannot open images created by more recent webp
print 'warning, cannot open webp expected image (your libwebp is likely too old)'
continue
if mapnik.Image.open(actual).tostring() != expected_bytes:
fails.append('%s (actual) not == to %s (expected)' % (actual,expected))
for opt in opts:
im = mapnik.Image.open('images/support/transparency/aerial_rgba.png')
expected = gen_filepath('aerial_rgba',opt)
actual = os.path.join(tmp_dir,os.path.basename(expected))
if generate or not os.path.exists(expected):
print 'generating expected image %s' % expected
im.save(expected,opt)
im.save(actual,opt)
try:
expected_bytes = mapnik.Image.open(expected).tostring()
except RuntimeError:
# this will happen if libweb is old, since it cannot open images created by more recent webp
print 'warning, cannot open webp expected image (your libwebp is likely too old)'
continue
if mapnik.Image.open(actual).tostring() != expected_bytes:
fails.append('%s (actual) not == to %s (expected)' % (actual,expected))
# disabled to avoid failures on ubuntu when using old webp packages
#eq_(fails,[],'\n'+'\n'.join(fails))
except RuntimeError, e:
print e
def test_transparency_levels():
try:
# create partial transparency image
im = mapnik.Image(256,256)
im.fill(mapnik.Color('rgba(255,255,255,.5)'))
c2 = mapnik.Color('rgba(255,255,0,.2)')
c3 = mapnik.Color('rgb(0,255,255)')
for y in range(0,im.height()/2):
for x in range(0,im.width()/2):
im.set_pixel(x,y,c2)
for y in range(im.height()/2,im.height()):
for x in range(im.width()/2,im.width()):
im.set_pixel(x,y,c3)
t0 = tmp_dir + 'white0-actual.webp'
# octree
format = 'webp'
expected = 'images/support/transparency/white0.webp'
if generate or not os.path.exists(expected):
im.save('images/support/transparency/white0.webp')
im.save(t0,format)
im_in = mapnik.Image.open(t0)
t0_len = len(im_in.tostring(format))
try:
expected_bytes = mapnik.Image.open(expected).tostring(format)
except RuntimeError:
# this will happen if libweb is old, since it cannot open images created by more recent webp
print 'warning, cannot open webp expected image (your libwebp is likely too old)'
return
eq_(t0_len,len(expected_bytes))
except RuntimeError, e:
print e
if __name__ == "__main__":
setup()
exit(run_all(eval(x) for x in dir() if x.startswith("test_")))