From 208a6896958b5281c11875b5c57806ca2daa9118 Mon Sep 17 00:00:00 2001 From: Tomaž Vajngerl Date: Sun, 3 Mar 2019 14:05:35 +0100 Subject: Update SvgRead test - add new parameters and path parsing MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Change-Id: Ic19bd2167cc359eef02648fa0ebd1d858fdeaec5 Reviewed-on: https://gerrit.libreoffice.org/68827 Reviewed-by: Tomaž Vajngerl Tested-by: Tomaž Vajngerl --- svgio/qa/cppunit/SvgRead.cxx | 65 ++++++++++++++++++++++++++++++++++-------- svgio/qa/cppunit/data/path.svg | 3 ++ 2 files changed, 56 insertions(+), 12 deletions(-) create mode 100644 svgio/qa/cppunit/data/path.svg (limited to 'svgio') diff --git a/svgio/qa/cppunit/SvgRead.cxx b/svgio/qa/cppunit/SvgRead.cxx index 3c7974794e1b..996be9d21f08 100644 --- a/svgio/qa/cppunit/SvgRead.cxx +++ b/svgio/qa/cppunit/SvgRead.cxx @@ -40,23 +40,26 @@ #include #include +#include namespace { using namespace css; -class Test : public test::BootstrapFixture +class TestParsing : public test::BootstrapFixture { - void test(); + void testSimpleRectangle(); + void testPath(); uno::Reference parseSvg(const OUString& aSource); public: - CPPUNIT_TEST_SUITE(Test); - CPPUNIT_TEST(test); + CPPUNIT_TEST_SUITE(TestParsing); + CPPUNIT_TEST(testSimpleRectangle); + CPPUNIT_TEST(testPath); CPPUNIT_TEST_SUITE_END(); }; -uno::Reference Test::parseSvg(const OUString& aSource) +uno::Reference TestParsing::parseSvg(const OUString& aSource) { SvFileStream aFileStream(aSource, StreamMode::READ); std::size_t nSize = aFileStream.remainingSize(); @@ -70,7 +73,7 @@ uno::Reference Test::parseSvg(const OUString& aSource) return aInputStream; } -void Test::test() +void TestParsing::testSimpleRectangle() { OUString aSvgFile = "/svgio/qa/cppunit/data/Rect.svg"; OUString aUrl = m_directories.getURLFromSrc(aSvgFile); @@ -84,18 +87,56 @@ void Test::test() uno::Any aAny = xSvgParser->getDrawCommands(xStream, aPath); CPPUNIT_ASSERT(aAny.has()); - gfx::DrawRoot* pDrawRoot = reinterpret_cast(aAny.get()); + auto* pDrawRoot = reinterpret_cast(aAny.get()); + + basegfx::B2DRange aSurfaceRectangle(0, 0, 120, 120); CPPUNIT_ASSERT_EQUAL(size_t(1), pDrawRoot->maChildren.size()); - CPPUNIT_ASSERT_EQUAL(basegfx::B2DRange(0, 0, 120, 120), pDrawRoot->maRectangle); + CPPUNIT_ASSERT_EQUAL(aSurfaceRectangle, pDrawRoot->maRectangle); + auto* pDrawBase = pDrawRoot->maChildren[0].get(); CPPUNIT_ASSERT_EQUAL(gfx::DrawCommandType::Rectangle, pDrawRoot->maChildren[0]->getType()); - CPPUNIT_ASSERT_EQUAL( - basegfx::B2DRange(10, 10, 110, 110), - static_cast(pDrawRoot->maChildren[0].get())->maRectangle); + auto* pDrawRect = static_cast(pDrawBase); + CPPUNIT_ASSERT_EQUAL(basegfx::B2DRange(10, 10, 110, 110), pDrawRect->maRectangle); + CPPUNIT_ASSERT_EQUAL(3.0, pDrawRect->mnStrokeWidth); + CPPUNIT_ASSERT(bool(pDrawRect->mpStrokeColor)); + CPPUNIT_ASSERT_EQUAL(sal_Int32(0xff0000), sal_Int32(Color(*pDrawRect->mpStrokeColor))); + CPPUNIT_ASSERT(bool(pDrawRect->mpFillColor)); + CPPUNIT_ASSERT_EQUAL(sal_Int32(0x00cc00), sal_Int32(Color(*pDrawRect->mpFillColor))); +} + +void TestParsing::testPath() +{ + OUString aSvgFile = "/svgio/qa/cppunit/data/path.svg"; + OUString aUrl = m_directories.getURLFromSrc(aSvgFile); + OUString aPath = m_directories.getPathFromSrc(aSvgFile); + + uno::Reference xStream = parseSvg(aUrl); + CPPUNIT_ASSERT(xStream.is()); + + uno::Reference xContext(comphelper::getProcessComponentContext()); + const uno::Reference xSvgParser = graphic::SvgTools::create(xContext); + + uno::Any aAny = xSvgParser->getDrawCommands(xStream, aPath); + CPPUNIT_ASSERT(aAny.has()); + auto* pDrawRoot = reinterpret_cast(aAny.get()); + + CPPUNIT_ASSERT_EQUAL(size_t(1), pDrawRoot->maChildren.size()); + + auto* pDrawBase = pDrawRoot->maChildren[0].get(); + CPPUNIT_ASSERT_EQUAL(gfx::DrawCommandType::Path, pDrawBase->getType()); + auto* pDrawPath = static_cast(pDrawBase); + + CPPUNIT_ASSERT_EQUAL(OUString("m1 1h42v24h-42v-24z"), + basegfx::utils::exportToSvgD(pDrawPath->maPolyPolygon, true, true, false)); + CPPUNIT_ASSERT_EQUAL(0.0, pDrawPath->mnStrokeWidth); + CPPUNIT_ASSERT(bool(pDrawPath->mpStrokeColor)); + CPPUNIT_ASSERT_EQUAL(sal_Int32(0xffffff), sal_Int32(Color(*pDrawPath->mpStrokeColor))); + CPPUNIT_ASSERT(bool(pDrawPath->mpFillColor)); + CPPUNIT_ASSERT_EQUAL(sal_Int32(0x007aff), sal_Int32(Color(*pDrawPath->mpFillColor))); } -CPPUNIT_TEST_SUITE_REGISTRATION(Test); +CPPUNIT_TEST_SUITE_REGISTRATION(TestParsing); } CPPUNIT_PLUGIN_IMPLEMENT(); diff --git a/svgio/qa/cppunit/data/path.svg b/svgio/qa/cppunit/data/path.svg new file mode 100644 index 000000000000..1722181c872e --- /dev/null +++ b/svgio/qa/cppunit/data/path.svg @@ -0,0 +1,3 @@ + + + -- cgit v1.2.3