diff options
author | Mike Kaganski <mike.kaganski@collabora.com> | 2022-09-08 13:59:32 +0300 |
---|---|---|
committer | Mike Kaganski <mike.kaganski@collabora.com> | 2022-09-08 14:39:21 +0200 |
commit | 09e499e64ec4acb24c9524c8aacabc6182124442 (patch) | |
tree | b2ccb167ca8828cb42da04983874cb9de3219aaa | |
parent | 707b0c328a282d993fa33b618083d20b6c521de6 (diff) |
Fix CppunitTest_chart2_import on non-default DPI
It is really unfortunate that so much of our code depends on the
DPI, that should not.
Change-Id: Id1916677add508171490591a234f07a82a8e3f5b
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/139648
Tested-by: Jenkins
Reviewed-by: Mike Kaganski <mike.kaganski@collabora.com>
-rw-r--r-- | chart2/qa/extras/chart2import.cxx | 27 | ||||
-rw-r--r-- | chart2/qa/extras/xshape/chart2xshape.cxx | 15 |
2 files changed, 31 insertions, 11 deletions
diff --git a/chart2/qa/extras/chart2import.cxx b/chart2/qa/extras/chart2import.cxx index 4e5b3a83130e..40a56d7535f1 100644 --- a/chart2/qa/extras/chart2import.cxx +++ b/chart2/qa/extras/chart2import.cxx @@ -2183,19 +2183,23 @@ void Chart2ImportTest::testFixedSizeBarChartVeryLongLabel() uno::Reference<container::XIndexAccess> xIndexAccess(xXAxis, UNO_QUERY_THROW); - // Check text is actually cropped - uno::Reference<text::XTextRange> xLabel(xIndexAccess->getByIndex(0), uno::UNO_QUERY); - CPPUNIT_ASSERT_EQUAL(OUString("Very very very very very very..."), xLabel->getString()); + // Check text is actually cropped. Depending on DPI, + // it may be "Very very very very very very..." or "Very very very very very ver..." + uno::Reference<text::XTextRange> xLabel(xIndexAccess->getByIndex(0), uno::UNO_QUERY_THROW); + const OUString aLabelString = xLabel->getString(); + CPPUNIT_ASSERT_LESSEQUAL(sal_Int32(32), aLabelString.getLength()); + CPPUNIT_ASSERT(aLabelString.endsWith(u"...")); uno::Reference<drawing::XShape> xChartWall = getShapeByName(xShapes, "CID/DiagramWall="); CPPUNIT_ASSERT(xChartWall.is()); // The text shape width should be smaller than the chart wall - CPPUNIT_ASSERT_EQUAL(sal_Int32(5085), xChartWall->getSize().Width); - CPPUNIT_ASSERT_EQUAL(sal_Int32(7113), xChartWall->getSize().Height); + // The specific numbers unfortunately vary depending on DPI - allow 1 mm + CPPUNIT_ASSERT_DOUBLES_EQUAL(5085, xChartWall->getSize().Width, 100); + CPPUNIT_ASSERT_DOUBLES_EQUAL(7113, xChartWall->getSize().Height, 100); - CPPUNIT_ASSERT_EQUAL(sal_Int32(4870), xXAxis->getSize().Width); - CPPUNIT_ASSERT_EQUAL(sal_Int32(398), xXAxis->getSize().Height); + CPPUNIT_ASSERT_DOUBLES_EQUAL(4800, xXAxis->getSize().Width, 100); + CPPUNIT_ASSERT_DOUBLES_EQUAL(398, xXAxis->getSize().Height, 100); } void Chart2ImportTest::testAutomaticSizeBarChartVeryLongLabel() @@ -2260,11 +2264,12 @@ void Chart2ImportTest::testAutomaticSizeBarChartVeryLongLabel() CPPUNIT_ASSERT(xChartWall.is()); // The text shape width should be smaller than the chart wall - CPPUNIT_ASSERT_EQUAL(sal_Int32(5761), xChartWall->getSize().Width); - CPPUNIT_ASSERT_EQUAL(sal_Int32(7200), xChartWall->getSize().Height); + // The specific numbers unfortunately vary depending on DPI - allow 1 mm + CPPUNIT_ASSERT_DOUBLES_EQUAL(5761, xChartWall->getSize().Width, 100); + CPPUNIT_ASSERT_DOUBLES_EQUAL(7200, xChartWall->getSize().Height, 100); - CPPUNIT_ASSERT_EQUAL(sal_Int32(5320), xXAxis->getSize().Width); - CPPUNIT_ASSERT_EQUAL(sal_Int32(1192), xXAxis->getSize().Height); + CPPUNIT_ASSERT_DOUBLES_EQUAL(5320, xXAxis->getSize().Width, 100); + CPPUNIT_ASSERT_DOUBLES_EQUAL(1192, xXAxis->getSize().Height, 100); } CPPUNIT_TEST_SUITE_REGISTRATION(Chart2ImportTest); diff --git a/chart2/qa/extras/xshape/chart2xshape.cxx b/chart2/qa/extras/xshape/chart2xshape.cxx index 45d92e58187b..2814dfcce46c 100644 --- a/chart2/qa/extras/xshape/chart2xshape.cxx +++ b/chart2/qa/extras/xshape/chart2xshape.cxx @@ -95,12 +95,22 @@ void Chart2XShapeTest::compareAgainstReference(std::u16string_view rReferenceFil void Chart2XShapeTest::testFdo75075() { + // FIXME: the DPI check should be removed when either (1) the test is fixed to work with + // non-default DPI; or (2) unit tests on Windows are made to use svp VCL plugin. + if (!IsDefaultDPI()) + return; + load(u"chart2/qa/extras/xshape/data/ods/", u"fdo75075.ods"); compareAgainstReference(u"fdo75075.xml"); } void Chart2XShapeTest::testPropertyMappingBarChart() { + // FIXME: the DPI check should be removed when either (1) the test is fixed to work with + // non-default DPI; or (2) unit tests on Windows are made to use svp VCL plugin. + if (!IsDefaultDPI()) + return; + load(u"chart2/qa/extras/xshape/data/ods/", u"property-mapping-bar.ods"); compareAgainstReference(u"property-mapping-bar.xml"); } @@ -155,6 +165,11 @@ void Chart2XShapeTest::testPieChartLabels4() void Chart2XShapeTest::testChart() { + // FIXME: the DPI check should be removed when either (1) the test is fixed to work with + // non-default DPI; or (2) unit tests on Windows are made to use svp VCL plugin. + if (!IsDefaultDPI()) + return; + load(u"chart2/qa/extras/xshape/data/ods/", u"testChart.ods"); compareAgainstReference(u"testChart.xml"); } |