from __future__ import print_function, absolute_import, division from fontTools.misc.py23 import * from fontTools.svgLib.path import shapes from fontTools.misc import etree import pytest @pytest.mark.parametrize( "svg_xml, expected_path, expected_transform", [ # path: direct passthrough ( "", "I love kittens", None ), # path no @d ( "", None, None ), # line ( '', 'M10,110 L50,150', None ), # line, decimal positioning ( '', 'M10,110.2 L50.5,150.7', None ), # rect: minimal valid example ( "", "M0,0 H1 V1 H0 V0 z", None ), # rect: sharp corners ( "", "M10,11 H27 V22 H10 V11 z", None ), # rect: round corners ( "", "M11,9 H18 A2,2 0 0 1 20,11 V14 A2,2 0 0 1 18,16 H11" " A2,2 0 0 1 9,14 V11 A2,2 0 0 1 11,9 z", None ), # rect: simple ( "", "M11.5,16 H22.5 V18 H11.5 V16 z", None ), # rect: the one above plus a rotation ( "", "M11.5,16 H22.5 V18 H11.5 V16 z", (0.7071, -0.7071, 0.7071, 0.7071, -7.0416, 16.9999) ), # polygon ( "", "M30,10 50,30 10,30 z", None ), # polyline ( "", "M30,10 50,30 10,30", None ), # circle, minimal valid example ( "", "M-1,0 A1,1 0 1 1 1,0 A1,1 0 1 1 -1,0", None ), # circle ( "", "M500,200 A100,100 0 1 1 700,200 A100,100 0 1 1 500,200", None ), # circle, decimal positioning ( "", "M10.5,6.5 A1.5,1.5 0 1 1 13.5,6.5 A1.5,1.5 0 1 1 10.5,6.5", None ), # circle, with transform ( '', 'M35.6,51 A14.3,14.3 0 1 1 64.2,51 A14.3,14.3 0 1 1 35.6,51', (0.9871, -0.1602, 0.1602, 0.9871, -7.525, 8.6516) ), # ellipse ( '', 'M0,50 A100,50 0 1 1 200,50 A100,50 0 1 1 0,50', None ), # ellipse, decimal positioning ( '', 'M90.5,50 A10,50.5 0 1 1 110.5,50 A10,50.5 0 1 1 90.5,50', None ), # ellipse, with transform ( '', 'M28.6,59.1 A30.9,11.9 0 1 1 90.4,59.1 A30.9,11.9 0 1 1 28.6,59.1', (0.9557, -0.2945, 0.2945, 0.9557, -14.7694, 20.1454) ), ] ) def test_el_to_path(svg_xml, expected_path, expected_transform): pb = shapes.PathBuilder() pb.add_path_from_element(etree.fromstring(svg_xml)) if expected_path: expected_paths = [expected_path] expected_transforms = [expected_transform] else: expected_paths = [] expected_transforms = [] assert pb.paths == expected_paths assert pb.transforms == expected_transforms