diff options
author | Tomaž Vajngerl <tomaz.vajngerl@collabora.com> | 2014-08-16 20:43:09 +0200 |
---|---|---|
committer | Tomaž Vajngerl <tomaz.vajngerl@collabora.com> | 2014-08-16 20:49:20 +0200 |
commit | 871b196f7e7296eb4e397f84f1700db33d77bfb9 (patch) | |
tree | 1819c3113c1c14208ad03771fd6189e4ce906717 | |
parent | 4bc6484c594cd11d2f04e9918aada20d49934bee (diff) |
SVG test: check content of Primitive2DSequence with the XML dumper
Change-Id: I12954cd52cece2d2fe99b7b4ca1e60cee3b430f0
-rw-r--r-- | svgio/CppunitTest_svgio.mk | 5 | ||||
-rw-r--r-- | svgio/qa/cppunit/SvgImportTest.cxx | 49 |
2 files changed, 41 insertions, 13 deletions
diff --git a/svgio/CppunitTest_svgio.mk b/svgio/CppunitTest_svgio.mk index 6c1380ce40b2..2aa4f39b61c4 100644 --- a/svgio/CppunitTest_svgio.mk +++ b/svgio/CppunitTest_svgio.mk @@ -14,7 +14,10 @@ $(eval $(call gb_CppunitTest_set_include,svgio_import_test,\ -I$(SRCDIR)/svgio/inc \ )) -$(eval $(call gb_CppunitTest_use_external,svgio_import_test,boost_headers)) +$(eval $(call gb_CppunitTest_use_externals,svgio_import_test,\ + boost_headers \ + libxml2 \ +)) $(eval $(call gb_CppunitTest_use_api,svgio_import_test,\ offapi \ diff --git a/svgio/qa/cppunit/SvgImportTest.cxx b/svgio/qa/cppunit/SvgImportTest.cxx index 5b8392d843a8..b2ed826fe06d 100644 --- a/svgio/qa/cppunit/SvgImportTest.cxx +++ b/svgio/qa/cppunit/SvgImportTest.cxx @@ -8,7 +8,11 @@ */ #include <sal/config.h> + #include <test/bootstrapfixture.hxx> +#include <test/primitive2dxmldump.hxx> +#include <test/xmltesttools.hxx> + #include <comphelper/processfactory.hxx> #include <comphelper/seqstream.hxx> @@ -28,8 +32,10 @@ using namespace css::io; using namespace css::graphic; using drawinglayer::primitive2d::arePrimitive2DSequencesEqual; -class Test : public test::BootstrapFixture +class Test : public test::BootstrapFixture, public XmlTestTools { + void checkRectPrimitive(Primitive2DSequence& rPrimitive); + void testStyles(); Primitive2DSequence parseSvg(const char* aSource); @@ -72,28 +78,47 @@ void Test::tearDown() BootstrapFixture::tearDown(); } +void Test::checkRectPrimitive(Primitive2DSequence& rPrimitive) +{ + Primitive2dXmlDump dumper; + xmlDocPtr pDocument = dumper.dumpAndParse(rPrimitive); + + CPPUNIT_ASSERT (pDocument); + + assertXPath(pDocument, "/primitive2D/transform/polypolygoncolor", "color", "#00cc00"); // rect background color + assertXPath(pDocument, "/primitive2D/transform/polypolygonstroke/line", "color", "#ff0000"); // rect stroke color + assertXPath(pDocument, "/primitive2D/transform/polypolygonstroke/line", "width", "3"); // rect stroke width + +} + // Attributes for an object (like rect as in this case) can be defined // in different ways (directly with xml attributes, or with CSS styles), // however the end result should be the same. void Test::testStyles() { - Primitive2DSequence maSequenceRect = parseSvg("/svgio/qa/cppunit/data/Rect.svg"); - CPPUNIT_ASSERT_EQUAL(1, (int) maSequenceRect.getLength()); + Primitive2DSequence aSequenceRect = parseSvg("/svgio/qa/cppunit/data/Rect.svg"); + CPPUNIT_ASSERT_EQUAL(1, (int) aSequenceRect.getLength()); + checkRectPrimitive(aSequenceRect); - Primitive2DSequence maSequenceRectWithStyle = parseSvg("/svgio/qa/cppunit/data/RectWithStyles.svg"); - CPPUNIT_ASSERT_EQUAL(1, (int) maSequenceRectWithStyle.getLength()); + Primitive2DSequence aSequenceRectWithStyle = parseSvg("/svgio/qa/cppunit/data/RectWithStyles.svg"); + CPPUNIT_ASSERT_EQUAL(1, (int) aSequenceRectWithStyle.getLength()); + checkRectPrimitive(aSequenceRectWithStyle); - Primitive2DSequence maSequenceRectWithParentStyle = parseSvg("/svgio/qa/cppunit/data/RectWithParentStyles.svg"); - CPPUNIT_ASSERT_EQUAL(1, (int) maSequenceRectWithParentStyle.getLength()); + Primitive2DSequence aSequenceRectWithParentStyle = parseSvg("/svgio/qa/cppunit/data/RectWithParentStyles.svg"); + CPPUNIT_ASSERT_EQUAL(1, (int) aSequenceRectWithParentStyle.getLength()); + checkRectPrimitive(aSequenceRectWithParentStyle); - Primitive2DSequence maSequenceRectWithStylesByGroup = parseSvg("/svgio/qa/cppunit/data/RectWithStylesByGroup.svg"); - CPPUNIT_ASSERT_EQUAL(1, (int) maSequenceRectWithStylesByGroup.getLength()); + Primitive2DSequence aSequenceRectWithStylesByGroup = parseSvg("/svgio/qa/cppunit/data/RectWithStylesByGroup.svg"); + CPPUNIT_ASSERT_EQUAL(1, (int) aSequenceRectWithStylesByGroup.getLength()); + checkRectPrimitive(aSequenceRectWithStylesByGroup); + + CPPUNIT_ASSERT(arePrimitive2DSequencesEqual(aSequenceRect, aSequenceRectWithStyle)); + CPPUNIT_ASSERT(arePrimitive2DSequencesEqual(aSequenceRect, aSequenceRectWithParentStyle)); + CPPUNIT_ASSERT(arePrimitive2DSequencesEqual(aSequenceRect, aSequenceRectWithStylesByGroup)); - CPPUNIT_ASSERT(arePrimitive2DSequencesEqual(maSequenceRect, maSequenceRectWithStyle)); - CPPUNIT_ASSERT(arePrimitive2DSequencesEqual(maSequenceRect, maSequenceRectWithParentStyle)); - CPPUNIT_ASSERT(arePrimitive2DSequencesEqual(maSequenceRect, maSequenceRectWithStylesByGroup)); } + CPPUNIT_TEST_SUITE_REGISTRATION(Test); } |