summaryrefslogtreecommitdiff
path: root/svgio/qa
diff options
context:
space:
mode:
authorTomaž Vajngerl <tomaz.vajngerl@collabora.co.uk>2021-05-01 15:06:14 +0900
committerTomaž Vajngerl <quikee@gmail.com>2021-05-01 13:45:43 +0200
commitafad6ba0f841985ee87a0a0871e10cda5d8913cc (patch)
tree24af51a61352b5c2862c09756d1643a406b04686 /svgio/qa
parent0acc9af66dd2d35c8335291ff3e72d98e4359bd5 (diff)
svgio: add test for SvgNumber::solve
Change-Id: I38aa58f9be104754d32ca985022947c3c7225f0c Reviewed-on: https://gerrit.libreoffice.org/c/core/+/114963 Tested-by: Jenkins Reviewed-by: Tomaž Vajngerl <quikee@gmail.com>
Diffstat (limited to 'svgio/qa')
-rw-r--r--svgio/qa/cppunit/SvgNumberTest.cxx43
1 files changed, 40 insertions, 3 deletions
diff --git a/svgio/qa/cppunit/SvgNumberTest.cxx b/svgio/qa/cppunit/SvgNumberTest.cxx
index 1880178cc360..f420a44b42fe 100644
--- a/svgio/qa/cppunit/SvgNumberTest.cxx
+++ b/svgio/qa/cppunit/SvgNumberTest.cxx
@@ -20,15 +20,30 @@ namespace
{
class TestNumber : public CppUnit::TestFixture
{
- void test();
+ void testSetting();
+ void testSolve();
public:
CPPUNIT_TEST_SUITE(TestNumber);
- CPPUNIT_TEST(test);
+ CPPUNIT_TEST(testSetting);
+ CPPUNIT_TEST(testSolve);
CPPUNIT_TEST_SUITE_END();
};
-void TestNumber::test()
+class TestInfoProvider : public svgio::svgreader::InfoProvider
+{
+public:
+ basegfx::B2DRange getCurrentViewPort() const override
+ {
+ return basegfx::B2DRange(0.0, 0.0, 0.0, 0.0);
+ }
+
+ double getCurrentFontSizeInherited() const override { return 12.0; }
+
+ double getCurrentXHeightInherited() const override { return 5.0; }
+};
+
+void TestNumber::testSetting()
{
{
svgio::svgreader::SvgNumber aNumber;
@@ -50,6 +65,28 @@ void TestNumber::test()
}
}
+void TestNumber::testSolve()
+{
+ {
+ svgio::svgreader::SvgNumber aNumber(1.01);
+ TestInfoProvider aInfoProvider;
+ double aSolvedNumber = aNumber.solve(aInfoProvider);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1.01, aSolvedNumber, 1e-8);
+ }
+ {
+ svgio::svgreader::SvgNumber aNumber(1.0, svgio::svgreader::SvgUnit::pt);
+ TestInfoProvider aInfoProvider;
+ double aSolvedNumber = aNumber.solve(aInfoProvider);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(1.333, aSolvedNumber, 1e-3);
+ }
+ {
+ svgio::svgreader::SvgNumber aNumber(2.54, svgio::svgreader::SvgUnit::cm);
+ TestInfoProvider aInfoProvider;
+ double aSolvedNumber = aNumber.solve(aInfoProvider);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(96.0, aSolvedNumber, 1e-3);
+ }
+}
+
CPPUNIT_TEST_SUITE_REGISTRATION(TestNumber);
}