/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "charttest.hxx" #include #include #include #include #include #include #include #include #include #include class Chart2ImportTest2 : public ChartTest { public: Chart2ImportTest2() : ChartTest("/chart2/qa/extras/data/") { } }; CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf114179) { loadFromURL(u"docx/testTdf114179.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); css::uno::Reference xDiagram; xDiagram.set(xChartDoc->getFirstDiagram()); CPPUNIT_ASSERT_MESSAGE("There is a Diagram.", xDiagram.is()); awt::Size aPage = getPageSize(xChartDoc); awt::Size aSize = getSize(xDiagram, aPage); CPPUNIT_ASSERT(aSize.Width > 0); CPPUNIT_ASSERT(aSize.Height > 0); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf124243) { loadFromURL(u"docx/tdf124243.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); Reference xPS(xAxis, uno::UNO_QUERY_THROW); bool bShow = true; // test X Axis is not visible. bool bSuccess = xPS->getPropertyValue("Show") >>= bShow; CPPUNIT_ASSERT(bSuccess); CPPUNIT_ASSERT(!bShow); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf127393) { loadFromURL(u"pptx/tdf127393.pptx"); // 1st chart Reference xChartDoc(getChartDocFromDrawImpress(0, 0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData1 = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData1.Categories.is()); CPPUNIT_ASSERT(aScaleData1.ShiftedCategoryPosition); // 2nd chart xChartDoc.set(getChartDocFromDrawImpress(1, 0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); xAxis.set(getAxisFromDoc(xChartDoc, 0, 0, 0)); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData2 = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData2.Categories.is()); CPPUNIT_ASSERT(!aScaleData2.ShiftedCategoryPosition); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf128733) { loadFromURL(u"odt/tdf128733.odt"); Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); // test secondary X axis ShiftedCategoryPosition value Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 1); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData.Categories.is()); CPPUNIT_ASSERT(aScaleData.ShiftedCategoryPosition); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf128432) { loadFromURL(u"ods/tdf128432.ods"); uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT(xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData.Categories.is()); CPPUNIT_ASSERT(aScaleData.ShiftedCategoryPosition); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf128627) { loadFromURL(u"xlsx/tdf128627.xlsx"); // Test ShiftedCategoryPosition for Radar Chart uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData.Categories.is()); CPPUNIT_ASSERT(!aScaleData.ShiftedCategoryPosition); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf128634) { loadFromURL(u"xlsx/tdf128634.xlsx"); // Test ShiftedCategoryPosition for 3D Charts uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData.Categories.is()); CPPUNIT_ASSERT(aScaleData.ShiftedCategoryPosition); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf130657) { loadFromURL(u"xlsx/tdf130657.xlsx"); // Test ShiftedCategoryPosition for charts which is not contain a "crossbetween" OOXML tag. uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData.Categories.is()); CPPUNIT_ASSERT(aScaleData.ShiftedCategoryPosition); } namespace { void checkDataLabelProperties(const Reference& xDataSeries, sal_Int32 nDataPointIndex, bool bValueVisible) { uno::Reference xPropertySet( xDataSeries->getDataPointByIndex(nDataPointIndex), uno::UNO_SET_THROW); chart2::DataPointLabel aLabel; xPropertySet->getPropertyValue("Label") >>= aLabel; CPPUNIT_ASSERT_EQUAL(bValueVisible, static_cast(aLabel.ShowNumber)); CPPUNIT_ASSERT_EQUAL(false, static_cast(aLabel.ShowNumberInPercent)); } } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testDeletedDataLabel) { loadFromURL(u"xlsx/deleted_data_labels.xlsx"); uno::Reference xChartDoc(getChartCompFromSheet(0, 0, mxComponent), UNO_QUERY_THROW); Reference xDataSeries0 = getDataSeriesFromDoc(xChartDoc, 0); CPPUNIT_ASSERT(xDataSeries0.is()); checkDataLabelProperties(xDataSeries0, 0, true); checkDataLabelProperties(xDataSeries0, 1, false); checkDataLabelProperties(xDataSeries0, 2, true); Reference xDataSeries1 = getDataSeriesFromDoc(xChartDoc, 1); CPPUNIT_ASSERT(xDataSeries1.is()); checkDataLabelProperties(xDataSeries1, 0, false); checkDataLabelProperties(xDataSeries1, 1, false); checkDataLabelProperties(xDataSeries1, 2, false); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testDataPointInheritedColorDOCX) { loadFromURL(u"docx/data_point_inherited_color.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); css::uno::Reference xDiagram(xChartDoc->getFirstDiagram(), UNO_SET_THROW); Reference xDataSeries = getDataSeriesFromDoc(xChartDoc, 0); uno::Reference xPropertySet(xDataSeries->getDataPointByIndex(0), uno::UNO_SET_THROW); CPPUNIT_ASSERT(xPropertySet.is()); sal_Int32 nColor = xPropertySet->getPropertyValue("FillColor").get(); CPPUNIT_ASSERT_EQUAL(sal_Int32(16776960), nColor); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testExternalStrRefsXLSX) { loadFromURL(u"xlsx/external_str_ref.xlsx"); uno::Reference xChartDoc(getChartCompFromSheet(0, 0, mxComponent), UNO_QUERY_THROW); CPPUNIT_ASSERT(xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); chart2::ScaleData aScaleData = xAxis->getScaleData(); css::uno::Sequence aValues = aScaleData.Categories->getValues()->getData(); CPPUNIT_ASSERT_EQUAL(OUString("test1"), aValues[0].get()); CPPUNIT_ASSERT_EQUAL(OUString("test2"), aValues[1].get()); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testSourceNumberFormatComplexCategoriesXLS) { loadFromURL(u"xls/source_number_format_axis.xls"); uno::Reference xChartDoc(getChartCompFromSheet(0, 0, mxComponent), UNO_QUERY_THROW); CPPUNIT_ASSERT(xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); chart2::ScaleData aScaleData = xAxis->getScaleData(); sal_Int32 nNumberFormat = aScaleData.Categories->getValues()->getNumberFormatKeyByIndex(-1); CPPUNIT_ASSERT(nNumberFormat != 0); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testSimpleCategoryAxis) { loadFromURL(u"docx/testSimpleCategoryAxis.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); // Test the internal data. CPPUNIT_ASSERT(xChartDoc->hasInternalDataProvider()); Reference xInternalProvider(xChartDoc->getDataProvider(), uno::UNO_QUERY); CPPUNIT_ASSERT(xInternalProvider.is()); Reference xDescAccess(xInternalProvider, uno::UNO_QUERY); CPPUNIT_ASSERT(xDescAccess.is()); // Get the category labels. Sequence> aCategories = xDescAccess->getComplexRowDescriptions(); CPPUNIT_ASSERT_EQUAL(sal_Int32(1), aCategories[0].getLength()); CPPUNIT_ASSERT(aCategories[0][0].endsWith("ria 1")); CPPUNIT_ASSERT_EQUAL(sal_Int32(1), aCategories[1].getLength()); CPPUNIT_ASSERT(aCategories[1][0].endsWith("ria 2")); CPPUNIT_ASSERT_EQUAL(sal_Int32(1), aCategories[2].getLength()); CPPUNIT_ASSERT(aCategories[2][0].endsWith("ria 3")); CPPUNIT_ASSERT_EQUAL(sal_Int32(1), aCategories[3].getLength()); CPPUNIT_ASSERT(aCategories[3][0].endsWith("ria 4")); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testMultilevelCategoryAxis) { loadFromURL(u"docx/testMultilevelCategoryAxis.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); // Test the internal data. CPPUNIT_ASSERT(xChartDoc->hasInternalDataProvider()); Reference xInternalProvider(xChartDoc->getDataProvider(), uno::UNO_QUERY); CPPUNIT_ASSERT(xInternalProvider.is()); Reference xDescAccess(xInternalProvider, uno::UNO_QUERY); CPPUNIT_ASSERT(xDescAccess.is()); // Get the complex category labels. Sequence> aCategories = xDescAccess->getComplexRowDescriptions(); CPPUNIT_ASSERT_EQUAL(sal_Int32(4), aCategories.getLength()); CPPUNIT_ASSERT_EQUAL(OUString("2011"), aCategories[0][0]); CPPUNIT_ASSERT_EQUAL(OUString(""), aCategories[1][0]); CPPUNIT_ASSERT_EQUAL(OUString("2012"), aCategories[2][0]); CPPUNIT_ASSERT_EQUAL(OUString(""), aCategories[3][0]); CPPUNIT_ASSERT_EQUAL(OUString("Categoria 1"), aCategories[0][1]); CPPUNIT_ASSERT_EQUAL(OUString("Categoria 2"), aCategories[1][1]); CPPUNIT_ASSERT_EQUAL(OUString("Categoria 3"), aCategories[2][1]); CPPUNIT_ASSERT_EQUAL(OUString("Categoria 4"), aCategories[3][1]); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testXaxisValues) { loadFromURL(u"docx/tdf124083.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); const uno::Reference xDataSeq = getDataSequenceFromDocByRole(xChartDoc, u"values-x"); Sequence xSequence = xDataSeq->getData(); // test X values CPPUNIT_ASSERT_EQUAL(uno::Any(0.04), xSequence[0]); CPPUNIT_ASSERT(std::isnan(*static_cast(xSequence[1].getValue()))); CPPUNIT_ASSERT_EQUAL(uno::Any(0.16), xSequence[2]); CPPUNIT_ASSERT_EQUAL(uno::Any(0.11), xSequence[3]); CPPUNIT_ASSERT(std::isnan(*static_cast(xSequence[4].getValue()))); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf123504) { loadFromURL(u"ods/pie_chart_100_and_0.ods"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xChartDoc2(xChartDoc, UNO_QUERY_THROW); Reference xChartType(getChartTypeFromDoc(xChartDoc2, 0), UNO_SET_THROW); std::vector aDataSeriesYValues = getDataSeriesYValuesFromChartType(xChartType); CPPUNIT_ASSERT_EQUAL(size_t(1), aDataSeriesYValues.size()); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xSeriesSlices(getShapeByName(xShapes, "CID/D=0:CS=0:CT=0:Series=0"), UNO_SET_THROW); Reference xIndexAccess(xSeriesSlices, UNO_QUERY_THROW); CPPUNIT_ASSERT_EQUAL(sal_Int32(1), xIndexAccess->getCount()); Reference xSlice(xIndexAccess->getByIndex(0), UNO_QUERY_THROW); // Check size and position of the only slice in the chart (100%) // In the regressed state, it used to be 0-sized at position 0,0 awt::Point aSlicePosition = xSlice->getPosition(); CPPUNIT_ASSERT_GREATER(sal_Int32(3000), aSlicePosition.X); CPPUNIT_ASSERT_GREATER(sal_Int32(150), aSlicePosition.Y); awt::Size aSliceSize = xSlice->getSize(); CPPUNIT_ASSERT_DOUBLES_EQUAL(8300.0, aSliceSize.Height, 10); CPPUNIT_ASSERT_DOUBLES_EQUAL(8300.0, aSliceSize.Width, 10); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf122765) { // The horizontal position of the slices was wrong. loadFromURL(u"pptx/tdf122765.pptx"); Reference xChartDoc = getChartDocFromDrawImpress(0, 0); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xSeriesSlices(getShapeByName(xShapes, "CID/D=0:CS=0:CT=0:Series=0"), UNO_SET_THROW); Reference xIndexAccess(xSeriesSlices, UNO_QUERY_THROW); CPPUNIT_ASSERT_EQUAL(sal_Int32(9), xIndexAccess->getCount()); Reference xSlice(xIndexAccess->getByIndex(0), UNO_QUERY_THROW); // Check position of the first slice, all slices move together, so enough to check only one. // Wrong position was around 5856. awt::Point aSlicePosition = xSlice->getPosition(); CPPUNIT_ASSERT_GREATER(sal_Int32(7000), aSlicePosition.X); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf123206CustomLabelField) { // File contains the deprecated "custom-label-field" attribute of the // "data-point" element. It should be interpreted and stored as a data point // property. loadFromURL(u"odp/tdf123206.odp"); uno::Reference xChartDoc(getChartDocFromDrawImpress(0, 0), uno::UNO_QUERY_THROW); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); CPPUNIT_ASSERT(xChartDoc.is()); Reference xDataSeries = getDataSeriesFromDoc(xChartDoc, 0); CPPUNIT_ASSERT(xDataSeries.is()); Reference xDp = xDataSeries->getDataPointByIndex(1); Sequence> aLabelFields; CPPUNIT_ASSERT(xDp->getPropertyValue("CustomLabelFields") >>= aLabelFields); CPPUNIT_ASSERT_EQUAL(static_cast(1), aLabelFields.getLength()); CPPUNIT_ASSERT_EQUAL(OUString("Kiskacsa"), aLabelFields[0]->getString()); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf125444PercentageCustomLabel) { loadFromURL(u"pptx/tdf125444.pptx"); // 1st chart Reference xChartDoc(getChartDocFromDrawImpress(0, 0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); uno::Reference xDataSeries(getDataSeriesFromDoc(xChartDoc, 0)); CPPUNIT_ASSERT(xDataSeries.is()); Reference xDp = xDataSeries->getDataPointByIndex(1); Sequence> aLabelFields; CPPUNIT_ASSERT(xDp->getPropertyValue("CustomLabelFields") >>= aLabelFields); // There are three label field: a value label, a newline and a percentage label. We want // to assert the latter. CPPUNIT_ASSERT_EQUAL(static_cast(3), aLabelFields.getLength()); CPPUNIT_ASSERT_EQUAL(chart2::DataPointCustomLabelFieldType_PERCENTAGE, aLabelFields[2]->getFieldType()); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testDataPointLabelCustomPos) { // test CustomLabelPosition on Bar chart loadFromURL(u"xlsx/testDataPointLabelCustomPos.xlsx"); uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT(xChartDoc.is()); uno::Reference xDataSeries(getDataSeriesFromDoc(xChartDoc, 0)); CPPUNIT_ASSERT(xDataSeries.is()); uno::Reference xPropertySet(xDataSeries->getDataPointByIndex(0), uno::UNO_SET_THROW); CPPUNIT_ASSERT(xPropertySet.is()); chart2::RelativePosition aCustomLabelPosition; xPropertySet->getPropertyValue("CustomLabelPosition") >>= aCustomLabelPosition; CPPUNIT_ASSERT_DOUBLES_EQUAL(-0.14621409921671025, aCustomLabelPosition.Primary, 1e-7); CPPUNIT_ASSERT_DOUBLES_EQUAL(-5.2887961029923464E-2, aCustomLabelPosition.Secondary, 1e-7); sal_Int32 aPlacement; xPropertySet->getPropertyValue("LabelPlacement") >>= aPlacement; CPPUNIT_ASSERT_EQUAL(chart::DataLabelPlacement::OUTSIDE, aPlacement); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf130032) { // test CustomLabelPosition on Line chart loadFromURL(u"xlsx/testTdf130032.xlsx"); uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT(xChartDoc.is()); uno::Reference xDataSeries(getDataSeriesFromDoc(xChartDoc, 0)); CPPUNIT_ASSERT(xDataSeries.is()); uno::Reference xPropertySet(xDataSeries->getDataPointByIndex(1), uno::UNO_SET_THROW); CPPUNIT_ASSERT(xPropertySet.is()); chart2::RelativePosition aCustomLabelPosition; xPropertySet->getPropertyValue("CustomLabelPosition") >>= aCustomLabelPosition; CPPUNIT_ASSERT_DOUBLES_EQUAL(-0.0438333333333334, aCustomLabelPosition.Primary, 1e-7); CPPUNIT_ASSERT_DOUBLES_EQUAL(0.086794050743657, aCustomLabelPosition.Secondary, 1e-7); sal_Int32 aPlacement; xPropertySet->getPropertyValue("LabelPlacement") >>= aPlacement; CPPUNIT_ASSERT_EQUAL(chart::DataLabelPlacement::RIGHT, aPlacement); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf134978) { // test CustomLabelPosition on Pie chart loadFromURL(u"xlsx/tdf134978.xlsx"); uno::Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT(xChartDoc.is()); uno::Reference xDataSeries(getDataSeriesFromDoc(xChartDoc, 0)); CPPUNIT_ASSERT(xDataSeries.is()); uno::Reference xPropertySet(xDataSeries->getDataPointByIndex(2), uno::UNO_SET_THROW); CPPUNIT_ASSERT(xPropertySet.is()); chart2::RelativePosition aCustomLabelPosition; xPropertySet->getPropertyValue("CustomLabelPosition") >>= aCustomLabelPosition; CPPUNIT_ASSERT_DOUBLES_EQUAL(-0.040273622047244093, aCustomLabelPosition.Primary, 1e-7); CPPUNIT_ASSERT_DOUBLES_EQUAL(-0.25635352872557599, aCustomLabelPosition.Secondary, 1e-7); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf119138MissingAutoTitleDeleted) { loadFromURL(u"xlsx/tdf119138-missing-autotitledeleted.xlsx"); Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); Reference xTitled(xChartDoc, uno::UNO_QUERY_THROW); uno::Reference xTitle = xTitled->getTitleObject(); CPPUNIT_ASSERT_MESSAGE( "Missing autoTitleDeleted is implied to be True if title text is present", xTitle.is()); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testStockChartShiftedCategoryPosition) { loadFromURL(u"odt/stock_chart_LO_6_2.odt"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); Reference xAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xAxis.is()); chart2::ScaleData aScaleData = xAxis->getScaleData(); CPPUNIT_ASSERT(aScaleData.Categories.is()); CPPUNIT_ASSERT(aScaleData.ShiftedCategoryPosition); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf133376) { // 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; loadFromURL(u"xlsx/tdf133376.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataPointLabel( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=2"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel.is()); // Check the position of the 3rd data point label, which is out from the pie slice awt::Point aLabelPosition = xDataPointLabel->getPosition(); CPPUNIT_ASSERT_DOUBLES_EQUAL(1208, aLabelPosition.X, 30); CPPUNIT_ASSERT_DOUBLES_EQUAL(5370, aLabelPosition.Y, 30); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf134225) { loadFromURL(u"xlsx/tdf134225.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataPointLabel1( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=0"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel1.is()); Reference xDataPointLabel2( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=1"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel2.is()); #if defined(_WIN32) // font is MS Comic Sans which we can only assume is available under windows awt::Point aLabelPosition1 = xDataPointLabel1->getPosition(); awt::Point aLabelPosition2 = xDataPointLabel2->getPosition(); // Check the distance between the position of the 1st data point label and the second one CPPUNIT_ASSERT_DOUBLES_EQUAL(1493, sal_Int32(aLabelPosition2.X - aLabelPosition1.X), 30); CPPUNIT_ASSERT_DOUBLES_EQUAL(2015, sal_Int32(aLabelPosition2.Y - aLabelPosition1.Y), 30); #endif } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf136105) { // 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; loadFromURL(u"xlsx/tdf136105.xlsx"); // 1st chart with fix inner position and size { Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataPointLabel( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=0"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel.is()); // Check the position of the 1st data point label, which is out from the pie slice awt::Point aLabelPosition = xDataPointLabel->getPosition(); CPPUNIT_ASSERT_DOUBLES_EQUAL(8797, aLabelPosition.X, 500); CPPUNIT_ASSERT_DOUBLES_EQUAL(1374, aLabelPosition.Y, 500); } // 2nd chart with auto inner position and size { Reference xChartDoc(getChartDocFromSheet(1, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataPointLabel( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=0"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel.is()); // Check the position of the 1st data point label, which is out from the pie slice awt::Point aLabelPosition = xDataPointLabel->getPosition(); CPPUNIT_ASSERT_DOUBLES_EQUAL(7978, aLabelPosition.X, 500); CPPUNIT_ASSERT_DOUBLES_EQUAL(1550, aLabelPosition.Y, 500); } } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf91250) { loadFromURL(u"docx/tdf91250.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); Reference xInternalProvider(xChartDoc->getDataProvider(), uno::UNO_QUERY); CPPUNIT_ASSERT(xInternalProvider.is()); Reference xDescAccess(xInternalProvider, uno::UNO_QUERY); CPPUNIT_ASSERT(xDescAccess.is()); // Get the category labels. Sequence aCategories = xDescAccess->getRowDescriptions(); CPPUNIT_ASSERT_EQUAL(sal_Int32(4), aCategories.getLength()); CPPUNIT_ASSERT_EQUAL(OUString("12.3254"), aCategories[0]); CPPUNIT_ASSERT_EQUAL(OUString("11.62315"), aCategories[1]); CPPUNIT_ASSERT_EQUAL(OUString("9.26"), aCategories[2]); CPPUNIT_ASSERT_EQUAL(OUString("8.657"), aCategories[3]); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf134111) { // tdf134111 : To check TextBreak value is true loadFromURL(u"docx/tdf134111.docx"); uno::Reference xChartDoc = getChartDocFromWriter(0); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); uno::Reference mxDiagram(xChartDoc->getDiagram()); CPPUNIT_ASSERT(mxDiagram.is()); uno::Reference xAxisXSupp(mxDiagram, uno::UNO_QUERY); CPPUNIT_ASSERT(xAxisXSupp.is()); uno::Reference xAxisProp(xAxisXSupp->getXAxis()); bool bTextBreak = false; xAxisProp->getPropertyValue("TextBreak") >>= bTextBreak; // Expected value of 'TextBreak' is true CPPUNIT_ASSERT(bTextBreak); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf136752) { loadFromURL(u"xlsx/tdf136752.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataPointLabel( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=0"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel.is()); // Check the position of the 1st data point label, which is out from the pie slice awt::Point aLabelPosition = xDataPointLabel->getPosition(); CPPUNIT_ASSERT_DOUBLES_EQUAL(8675, aLabelPosition.X, 500); CPPUNIT_ASSERT_DOUBLES_EQUAL(1458, aLabelPosition.Y, 500); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf137505) { loadFromURL(u"xlsx/tdf137505.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xCustomShape(xDrawPage->getByIndex(1), UNO_QUERY_THROW); CPPUNIT_ASSERT(xCustomShape.is()); float nFontSize; Reference xRange(xCustomShape, uno::UNO_QUERY_THROW); Reference xAt = xRange->createTextCursor(); Reference xProps(xAt, UNO_QUERY); // check the text size of custom shape, inside the chart. CPPUNIT_ASSERT(xProps->getPropertyValue("CharHeight") >>= nFontSize); CPPUNIT_ASSERT_EQUAL(float(12), nFontSize); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf137734) { loadFromURL(u"xlsx/tdf137734.xlsx"); Reference xChartDoc = getChartDocFromSheet(0, mxComponent); CPPUNIT_ASSERT_MESSAGE("failed to load chart", xChartDoc.is()); CPPUNIT_ASSERT(xChartDoc.is()); Reference xDataSeries = getDataSeriesFromDoc(xChartDoc, 0); CPPUNIT_ASSERT(xDataSeries.is()); Reference xPropSet(xDataSeries, uno::UNO_QUERY_THROW); uno::Any aAny = xPropSet->getPropertyValue("VaryColorsByPoint"); bool bVaryColor = true; CPPUNIT_ASSERT(aAny >>= bVaryColor); CPPUNIT_ASSERT(!bVaryColor); // tdf#126133 Test primary X axis Rotation value Reference xXAxis = getAxisFromDoc(xChartDoc, 0, 0, 0); CPPUNIT_ASSERT(xXAxis.is()); Reference xTitled(xXAxis, uno::UNO_QUERY_THROW); Reference xTitle = xTitled->getTitleObject(); CPPUNIT_ASSERT(xTitle.is()); Reference xTitlePropSet(xTitle, uno::UNO_QUERY_THROW); uno::Any aAny2 = xTitlePropSet->getPropertyValue("TextRotation"); double nRotation = -1; CPPUNIT_ASSERT(aAny2 >>= nRotation); CPPUNIT_ASSERT_EQUAL(0.0, nRotation); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf137874) { loadFromURL(u"xlsx/piechart_legend.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xLegendEntry; xLegendEntry = getShapeByName(xShapes, "CID/MultiClick/D=0:CS=0:CT=0:Series=0:Point=0:LegendEntry=0"); CPPUNIT_ASSERT(xLegendEntry.is()); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf146463) { loadFromURL(u"ods/tdf146463.ods"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent)); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xChartType = getChartTypeFromDoc(xChartDoc, 0); std::vector> aDataSeriesYValues = getDataSeriesYValuesFromChartType(xChartType); size_t nLegendEntryCount = aDataSeriesYValues.size(); CPPUNIT_ASSERT_EQUAL(size_t(14), nLegendEntryCount); for (size_t nSeriesIndex = 0; nSeriesIndex < nLegendEntryCount; ++nSeriesIndex) { uno::Reference xLegendEntry = getShapeByName(xShapes, "CID/MultiClick/D=0:CS=0:CT=0:Series=" + OUString::number(nSeriesIndex) + ":LegendEntry=0"); if (nSeriesIndex == 0) CPPUNIT_ASSERT_MESSAGE("Legend 0 is not visible", xLegendEntry.is()); else CPPUNIT_ASSERT_MESSAGE( OString("Legend " + OString::number(nSeriesIndex) + " is visible").getStr(), !xLegendEntry.is()); } } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdfCustomShapePos) { loadFromURL(u"docx/testcustomshapepos.docx"); Reference xChartDoc(getChartDocFromWriter(0), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); // test position and size of a custom shape within a chart, rotated by 0 degree. { Reference xCustomShape(xDrawPage->getByIndex(0), UNO_QUERY_THROW); awt::Point aPosition = xCustomShape->getPosition(); CPPUNIT_ASSERT_DOUBLES_EQUAL(8845, aPosition.X, 300); CPPUNIT_ASSERT_DOUBLES_EQUAL(855, aPosition.Y, 300); awt::Size aSize = xCustomShape->getSize(); CPPUNIT_ASSERT_DOUBLES_EQUAL(4831, aSize.Width, 300); CPPUNIT_ASSERT_DOUBLES_EQUAL(1550, aSize.Height, 300); } // test position and size of a custom shape within a chart, rotated by 90 degree. { Reference xCustomShape(xDrawPage->getByIndex(1), UNO_QUERY_THROW); awt::Point aPosition = xCustomShape->getPosition(); CPPUNIT_ASSERT_DOUBLES_EQUAL(1658, aPosition.X, 300); CPPUNIT_ASSERT_DOUBLES_EQUAL(6119, aPosition.Y, 300); awt::Size aSize = xCustomShape->getSize(); CPPUNIT_ASSERT_DOUBLES_EQUAL(4165, aSize.Width, 300); CPPUNIT_ASSERT_DOUBLES_EQUAL(1334, aSize.Height, 300); } } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf121281) { loadFromURL(u"xlsx/incorrect_label_position.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataPointLabel( getShapeByName(xShapes, "CID/MultiClick/CID/D=0:CS=0:CT=0:Series=0:DataLabels=:DataLabel=0"), UNO_SET_THROW); CPPUNIT_ASSERT(xDataPointLabel.is()); awt::Point aLabelPosition = xDataPointLabel->getPosition(); // This failed, if the data label flowed out of the chart area. CPPUNIT_ASSERT_GREATEREQUAL(static_cast(0), aLabelPosition.Y); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf139658) { loadFromURL(u"docx/tdf139658.docx"); uno::Reference xChartDoc(getChartDocFromWriter(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xChartDoc.is()); Reference xInternalProvider(xChartDoc->getDataProvider(), uno::UNO_QUERY); CPPUNIT_ASSERT(xInternalProvider.is()); Reference xDescAccess(xInternalProvider, uno::UNO_QUERY); CPPUNIT_ASSERT(xDescAccess.is()); // Get the category labels. Sequence aCategories = xDescAccess->getRowDescriptions(); CPPUNIT_ASSERT_EQUAL(sal_Int32(3), aCategories.getLength()); CPPUNIT_ASSERT_EQUAL(OUString("category1"), aCategories[0]); CPPUNIT_ASSERT_EQUAL(OUString("\"category2\""), aCategories[1]); CPPUNIT_ASSERT_EQUAL(OUString("category\"3"), aCategories[2]); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf146066) { loadFromURL(u"ods/tdf146066.ods"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); uno::Reference xDrawPageSupplier(xChartDoc, uno::UNO_QUERY); uno::Reference xDrawPage = xDrawPageSupplier->getDrawPage(); uno::Reference xShapes(xDrawPage->getByIndex(0), uno::UNO_QUERY); CPPUNIT_ASSERT(xShapes.is()); uno::Reference xYAxisShape = getShapeByName( xShapes, "CID/D=0:CS=0:Axis=1,0", // Y Axis // Axis occurs twice in chart xshape representation so need to get the one related to labels [](const uno::Reference& rXShape) -> bool { uno::Reference xAxisShapes(rXShape, uno::UNO_QUERY); CPPUNIT_ASSERT(xAxisShapes.is()); uno::Reference xChildShape(xAxisShapes->getByIndex(0), uno::UNO_QUERY); uno::Reference xShapeDescriptor(xChildShape, uno::UNO_QUERY_THROW); return (xShapeDescriptor->getShapeType() == "com.sun.star.drawing.TextShape"); }); CPPUNIT_ASSERT(xYAxisShape.is()); // Check label count uno::Reference xIndexAccess(xYAxisShape, UNO_QUERY_THROW); CPPUNIT_ASSERT_EQUAL(static_cast(8), xIndexAccess->getCount()); // Check text uno::Reference xLabel0(xIndexAccess->getByIndex(0), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("0"), xLabel0->getString()); uno::Reference xLabel1(xIndexAccess->getByIndex(1), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("5"), xLabel1->getString()); uno::Reference xLabel2(xIndexAccess->getByIndex(2), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("10"), xLabel2->getString()); uno::Reference xLabel3(xIndexAccess->getByIndex(3), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("15"), xLabel3->getString()); uno::Reference xLabel4(xIndexAccess->getByIndex(4), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("20"), xLabel4->getString()); uno::Reference xLabel5(xIndexAccess->getByIndex(5), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("25"), xLabel5->getString()); uno::Reference xLabel6(xIndexAccess->getByIndex(6), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("30"), xLabel6->getString()); uno::Reference xLabel7(xIndexAccess->getByIndex(7), uno::UNO_QUERY); CPPUNIT_ASSERT_EQUAL(OUString("35"), xLabel7->getString()); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testTdf150434) { loadFromURL(u"xlsx/tdf150434.xlsx"); Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xLegend = getShapeByName(xShapes, "CID/D=0:Legend="); CPPUNIT_ASSERT(xLegend.is()); awt::Point aPosition = xLegend->getPosition(); // This failed, if the legend flowed out of the chart area. CPPUNIT_ASSERT_GREATEREQUAL(static_cast(0), aPosition.Y); } CPPUNIT_TEST_FIXTURE(Chart2ImportTest2, testChartDataTableWithMultipleLegendEntriesForOneDataSeries) { loadFromURL(u"xlsx/DataTable-MultipleLegendEntriesForOneDataSeries.xlsx"); // Loading this file caused a crash in the data table code Reference xChartDoc(getChartDocFromSheet(0, mxComponent), UNO_QUERY_THROW); Reference xDrawPageSupplier(xChartDoc, UNO_QUERY_THROW); Reference xDrawPage(xDrawPageSupplier->getDrawPage(), UNO_SET_THROW); Reference xShapes(xDrawPage->getByIndex(0), UNO_QUERY_THROW); Reference xDataTableShape = getShapeByName(xShapes, "CID/D=0:DataTable="); CPPUNIT_ASSERT(xDataTableShape.is()); } CPPUNIT_PLUGIN_IMPLEMENT(); /* vim:set shiftwidth=4 softtabstop=4 expandtab: */