diff options
author | Miklos Vajna <vmiklos@suse.cz> | 2012-04-15 20:02:30 +0200 |
---|---|---|
committer | Miklos Vajna <vmiklos@suse.cz> | 2012-04-15 20:05:08 +0200 |
commit | fd2cb15bad245aeed3b18d6ad0711f2e9be6ff98 (patch) | |
tree | 28b4e1ba971120b01d371b832425fa6a7b0d09f0 /sw | |
parent | edcf5270f0a4d6ef59fe914e41e25df494ceca54 (diff) |
sw: also test RTF export of zoom level
Diffstat (limited to 'sw')
-rw-r--r-- | sw/CppunitTest_sw_subsequent_rtfexport.mk | 82 | ||||
-rw-r--r-- | sw/Module_sw.mk | 1 | ||||
-rw-r--r-- | sw/qa/extras/rtfexport/data/zoom.rtf (renamed from sw/qa/extras/rtftok/data/zoom.rtf) | 0 | ||||
-rw-r--r-- | sw/qa/extras/rtfexport/rtfexport.cxx | 104 | ||||
-rw-r--r-- | sw/qa/extras/rtftok/rtftok.cxx | 15 |
5 files changed, 187 insertions, 15 deletions
diff --git a/sw/CppunitTest_sw_subsequent_rtfexport.mk b/sw/CppunitTest_sw_subsequent_rtfexport.mk new file mode 100644 index 000000000000..f763e5d6bd31 --- /dev/null +++ b/sw/CppunitTest_sw_subsequent_rtfexport.mk @@ -0,0 +1,82 @@ +# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*- +#************************************************************************* +# Version: MPL 1.1 / GPLv3+ / LGPLv3+ +# +# The contents of this file are subject to the Mozilla Public License Version +# 1.1 (the "License"); you may not use this file except in compliance with +# the License or as specified alternatively below. You may obtain a copy of +# the License at http://www.mozilla.org/MPL/ +# +# Software distributed under the License is distributed on an "AS IS" basis, +# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License +# for the specific language governing rights and limitations under the +# License. +# +# The Initial Developer of the Original Code is +# Miklos Vajna <vmiklos@suse.cz> (SUSE, Inc.) +# Portions created by the Initial Developer are Copyright (C) 2012 the +# Initial Developer. All Rights Reserved. +# +# Major Contributor(s): +# +# For minor contributions see the git repository. +# +# Alternatively, the contents of this file may be used under the terms of +# either the GNU General Public License Version 3 or later (the "GPLv3+"), or +# the GNU Lesser General Public License Version 3 or later (the "LGPLv3+"), +# in which case the provisions of the GPLv3+ or the LGPLv3+ are applicable +# instead of those above. +#************************************************************************* + +$(eval $(call gb_CppunitTest_CppunitTest,sw_subsequent_rtfexport)) + +$(eval $(call gb_CppunitTest_add_exception_objects,sw_subsequent_rtfexport, \ + sw/qa/extras/rtfexport/rtfexport \ +)) + +$(eval $(call gb_CppunitTest_use_libraries,sw_subsequent_rtfexport, \ + cppu \ + sal \ + test \ + unotest \ + utl \ + tl \ + $(gb_STDLIBS) \ +)) + +$(eval $(call gb_CppunitTest_use_api,sw_subsequent_rtfexport,\ + offapi \ + udkapi \ +)) + +$(eval $(call gb_CppunitTest_use_ure,sw_subsequent_rtfexport)) + +$(eval $(call gb_CppunitTest_use_components,sw_subsequent_rtfexport,\ + comphelper/util/comphelp \ + configmgr/source/configmgr \ + fileaccess/source/fileacc \ + filter/source/config/cache/filterconfig1 \ + framework/util/fwk \ + i18npool/util/i18npool \ + package/util/package2 \ + sfx2/util/sfx \ + svl/source/fsstor/fsstorage \ + sw/util/msword \ + sw/util/sw \ + sw/util/swd \ + toolkit/util/tk \ + ucb/source/core/ucb1 \ + ucb/source/ucp/file/ucpfile1 \ + unoxml/source/service/unoxml \ + writerfilter/util/writerfilter \ +)) + +$(eval $(call gb_CppunitTest_use_configuration,sw_subsequent_rtfexport)) + +$(eval $(call gb_CppunitTest_use_filter_configuration,sw_subsequent_rtfexport)) + +$(eval $(call gb_CppunitTest_use_extra_configuration,sw_subsequent_rtfexport,\ + $(OUTDIR)/unittest/registry \ +)) + +# vim: set noet sw=4 ts=4: diff --git a/sw/Module_sw.mk b/sw/Module_sw.mk index d5f1e06b0c7a..de2bd90a9dcf 100644 --- a/sw/Module_sw.mk +++ b/sw/Module_sw.mk @@ -55,6 +55,7 @@ $(eval $(call gb_Module_add_slowcheck_targets,sw,\ CppunitTest_sw_filters_test \ CppunitTest_sw_macros_test \ CppunitTest_sw_subsequent_ooxmltok \ + CppunitTest_sw_subsequent_rtfexport \ CppunitTest_sw_subsequent_rtftok \ )) diff --git a/sw/qa/extras/rtftok/data/zoom.rtf b/sw/qa/extras/rtfexport/data/zoom.rtf index c7fd19b20b33..c7fd19b20b33 100644 --- a/sw/qa/extras/rtftok/data/zoom.rtf +++ b/sw/qa/extras/rtfexport/data/zoom.rtf diff --git a/sw/qa/extras/rtfexport/rtfexport.cxx b/sw/qa/extras/rtfexport/rtfexport.cxx new file mode 100644 index 000000000000..642544d8f828 --- /dev/null +++ b/sw/qa/extras/rtfexport/rtfexport.cxx @@ -0,0 +1,104 @@ +/* + * Version: MPL 1.1 / GPLv3+ / LGPLv3+ + * + * The contents of this file are subject to the Mozilla Public License Version + * 1.1 (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" basis, + * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License + * for the specific language governing rights and limitations under the + * License. + * + * The Initial Developer of the Original Code is + * Miklos Vajna <vmiklos@suse.cz> (SUSE, Inc.) + * Portions created by the Initial Developer are Copyright (C) 2012 the + * Initial Developer. All Rights Reserved. + * + * Contributor(s): + * + * Alternatively, the contents of this file may be used under the terms of + * either the GNU General Public License Version 3 or later (the "GPLv3+"), or + * the GNU Lesser General Public License Version 3 or later (the "LGPLv3+"), + * in which case the provisions of the GPLv3+ or the LGPLv3+ are applicable + * instead of those above. + */ + +#include <com/sun/star/frame/XStorable.hpp> +#include <com/sun/star/view/XViewSettingsSupplier.hpp> + +#include <test/bootstrapfixture.hxx> +#include <unotest/macros_test.hxx> +#include <unotools/tempfile.hxx> +#include <vcl/svapp.hxx> + +using rtl::OString; +using rtl::OUString; +using rtl::OUStringBuffer; +using namespace com::sun::star; + +class RtfExportTest : public test::BootstrapFixture, public unotest::MacrosTest +{ +public: + virtual void setUp(); + virtual void tearDown(); + void testZoom(); + + CPPUNIT_TEST_SUITE(RtfExportTest); +#if !defined(MACOSX) && !defined(WNT) + CPPUNIT_TEST(testZoom); +#endif + CPPUNIT_TEST_SUITE_END(); + +private: + void roundtrip(const OUString& rURL); + uno::Reference<lang::XComponent> mxComponent; +}; + +void RtfExportTest::roundtrip(const OUString& rFilename) +{ + uno::Reference<lang::XComponent> xImported = loadFromDesktop(getURLFromSrc("/sw/qa/extras/rtfexport/data/") + rFilename); + uno::Reference<frame::XStorable> xStorable(xImported, uno::UNO_QUERY); + uno::Sequence<beans::PropertyValue> aArgs(1); + aArgs[0].Name = "FilterName"; + aArgs[0].Value <<= OUString("Rich Text Format"); + utl::TempFile aTempFile; + aTempFile.EnableKillingFile(); + xStorable->storeToURL(aTempFile.GetURL(), aArgs); + mxComponent = loadFromDesktop(aTempFile.GetURL()); +} + +void RtfExportTest::setUp() +{ + test::BootstrapFixture::setUp(); + + mxDesktop.set(getMultiServiceFactory()->createInstance("com.sun.star.frame.Desktop"), uno::UNO_QUERY); + CPPUNIT_ASSERT(mxDesktop.is()); +} + +void RtfExportTest::tearDown() +{ + if (mxComponent.is()) + mxComponent->dispose(); + + test::BootstrapFixture::tearDown(); +} + +void RtfExportTest::testZoom() +{ + roundtrip("zoom.rtf"); + + uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY); + uno::Reference<view::XViewSettingsSupplier> xViewSettingsSupplier(xModel->getCurrentController(), uno::UNO_QUERY); + uno::Reference<beans::XPropertySet> xPropertySet(xViewSettingsSupplier->getViewSettings()); + sal_Int16 nValue = 0; + xPropertySet->getPropertyValue("ZoomValue") >>= nValue; + CPPUNIT_ASSERT_EQUAL(sal_Int16(42), nValue); +} + +CPPUNIT_TEST_SUITE_REGISTRATION(RtfExportTest); + +CPPUNIT_PLUGIN_IMPLEMENT(); + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/qa/extras/rtftok/rtftok.cxx b/sw/qa/extras/rtftok/rtftok.cxx index 2b5146a16ad0..fad769cfaef7 100644 --- a/sw/qa/extras/rtftok/rtftok.cxx +++ b/sw/qa/extras/rtftok/rtftok.cxx @@ -42,7 +42,6 @@ #include <com/sun/star/text/XTextFramesSupplier.hpp> #include <com/sun/star/text/XTextTablesSupplier.hpp> #include <com/sun/star/text/XTextViewCursorSupplier.hpp> -#include <com/sun/star/view/XViewSettingsSupplier.hpp> #include <rtl/oustringostreaminserter.hxx> #include <test/bootstrapfixture.hxx> @@ -81,7 +80,6 @@ public: void testFdo47107(); void testFdo45182(); void testFdo44176(); - void testZoom(); void testFdo39053(); CPPUNIT_TEST_SUITE(RtfModelTest); @@ -105,7 +103,6 @@ public: CPPUNIT_TEST(testFdo47107); CPPUNIT_TEST(testFdo45182); CPPUNIT_TEST(testFdo44176); - CPPUNIT_TEST(testZoom); CPPUNIT_TEST(testFdo39053); #endif CPPUNIT_TEST_SUITE_END(); @@ -538,18 +535,6 @@ void RtfModelTest::testFdo44176() CPPUNIT_ASSERT_EQUAL(nFirstTop, nDefaultTop + nDefaultHeader); } -void RtfModelTest::testZoom() -{ - load("zoom.rtf"); - - uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY); - uno::Reference<view::XViewSettingsSupplier> xViewSettingsSupplier(xModel->getCurrentController(), uno::UNO_QUERY); - uno::Reference<beans::XPropertySet> xPropertySet(xViewSettingsSupplier->getViewSettings()); - sal_Int16 nValue = 0; - xPropertySet->getPropertyValue("ZoomValue") >>= nValue; - CPPUNIT_ASSERT_EQUAL(sal_Int16(42), nValue); -} - void RtfModelTest::testFdo39053() { load("fdo39053.rtf"); |