diff options
author | Kohei Yoshida <kohei.yoshida@gmail.com> | 2012-04-27 21:03:46 -0400 |
---|---|---|
committer | Kohei Yoshida <kohei.yoshida@gmail.com> | 2012-04-28 00:24:49 -0400 |
commit | 9c9e0db4f0dd17843eae06c30730358a60b5ea8e (patch) | |
tree | 1872ca1cf7b97288aace164497b0fd2cafc9173e | |
parent | 8600f21b7d3c3656c1458aa440dbb330c08a7c7c (diff) |
Copy & paste the *_Cell test code into *_Header test code.
I still need to rewrite it to make it the header test.
Change-Id: I0f8c469d51340ae72cb61696a22ebcbdcf84ffa6
-rw-r--r-- | sc/CppunitTest_sc_editfieldobj_cell.mk (renamed from sc/CppunitTest_sc_editfieldobj.mk) | 22 | ||||
-rw-r--r-- | sc/CppunitTest_sc_editfieldobj_header.mk | 134 | ||||
-rw-r--r-- | sc/Module_sc.mk | 3 | ||||
-rw-r--r-- | sc/qa/extras/sceditfieldobj-header.cxx | 162 |
4 files changed, 309 insertions, 12 deletions
diff --git a/sc/CppunitTest_sc_editfieldobj.mk b/sc/CppunitTest_sc_editfieldobj_cell.mk index c14dc4d30c0c..70ca94ce7abb 100644 --- a/sc/CppunitTest_sc_editfieldobj.mk +++ b/sc/CppunitTest_sc_editfieldobj_cell.mk @@ -28,13 +28,13 @@ # instead of those above. #************************************************************************* -$(eval $(call gb_CppunitTest_CppunitTest,sc_editfieldobj)) +$(eval $(call gb_CppunitTest_CppunitTest,sc_editfieldobj_cell)) -$(eval $(call gb_CppunitTest_add_exception_objects,sc_editfieldobj, \ +$(eval $(call gb_CppunitTest_add_exception_objects,sc_editfieldobj_cell, \ sc/qa/extras/sceditfieldobj-cell \ )) -$(eval $(call gb_CppunitTest_use_libraries,sc_editfieldobj, \ +$(eval $(call gb_CppunitTest_use_libraries,sc_editfieldobj_cell, \ avmedia \ basegfx \ comphelper \ @@ -72,20 +72,20 @@ $(eval $(call gb_CppunitTest_use_libraries,sc_editfieldobj, \ $(gb_STDLIBS) \ )) -$(eval $(call gb_CppunitTest_set_include,sc_editfieldobj,\ +$(eval $(call gb_CppunitTest_set_include,sc_editfieldobj_cell,\ -I$(SRCDIR)/sc/source/ui/inc \ -I$(SRCDIR)/sc/inc \ $$(INCLUDE) \ )) -$(eval $(call gb_CppunitTest_use_api,sc_editfieldobj,\ +$(eval $(call gb_CppunitTest_use_api,sc_editfieldobj_cell,\ offapi \ udkapi \ )) -$(eval $(call gb_CppunitTest_use_ure,sc_editfieldobj)) +$(eval $(call gb_CppunitTest_use_ure,sc_editfieldobj_cell)) -$(eval $(call gb_CppunitTest_use_components,sc_editfieldobj,\ +$(eval $(call gb_CppunitTest_use_components,sc_editfieldobj_cell,\ basic/util/sb \ comphelper/util/comphelp \ configmgr/source/configmgr \ @@ -118,17 +118,17 @@ $(eval $(call gb_CppunitTest_use_components,sc_editfieldobj,\ unoxml/source/service/unoxml \ )) -$(eval $(call gb_CppunitTest_use_configuration,sc_editfieldobj)) +$(eval $(call gb_CppunitTest_use_configuration,sc_editfieldobj_cell)) -$(eval $(call gb_CppunitTest_use_filter_configuration,sc_editfieldobj)) +$(eval $(call gb_CppunitTest_use_filter_configuration,sc_editfieldobj_cell)) -$(eval $(call gb_CppunitTest_use_extra_configuration,sc_editfieldobj,\ +$(eval $(call gb_CppunitTest_use_extra_configuration,sc_editfieldobj_cell,\ $(OUTDIR)/unittest/registry \ )) # we need to # - explicitly depend on the sc resource files needed at unit-test runtime -$(call gb_CppunitTest_get_target,sc_editfieldobj) : \ +$(call gb_CppunitTest_get_target,sc_editfieldobj_cell) : \ $(WORKDIR)/AllLangRes/sc \ # vim: set noet sw=4 ts=4: diff --git a/sc/CppunitTest_sc_editfieldobj_header.mk b/sc/CppunitTest_sc_editfieldobj_header.mk new file mode 100644 index 000000000000..301c8f0c569f --- /dev/null +++ b/sc/CppunitTest_sc_editfieldobj_header.mk @@ -0,0 +1,134 @@ +# -*- 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 +# Kohei Yoshida <kohei.yoshida@suse.com> +# Portions created by the Initial Developer are Copyright (C) 2011 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,sc_editfieldobj_header)) + +$(eval $(call gb_CppunitTest_add_exception_objects,sc_editfieldobj_header, \ + sc/qa/extras/sceditfieldobj-header \ +)) + +$(eval $(call gb_CppunitTest_use_libraries,sc_editfieldobj_header, \ + avmedia \ + basegfx \ + comphelper \ + cppu \ + cppuhelper \ + drawinglayer \ + editeng \ + fileacc \ + for \ + forui \ + i18nisolang1 \ + msfilter \ + oox \ + sal \ + salhelper \ + sax \ + sb \ + sc \ + sfx \ + sot \ + svl \ + svt \ + svx \ + svxcore \ + test \ + tl \ + tk \ + subsequenttest \ + ucbhelper \ + unotest \ + utl \ + vbahelper \ + vcl \ + xo \ + $(gb_STDLIBS) \ +)) + +$(eval $(call gb_CppunitTest_set_include,sc_editfieldobj_header,\ + -I$(SRCDIR)/sc/source/ui/inc \ + -I$(SRCDIR)/sc/inc \ + $$(INCLUDE) \ +)) + +$(eval $(call gb_CppunitTest_use_api,sc_editfieldobj_header,\ + offapi \ + udkapi \ +)) + +$(eval $(call gb_CppunitTest_use_ure,sc_editfieldobj_header)) + +$(eval $(call gb_CppunitTest_use_components,sc_editfieldobj_header,\ + basic/util/sb \ + comphelper/util/comphelp \ + configmgr/source/configmgr \ + dbaccess/util/dba \ + fileaccess/source/fileacc \ + filter/source/config/cache/filterconfig1 \ + forms/util/frm \ + framework/util/fwk \ + i18npool/util/i18npool \ + oox/util/oox \ + package/source/xstor/xstor \ + package/util/package2 \ + sax/source/expatwrap/expwrap \ + sax/source/fastparser/fastsax \ + sc/util/sc \ + sc/util/scd \ + sc/util/scfilt \ + sc/util/vbaobj \ + scripting/source/basprov/basprov \ + scripting/util/scriptframe \ + sfx2/util/sfx \ + sot/util/sot \ + svl/source/fsstor/fsstorage \ + toolkit/util/tk \ + ucb/source/core/ucb1 \ + ucb/source/ucp/file/ucpfile1 \ + ucb/source/ucp/tdoc/ucptdoc1 \ + unotools/util/utl \ + unoxml/source/rdf/unordf \ + unoxml/source/service/unoxml \ +)) + +$(eval $(call gb_CppunitTest_use_configuration,sc_editfieldobj_header)) + +$(eval $(call gb_CppunitTest_use_filter_configuration,sc_editfieldobj_header)) + +$(eval $(call gb_CppunitTest_use_extra_configuration,sc_editfieldobj_header,\ + $(OUTDIR)/unittest/registry \ +)) + +# we need to +# - explicitly depend on the sc resource files needed at unit-test runtime +$(call gb_CppunitTest_get_target,sc_editfieldobj_header) : \ + $(WORKDIR)/AllLangRes/sc \ + +# vim: set noet sw=4 ts=4: diff --git a/sc/Module_sc.mk b/sc/Module_sc.mk index 926ac33da6a8..4727d7413c77 100644 --- a/sc/Module_sc.mk +++ b/sc/Module_sc.mk @@ -64,7 +64,8 @@ $(eval $(call gb_Module_add_subsequentcheck_targets,sc,\ CppunitTest_sc_namedrangesobj \ CppunitTest_sc_tablesheetobj \ CppunitTest_sc_tablesheetsobj \ - CppunitTest_sc_editfieldobj \ + CppunitTest_sc_editfieldobj_cell \ + CppunitTest_sc_editfieldobj_header \ )) # vim: set noet sw=4 ts=4: diff --git a/sc/qa/extras/sceditfieldobj-header.cxx b/sc/qa/extras/sceditfieldobj-header.cxx new file mode 100644 index 000000000000..ab84b70e1a81 --- /dev/null +++ b/sc/qa/extras/sceditfieldobj-header.cxx @@ -0,0 +1,162 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * 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. + * + * Major Contributor(s): + * Copyright (C) 2012 Kohei Yoshida <kohei.yoshida@suse.com> + * + * All Rights Reserved. + * + * 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. + */ + +#include <test/unoapi_test.hxx> +#include <test/text/xtextfield.hxx> +#include <test/text/xtextcontent.hxx> + +#include <com/sun/star/beans/XPropertySet.hpp> +#include <com/sun/star/container/XEnumerationAccess.hpp> +#include <com/sun/star/text/XText.hpp> +#include <com/sun/star/text/XTextField.hpp> +#include <com/sun/star/text/XTextFieldsSupplier.hpp> +#include <com/sun/star/sheet/XSpreadsheetDocument.hpp> +#include <com/sun/star/sheet/XSpreadsheet.hpp> + +#define NUMBER_OF_TESTS 3 + +namespace sc_apitest { + +class ScEditFieldObj_Header : public UnoApiTest, apitest::XTextField, apitest::XTextContent +{ +public: + ScEditFieldObj_Header(); + + virtual void setUp(); + virtual void tearDown(); + virtual uno::Reference<uno::XInterface> init(); + virtual uno::Reference<text::XTextContent> getTextContent(); + virtual uno::Reference<text::XTextRange> getTextRange(); + virtual bool isAttachSupported() { return true; } + + CPPUNIT_TEST_SUITE(ScEditFieldObj_Header); + // XTextField + CPPUNIT_TEST(testGetPresentation); + // XTextContent + CPPUNIT_TEST(testGetAnchor); + CPPUNIT_TEST(testAttach); + CPPUNIT_TEST_SUITE_END(); + +private: + static sal_Int32 nTest; + static uno::Reference<lang::XComponent> mxComponent; + static uno::Reference<text::XTextField> mxField; +}; + +sal_Int32 ScEditFieldObj_Header::nTest = 0; +uno::Reference<lang::XComponent> ScEditFieldObj_Header::mxComponent; +uno::Reference<text::XTextField> ScEditFieldObj_Header::mxField; + +ScEditFieldObj_Header::ScEditFieldObj_Header() {} + +void ScEditFieldObj_Header::setUp() +{ + ++nTest; + UnoApiTest::setUp(); +} + +void ScEditFieldObj_Header::tearDown() +{ + if (nTest == NUMBER_OF_TESTS) + closeDocument(mxComponent); + + UnoApiTest::tearDown(); +} + +namespace { + +uno::Reference<text::XTextField> getNewField(const uno::Reference<lang::XMultiServiceFactory>& xSM) +{ + uno::Reference<text::XTextField> xField( + xSM->createInstance("com.sun.star.text.TextField.URL"), UNO_QUERY_THROW); + uno::Reference<beans::XPropertySet> xPropSet(xField, UNO_QUERY_THROW); + xPropSet->setPropertyValue("Representation", uno::makeAny(rtl::OUString("LibreOffice"))); + xPropSet->setPropertyValue("URL", uno::makeAny(rtl::OUString("http://www.libreoffice.org/"))); + return xField; +} + +} + +uno::Reference<uno::XInterface> ScEditFieldObj_Header::init() +{ + // Return a field that's already in the cell. + if (!mxField.is()) + { + if (!mxComponent.is()) + // Load an empty document. + mxComponent = loadFromDesktop("private:factory/scalc"); + + uno::Reference<lang::XMultiServiceFactory> xSM(mxComponent, UNO_QUERY_THROW); + + // Create a new URL field object, and populate it with name and URL. + mxField = getNewField(xSM); + + // Insert this field into a cell. + uno::Reference<sheet::XSpreadsheetDocument> xDoc(mxComponent, UNO_QUERY_THROW); + uno::Reference<container::XIndexAccess> xIA(xDoc->getSheets(), UNO_QUERY_THROW); + uno::Reference<sheet::XSpreadsheet> xSheet(xIA->getByIndex(0), UNO_QUERY_THROW); + // Use cell A1 for this. + uno::Reference<table::XCell> xCell = xSheet->getCellByPosition(0, 0); + uno::Reference<text::XText> xText(xCell, UNO_QUERY_THROW); + + uno::Reference<text::XTextCursor> xCursor = xText->createTextCursor(); + uno::Reference<text::XTextRange> xRange(xCursor, UNO_QUERY_THROW); + uno::Reference<text::XTextContent> xContent(mxField, UNO_QUERY_THROW); + xText->insertTextContent(xRange, xContent, sal_False); + } + return mxField; +} + +uno::Reference<text::XTextContent> ScEditFieldObj_Header::getTextContent() +{ + // Return a field object that's not yet inserted. + uno::Reference<lang::XMultiServiceFactory> xSM(mxComponent, UNO_QUERY_THROW); + return uno::Reference<text::XTextContent>(getNewField(xSM), UNO_QUERY_THROW); +} + +uno::Reference<text::XTextRange> ScEditFieldObj_Header::getTextRange() +{ + // Use cell A2 for this. + uno::Reference<sheet::XSpreadsheetDocument> xDoc(mxComponent, UNO_QUERY_THROW); + uno::Reference<container::XIndexAccess> xIA(xDoc->getSheets(), UNO_QUERY_THROW); + uno::Reference<sheet::XSpreadsheet> xSheet(xIA->getByIndex(0), UNO_QUERY_THROW); + uno::Reference<table::XCell> xCell = xSheet->getCellByPosition(0, 1); + uno::Reference<text::XText> xText(xCell, UNO_QUERY_THROW); + + uno::Reference<text::XTextCursor> xCursor = xText->createTextCursor(); + uno::Reference<text::XTextRange> xRange(xCursor, UNO_QUERY_THROW); + return xRange; +} + +CPPUNIT_TEST_SUITE_REGISTRATION(ScEditFieldObj_Header); + +CPPUNIT_PLUGIN_IMPLEMENT(); + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |