diff options
Diffstat (limited to 'svgio/qa/cppunit/SvgImportTest.cxx')
-rw-r--r-- | svgio/qa/cppunit/SvgImportTest.cxx | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/svgio/qa/cppunit/SvgImportTest.cxx b/svgio/qa/cppunit/SvgImportTest.cxx index 7263439e86c1..0a976eb276e0 100644 --- a/svgio/qa/cppunit/SvgImportTest.cxx +++ b/svgio/qa/cppunit/SvgImportTest.cxx @@ -1431,6 +1431,52 @@ CPPUNIT_TEST_FIXTURE(Test, testTdf156269) assertXPath(pDocument, "//textsimpleportion[@text='two']", "fontcolor", "#000000"); } +CPPUNIT_TEST_FIXTURE(Test, testTdf156271) +{ + Primitive2DSequence aSequence = parseSvg(u"/svgio/qa/cppunit/data/tdf156271.svg"); + CPPUNIT_ASSERT_EQUAL(1, static_cast<int>(aSequence.getLength())); + + drawinglayer::Primitive2dXmlDump dumper; + xmlDocUniquePtr pDocument = dumper.dumpAndParse(Primitive2DContainer(aSequence)); + + CPPUNIT_ASSERT (pDocument); + + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "width", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "height", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "x", "40"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "y", "10"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "text", "AB"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "dx0", "-30"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[1]", "dx1", "-19"); + + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "width", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "height", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "x", "40"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "y", "20"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "text", "AB"); + + // Without the fix in place, this test would have failed with + // - Expected: -30 + // - Actual : 0 + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "dx0", "-30"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[2]", "dx1", "-19"); + + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "width", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "height", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "x", "40"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "y", "30"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "text", "AB"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "dx0", "-30"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[3]", "dx1", "-19"); + + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[4]", "width", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[4]", "height", "16"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[4]", "x", "40"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[4]", "y", "40"); + assertXPath(pDocument, "/primitive2D/transform/mask/textsimpleportion[4]", "text", "AB"); + assertXPathNoAttribute(pDocument, "/primitive2D/transform/mask/textsimpleportion[4]", "dx0"); +} + CPPUNIT_TEST_FIXTURE(Test, testTdf149880) { Primitive2DSequence aSequence = parseSvg(u"/svgio/qa/cppunit/data/tdf149880.svg"); |