Unit tests for BoundsPen

This commit is contained in:
Sascha Brawer 2015-05-26 11:31:37 +02:00
parent d2f7e281a2
commit c84975299e
2 changed files with 66 additions and 17 deletions

View File

@ -76,20 +76,3 @@ class BoundsPen(ControlBoundsPen):
bounds = unionRect(bounds, calcQuadraticBounds(
self._getCurrentPoint(), bcp, pt))
self.bounds = bounds
if __name__ == "__main__":
def draw(pen):
pen.moveTo((0, 0))
pen.lineTo((0, 100))
pen.qCurveTo((50, 75), (60, 50), (50, 25), (0, 0))
pen.curveTo((-50, 25), (-60, 50), (-50, 75), (0, 100))
pen.closePath()
pen = ControlBoundsPen(None)
draw(pen)
print(pen.bounds)
pen = BoundsPen(None)
draw(pen)
print(pen.bounds)

View File

@ -0,0 +1,66 @@
from __future__ import print_function, division, absolute_import
from fontTools.misc.py23 import *
from fontTools.pens.boundsPen import BoundsPen, ControlBoundsPen
import unittest
def draw_(pen):
pen.moveTo((0, 0))
pen.lineTo((0, 100))
pen.qCurveTo((50, 75), (60, 50), (50, 25), (0, 0))
pen.curveTo((-50, 25), (-60, 50), (-50, 75), (0, 100))
pen.closePath()
def bounds_(pen):
return " ".join(["%.0f" % c for c in pen.bounds])
class BoundsPenTest(unittest.TestCase):
def test_draw(self):
pen = BoundsPen(None)
draw_(pen)
self.assertEqual("-55 0 58 100", bounds_(pen))
def test_empty(self):
pen = BoundsPen(None)
self.assertEqual(None, pen.bounds)
def test_curve(self):
pen = BoundsPen(None)
pen.moveTo((0, 0))
pen.curveTo((20, 10), (90, 40), (0, 0))
self.assertEqual("0 0 45 20", bounds_(pen))
def test_quadraticCurve(self):
pen = BoundsPen(None)
pen.moveTo((0, 0))
pen.qCurveTo((6, 6), (10, 0))
self.assertEqual("0 0 10 3", bounds_(pen))
class ControlBoundsPenTest(unittest.TestCase):
def test_draw(self):
pen = ControlBoundsPen(None)
draw_(pen)
self.assertEqual("-55 0 60 100", bounds_(pen))
def test_empty(self):
pen = ControlBoundsPen(None)
self.assertEqual(None, pen.bounds)
def test_curve(self):
pen = ControlBoundsPen(None)
pen.moveTo((0, 0))
pen.curveTo((20, 10), (90, 40), (0, 0))
self.assertEqual("0 0 90 40", bounds_(pen))
def test_quadraticCurve(self):
pen = ControlBoundsPen(None)
pen.moveTo((0, 0))
pen.qCurveTo((6, 6), (10, 0))
self.assertEqual("0 0 10 6", bounds_(pen))
if __name__ == '__main__':
unittest.main()