diff options
author | anfanite396 <dipamt1729@gmail.com> | 2023-07-11 16:08:57 +0530 |
---|---|---|
committer | Tomaž Vajngerl <quikee@gmail.com> | 2023-07-14 03:13:20 +0200 |
commit | 979bdded307531f8b6a930a6515c675d9445de65 (patch) | |
tree | f85bb15a7c9ce6c2ee2255b9dd7c14b94e94aa72 /sw | |
parent | 0fa8010a07c6e6fd7d3506087a417bf84e948e16 (diff) |
Move SwXFieldEnumeration Java tests to C++
Change-Id: I6f1eb42e9284593bcc0db1934f3b14d090349d91
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/154298
Tested-by: Jenkins
Reviewed-by: Tomaž Vajngerl <quikee@gmail.com>
Diffstat (limited to 'sw')
-rw-r--r-- | sw/CppunitTest_sw_apitests.mk | 1 | ||||
-rw-r--r-- | sw/qa/api/SwXFieldEnumeration.cxx | 109 |
2 files changed, 110 insertions, 0 deletions
diff --git a/sw/CppunitTest_sw_apitests.mk b/sw/CppunitTest_sw_apitests.mk index c1d323dc5df1..7d44286f60cb 100644 --- a/sw/CppunitTest_sw_apitests.mk +++ b/sw/CppunitTest_sw_apitests.mk @@ -25,6 +25,7 @@ $(eval $(call gb_CppunitTest_add_exception_objects,sw_apitests, \ sw/qa/api/SwXDocumentIndexes \ sw/qa/api/SwXDocumentIndexMark \ sw/qa/api/SwXDocumentSettings \ + sw/qa/api/SwXFieldEnumeration \ sw/qa/api/SwXFootnote \ sw/qa/api/SwXFootnoteProperties \ sw/qa/api/SwXFootnoteText \ diff --git a/sw/qa/api/SwXFieldEnumeration.cxx b/sw/qa/api/SwXFieldEnumeration.cxx new file mode 100644 index 000000000000..53c437ed18d3 --- /dev/null +++ b/sw/qa/api/SwXFieldEnumeration.cxx @@ -0,0 +1,109 @@ +/* -*- 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 <test/unoapi_test.hxx> +#include <test/container/xenumeration.hxx> + +#include <com/sun/star/frame/Desktop.hpp> + +#include <com/sun/star/lang/XMultiServiceFactory.hpp> + +#include <com/sun/star/beans/XPropertySet.hpp> +#include <com/sun/star/text/XDependentTextField.hpp> +#include <com/sun/star/container/XEnumeration.hpp> +#include <com/sun/star/container/XEnumerationAccess.hpp> +#include <com/sun/star/text/XTextDocument.hpp> +#include <com/sun/star/text/XText.hpp> +#include <com/sun/star/text/XTextFieldsSupplier.hpp> + +using namespace css; +using namespace css::uno; + +namespace +{ +/** + * Initial tests for SwXFieldEnumeration. + */ +class SwXFieldEnumeration final : public UnoApiTest, public apitest::XEnumeration +{ +public: + SwXFieldEnumeration() + : UnoApiTest("") + { + } + + virtual void setUp() override + { + UnoApiTest::setUp(); + mxDesktop.set(frame::Desktop::create(mxComponentContext)); + mxComponent = loadFromDesktop("private:factory/swriter"); + CPPUNIT_ASSERT(mxComponent.is()); + } + + Reference<XInterface> init() override + { + Reference<text::XTextDocument> xTextDocument(mxComponent, UNO_QUERY_THROW); + Reference<lang::XMultiServiceFactory> xMSF(mxComponent, UNO_QUERY_THROW); + + Reference<beans::XPropertySet> xFieldMaster; + Reference<text::XDependentTextField> xTF; + + try + { + xFieldMaster = Reference<beans::XPropertySet>( + xMSF->createInstance("com.sun.star.text.FieldMaster.Database"), UNO_QUERY_THROW); + xTF = Reference<text::XDependentTextField>( + xMSF->createInstance("com.sun.star.text.TextField.Database"), UNO_QUERY_THROW); + } + catch (Exception&) + { + } + + try + { + xFieldMaster->setPropertyValue("DataBaseName", Any(OUString("Bibliography"))); + xFieldMaster->setPropertyValue("DataTableName", Any(OUString("biblio"))); + xFieldMaster->setPropertyValue("DataColumnName", Any(OUString("Address"))); + } + catch (lang::WrappedTargetException&) + { + } + catch (lang::IllegalArgumentException&) + { + } + catch (beans::UnknownPropertyException&) + { + } + catch (beans::PropertyVetoException&) + { + } + + Reference<text::XText> xText = xTextDocument->getText(); + Reference<text::XTextCursor> xCursor = xText->createTextCursor(); + Reference<text::XTextContent> xTextContent(xTF, UNO_QUERY_THROW); + + xTF->attachTextFieldMaster(xFieldMaster); + xText->insertTextContent(xCursor, xTextContent, false); + + Reference<text::XTextFieldsSupplier> xTFS(xTextDocument, UNO_QUERY_THROW); + Reference<container::XEnumerationAccess> xEnumerationAccess = xTFS->getTextFields(); + + return Reference<XInterface>(xEnumerationAccess->createEnumeration(), UNO_QUERY_THROW); + } + + CPPUNIT_TEST_SUITE(SwXFieldEnumeration); + CPPUNIT_TEST(testHasMoreElements); + CPPUNIT_TEST(testNextElement); + CPPUNIT_TEST_SUITE_END(); +}; + +CPPUNIT_TEST_SUITE_REGISTRATION(SwXFieldEnumeration); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |