diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:24:48 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:24:48 +0000 |
commit | cca66b9ec4e494c1d919bff0f71a820d8afab1fa (patch) | |
tree | 146f39ded1c938019e1ed42d30923c2ac9e86789 /share/extensions/tests/test_dxf_outlines.py | |
parent | Initial commit. (diff) | |
download | inkscape-upstream.tar.xz inkscape-upstream.zip |
Adding upstream version 1.2.2.upstream/1.2.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | share/extensions/tests/test_dxf_outlines.py | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/share/extensions/tests/test_dxf_outlines.py b/share/extensions/tests/test_dxf_outlines.py new file mode 100644 index 0000000..9639c28 --- /dev/null +++ b/share/extensions/tests/test_dxf_outlines.py @@ -0,0 +1,76 @@ +# coding=utf-8 +from io import BytesIO +from dxf_outlines import DxfOutlines +from inkex.tester import ComparisonMixin, InkscapeExtensionTestMixin, TestCase +from inkex.tester.filters import WindowsTextCompat +from inkex.elements._parser import load_svg + +from inkex.utils import AbortExtension +from inkex.base import SvgOutputMixin +from inkex.elements import Rectangle + + +class DFXOutlineBasicTest(ComparisonMixin, InkscapeExtensionTestMixin, TestCase): + effect_class = DxfOutlines + comparisons = [ + (), + ("--id=p1", "--id=r3"), + ("--POLY=true",), + ("--ROBO=true",), + ] + compare_filters = [WindowsTextCompat()] + + +def run_extension(document, *args) -> str: + output = BytesIO() + ext = DxfOutlines() + ext.parse_arguments([*args]) + ext.svg = document.getroot() + ext.document = document + ext.effect() + ext.save(output) + output.seek(0) + return output.read() + + +class DXFDeeplyNestedTest(TestCase): + """Check that a deeply nested SVG raises an AbortExtension""" + + @staticmethod + def create_deep_svg(amount): + """Create a very deep svg and test getting ancestors""" + svg = '<svg xmlns="http://www.w3.org/2000/svg">' + for i in range(amount): + svg += f'<g id="{i}">' + svg = load_svg(svg + ("</g>" * amount) + "</svg>") + return svg + + def test_deeply_nested(self): + "Run test" + with self.assertRaisesRegex(AbortExtension, "Deep Ungroup"): + run_extension(self.create_deep_svg(1500)) + + +class TestDxfUnits(TestCase): + """Test ensuring that units work properly""" + + def test_mm(self): + """Test that the documents created with/without scaling and base units are + identical.""" + document = SvgOutputMixin.get_template(width=210, height=297, unit="mm") + document.getroot().namedview.set("inkscape:document-units", "mm") + document.getroot().add(Rectangle.new(200, 0, 10, 16)) + out1 = run_extension(document) + + document = SvgOutputMixin.get_template(width=210, height=297, unit="mm") + document.getroot().add(Rectangle.new(200, 0, 10, 16)) + out2 = run_extension(document, "--unit_from_document=False", "--units=mm") + + self.assertEqual(out1, out2) + # Now with scaling - should result in the same document + document = SvgOutputMixin.get_template(width=210, height=297, unit="mm") + document.getroot().set("viewBox", "0 0 105 148.5") + document.getroot().add(Rectangle.new(100, 0, 5, 8)) + out3 = run_extension(document, "--unit_from_document=False", "--units=mm") + + self.assertEqual(out1, out3) |