diff options
Diffstat (limited to 'sc')
-rw-r--r-- | sc/qa/extras/scpdfexport.cxx | 67 | ||||
-rw-r--r-- | sc/qa/extras/testdocuments/tdf120161.ods (renamed from sc/qa/uitest/data/tdf120161.ods) | bin | 8192 -> 8192 bytes | |||
-rwxr-xr-x | sc/qa/uitest/calc_tests/tdf120161.py | 79 |
3 files changed, 67 insertions, 79 deletions
diff --git a/sc/qa/extras/scpdfexport.cxx b/sc/qa/extras/scpdfexport.cxx index 7b9610061bdb..58a93df8268e 100644 --- a/sc/qa/extras/scpdfexport.cxx +++ b/sc/qa/extras/scpdfexport.cxx @@ -15,6 +15,7 @@ #include <com/sun/star/sheet/XSpreadsheet.hpp> #include <com/sun/star/table/XCellRange.hpp> #include <com/sun/star/view/XSelectionSupplier.hpp> +#include <comphelper/propertysequence.hxx> #include <test/bootstrapfixture.hxx> #include <unotools/tempfile.hxx> #include <unotest/macros_test.hxx> @@ -45,6 +46,8 @@ private: std::shared_ptr<utl::TempFile> exportToPDF(const uno::Reference<frame::XModel>& xModel, const ScRange& range); + std::shared_ptr<utl::TempFile> exportToPDFWithUnoCommands(const OUString& rRange); + static bool hasTextInPdf(const std::shared_ptr<utl::TempFile>& pPDFFile, const char* sText, bool& bFound); @@ -55,13 +58,17 @@ private: public: void testExportRange_Tdf120161(); void testExportFitToPage_Tdf103516(); + void testUnoCommands_Tdf120161(); CPPUNIT_TEST_SUITE(ScPDFExportTest); CPPUNIT_TEST(testExportRange_Tdf120161); CPPUNIT_TEST(testExportFitToPage_Tdf103516); + CPPUNIT_TEST(testUnoCommands_Tdf120161); CPPUNIT_TEST_SUITE_END(); }; +constexpr OUStringLiteral DATA_DIRECTORY = u"/sc/qa/extras/testdocuments/"; + void ScPDFExportTest::setUp() { test::BootstrapFixture::setUp(); @@ -201,6 +208,36 @@ ScPDFExportTest::exportToPDF(const uno::Reference<frame::XModel>& xModel, const return pTempFile; } +std::shared_ptr<utl::TempFile> ScPDFExportTest::exportToPDFWithUnoCommands(const OUString& rRange) +{ + // create temp file name + auto pTempFile = std::make_shared<utl::TempFile>(); + pTempFile->EnableKillingFile(); + OUString sFileURL = pTempFile->GetURL(); + // Note: under Windows path path should be with "/" delimiters instead of "\\" + // due to usage of INetURLObject() that converts "\\" to hexadecimal notation. + ::osl::FileBase::getFileURLFromSystemPath(sFileURL, sFileURL); + + uno::Sequence<beans::PropertyValue> aArgs + = comphelper::InitPropertySequence({ { "ToPoint", uno::makeAny(rRange) } }); + dispatchCommand(mxComponent, ".uno:GoToCell", aArgs); + + dispatchCommand(mxComponent, ".uno:DefinePrintArea", {}); + + uno::Sequence<beans::PropertyValue> aFilterData(comphelper::InitPropertySequence( + { { "ViewPDFAfterExport", uno::Any(true) }, { "Printing", uno::Any(sal_Int32(2)) } })); + + uno::Sequence<beans::PropertyValue> aDescriptor( + comphelper::InitPropertySequence({ { "FilterName", uno::Any(OUString("calc_pdf_Export")) }, + { "FilterData", uno::Any(aFilterData) }, + { "URL", uno::Any(sFileURL) } })); + + dispatchCommand(mxComponent, ".uno:ExportToPDF", aDescriptor); + + // return file object with generated PDF + return pTempFile; +} + void ScPDFExportTest::setFont(ScFieldEditEngine& rEE, sal_Int32 nStart, sal_Int32 nEnd, const OUString& rFontName) { @@ -358,6 +395,36 @@ void ScPDFExportTest::testExportFitToPage_Tdf103516() } } +void ScPDFExportTest::testUnoCommands_Tdf120161() +{ + mxComponent = loadFromDesktop(m_directories.getURLFromSrc(DATA_DIRECTORY) + "tdf120161.ods", + "com.sun.star.sheet.SpreadsheetDocument"); + + // A1:G1 + { + std::shared_ptr<utl::TempFile> pPDFFile = exportToPDFWithUnoCommands("A1:G1"); + bool bFound = false; + CPPUNIT_ASSERT(hasTextInPdf(pPDFFile, "DejaVuSans", bFound)); + CPPUNIT_ASSERT_EQUAL(false, bFound); + } + + // G1:H1 + { + std::shared_ptr<utl::TempFile> pPDFFile = exportToPDFWithUnoCommands("G1:H1"); + bool bFound = false; + CPPUNIT_ASSERT(hasTextInPdf(pPDFFile, "DejaVuSans", bFound)); + CPPUNIT_ASSERT_EQUAL(true, bFound); + } + + // H1:I1 + { + std::shared_ptr<utl::TempFile> pPDFFile = exportToPDFWithUnoCommands("H1:I1"); + bool bFound = false; + CPPUNIT_ASSERT(hasTextInPdf(pPDFFile, "DejaVuSans", bFound)); + CPPUNIT_ASSERT_EQUAL(true, bFound); + } +} + CPPUNIT_TEST_SUITE_REGISTRATION(ScPDFExportTest); CPPUNIT_PLUGIN_IMPLEMENT(); diff --git a/sc/qa/uitest/data/tdf120161.ods b/sc/qa/extras/testdocuments/tdf120161.ods Binary files differindex 4b2c6e3ce69c..4b2c6e3ce69c 100644 --- a/sc/qa/uitest/data/tdf120161.ods +++ b/sc/qa/extras/testdocuments/tdf120161.ods diff --git a/sc/qa/uitest/calc_tests/tdf120161.py b/sc/qa/uitest/calc_tests/tdf120161.py deleted file mode 100755 index a15384c1a0cc..000000000000 --- a/sc/qa/uitest/calc_tests/tdf120161.py +++ /dev/null @@ -1,79 +0,0 @@ -# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*- -# -# 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/. -# -from uitest.framework import UITestCase -from libreoffice.uno.propertyvalue import mkPropertyValues -import os -from tempfile import TemporaryDirectory -from uitest.uihelper.common import get_url_for_data_file - -# Bug 120161: PRINTING, PDF Export: Problem with selected cells which cross pages -class tdf120161(UITestCase): - def getFileContent(self, pathAndFileName): - with open(pathAndFileName, 'rb') as theFile: # b is important -> binary - # Return as binary string - data = theFile.read() - return data - - def verifyExportToFile(self, xDoc, xContext, xRange, xFontName, xFilename): - # set selection - xGridWin = xDoc.getChild("grid_window") - xGridWin.executeAction("SELECT", mkPropertyValues({"RANGE": xRange})) - - # set print area - self.xUITest.executeCommand(".uno:DefinePrintArea") - - # create temp file name - xURL = 'file:///' + xFilename - - # prepare to export into pdf - xServiceManager = xContext.ServiceManager - xDispatcher = xServiceManager.createInstanceWithContext( - 'com.sun.star.frame.DispatchHelper', xContext) - xDocFrame = self.ui_test.get_desktop().getCurrentFrame() - document = self.ui_test.get_component() - - # get selection - xSelection = document.Sheets.getByName("Sheet1").getCellRangeByName(xRange) - self.assertIsNotNone(xSelection) - - # run export into pdf - xFilterData = mkPropertyValues( - {'Selection': xSelection, 'ViewPDFAfterExport': True, 'Printing': '2'}) - xParams = mkPropertyValues( - {'URL': xURL, 'FilterName': 'calc_pdf_Export', 'FilterData': xFilterData}) - xDispatcher.executeDispatch(xDocFrame, '.uno:ExportToPDF', '', 0, xParams) - - # check resulting pdf file - xFileContent = self.getFileContent(xFilename) - position = xFileContent.find(xFontName) - return position > 0 - - # create temp directory and filename inside it - def verifyExport(self, xDoc, xContext, xRange, xFontName): - with TemporaryDirectory() as tempdir: - if os.altsep: # we need URL so replace "\" with "/" - tempdir = tempdir.replace(os.sep, os.altsep) - xFilename = tempdir + "/tdf120161-temp.pdf" - return self.verifyExportToFile(xDoc, xContext, xRange, xFontName, xFilename) - return False - - def test_tdf120161(self): - calc_doc = self.ui_test.load_file(get_url_for_data_file("tdf120161.ods")) - xDoc = self.xUITest.getTopFocusWindow() - xContext = self.xContext - - # check different areas to be printed without any lost cell - # note: - # 1. Visually in GridView G1 is on page-1 and H1 is on page-2 - # 2. DejaVuSans is used only in H1 - self.assertFalse(self.verifyExport(xDoc, xContext, "A1:G1", b"DejaVuSans")) - self.assertTrue(self.verifyExport(xDoc, xContext, "H1:I1", b"DejaVuSans")) - self.assertTrue(self.verifyExport(xDoc, xContext, "G1:H1", b"DejaVuSans")) - - self.ui_test.close_doc() - -# vim: set shiftwidth=4 softtabstop=4 expandtab: |