From 1a56bf9536c28ff277a6f60f358f528d0b9da025 Mon Sep 17 00:00:00 2001 From: Markus Mohrhard Date: Thu, 26 Apr 2012 16:22:03 +0200 Subject: add test for XTextContent --- test/Library_subsequenttest.mk | 1 + test/Package_inc.mk | 1 + test/inc/test/text/xtextcontent.hxx | 55 ++++++++++++++++++++++++++ test/source/text/xtextcontent.cxx | 78 +++++++++++++++++++++++++++++++++++++ 4 files changed, 135 insertions(+) create mode 100644 test/inc/test/text/xtextcontent.hxx create mode 100644 test/source/text/xtextcontent.cxx (limited to 'test') diff --git a/test/Library_subsequenttest.mk b/test/Library_subsequenttest.mk index 26bbeb5c2acf..a7c5e415b32f 100644 --- a/test/Library_subsequenttest.mk +++ b/test/Library_subsequenttest.mk @@ -83,6 +83,7 @@ $(eval $(call gb_Library_add_exception_objects,subsequenttest,\ test/source/sheet/xspreadsheetdocument \ test/source/sheet/xspreadsheets2 \ test/source/text/xtextfield \ + test/source/text/xtextcontent \ test/source/util/xreplaceable \ test/source/util/xsearchable \ )) diff --git a/test/Package_inc.mk b/test/Package_inc.mk index c44a695a847c..1bf786180cbf 100644 --- a/test/Package_inc.mk +++ b/test/Package_inc.mk @@ -50,6 +50,7 @@ $(eval $(call gb_Package_add_file,test_inc,inc/test/sheet/xprintareas.hxx,test/s $(eval $(call gb_Package_add_file,test_inc,inc/test/sheet/xspreadsheetdocument.hxx,test/sheet/xspreadsheetdocument.hxx)) $(eval $(call gb_Package_add_file,test_inc,inc/test/sheet/xspreadsheets2.hxx,test/sheet/xspreadsheets2.hxx)) $(eval $(call gb_Package_add_file,test_inc,inc/test/text/xtextfield.hxx,test/text/xtextfield.hxx)) +$(eval $(call gb_Package_add_file,test_inc,inc/test/text/xtextcontent.hxx,test/text/xtextcontent.hxx)) $(eval $(call gb_Package_add_file,test_inc,inc/test/util/xreplaceable.hxx,test/util/xreplaceable.hxx)) $(eval $(call gb_Package_add_file,test_inc,inc/test/util/xsearchable.hxx,test/util/xsearchable.hxx)) diff --git a/test/inc/test/text/xtextcontent.hxx b/test/inc/test/text/xtextcontent.hxx new file mode 100644 index 000000000000..600984981eee --- /dev/null +++ b/test/inc/test/text/xtextcontent.hxx @@ -0,0 +1,55 @@ +/* -*- 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 Markus Mohrhard (initial developer) + * + * 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 +#include +#include + +using namespace com::sun::star; + +namespace apitest { + +class XTextContent +{ +public: + virtual ~XTextContent() {} + + virtual uno::Reference< uno::XInterface > init() = 0; + virtual uno::Reference< text::XTextRange > getTextRange() = 0; + virtual uno::Reference< text::XTextContent > getTextContent() = 0; + virtual bool isAttachSupported() = 0; + + void testGetAnchor(); + void testAttach(); + + +}; + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/test/source/text/xtextcontent.cxx b/test/source/text/xtextcontent.cxx new file mode 100644 index 000000000000..c6662e7cf687 --- /dev/null +++ b/test/source/text/xtextcontent.cxx @@ -0,0 +1,78 @@ +/* -*- 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 Markus Mohrhard (initial developer) + * + * 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/text/xtextcontent.hxx" +#include +#include +#include +#include "cppunit/extensions/HelperMacros.h" + +using namespace com::sun::star::uno; + +namespace apitest { + +void XTextContent::testGetAnchor() +{ + uno::Reference< text::XTextContent > xTextContent(init(), UNO_QUERY_THROW); + uno::Reference< uno::XInterface > xAnchor = xTextContent->getAnchor(); + CPPUNIT_ASSERT(xAnchor.is()); +} + +void XTextContent::testAttach() +{ + uno::Reference< text::XTextContent > xTextContent(init(), UNO_QUERY_THROW); + uno::Reference< text::XTextRange > xAnchor = xTextContent->getAnchor(); + + uno::Reference< text::XTextContent > xContent(getTextContent(), UNO_QUERY_THROW); + uno::Reference< text::XTextRange > xRange(getTextRange(), UNO_QUERY_THROW); + + try + { + if (xContent.is()) + xContent->attach(xRange); + else + xTextContent->attach(xRange); + } + catch (const lang::IllegalArgumentException& e) + { + bool bAttachSupported = isAttachSupported(); + if (bAttachSupported) + CPPUNIT_ASSERT(false); + + } + catch (const RuntimeException& e) + { + bool bAttachSupported = isAttachSupported(); + if (bAttachSupported) + CPPUNIT_ASSERT(false); + } +} + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ -- cgit