diff options
author | Caolán McNamara <caolanm@redhat.com> | 2010-11-09 15:28:50 +0000 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2010-11-09 15:28:50 +0000 |
commit | 4ba60ec9b47c6575d8a16d1deef98b0401d01f5c (patch) | |
tree | 95fa63121bc8f5335016a67b1901a8836c1cfd20 /starmath/qa | |
parent | 3bcdc0147893be9fd468f16c3823e1d22f0bc6fd (diff) |
cppunit equivalent to tmEditUndoRedo of testAutomation
Diffstat (limited to 'starmath/qa')
-rw-r--r-- | starmath/qa/cppunit/makefile.mk | 141 | ||||
-rw-r--r-- | starmath/qa/cppunit/test_starmath.cxx | 138 | ||||
-rw-r--r-- | starmath/qa/cppunit/version.map | 34 |
3 files changed, 313 insertions, 0 deletions
diff --git a/starmath/qa/cppunit/makefile.mk b/starmath/qa/cppunit/makefile.mk new file mode 100644 index 000000000000..7bdc6c87059e --- /dev/null +++ b/starmath/qa/cppunit/makefile.mk @@ -0,0 +1,141 @@ +#************************************************************************* +# +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# Copyright 2000, 2010 Oracle and/or its affiliates. +# +# OpenOffice.org - a multi-platform office productivity suite +# +# This file is part of OpenOffice.org. +# +# OpenOffice.org is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License version 3 +# only, as published by the Free Software Foundation. +# +# OpenOffice.org is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License version 3 for more details +# (a copy is included in the LICENSE file that accompanied this code). +# +# You should have received a copy of the GNU Lesser General Public License +# version 3 along with OpenOffice.org. If not, see +# <http://www.openoffice.org/license.html> +# for a copy of the LGPLv3 License. +# +#************************************************************************* + +PRJ=../.. +PRJNAME=starmath +TARGET=qa_cppunit + +ENABLE_EXCEPTIONS=TRUE + +# --- Settings ----------------------------------------------------- + +.INCLUDE : settings.mk + +#building with stlport, but cppunit was not built with stlport +.IF "$(USE_SYSTEM_STL)"!="YES" +.IF "$(SYSTEM_CPPUNIT)"=="YES" +CFLAGSCXX+=-DADAPT_EXT_STL +.ENDIF +.ENDIF + +CFLAGSCXX += $(CPPUNIT_CFLAGS) + +# --- Libs --------------------------------------------------------- + +SHL1OBJS= \ + $(SLO)/test_starmath.obj \ + + +SHL1STDLIBS= \ + $(CPPUNITLIB) \ + $(EDITENGLIB) \ + $(SVXCORELIB) \ + $(SVXLIB) \ + $(SFX2LIB) \ + $(XMLOFFLIB) \ + $(SVTOOLLIB) \ + $(TKLIB) \ + $(VCLLIB) \ + $(SVLLIB) \ + $(I18NPAPERLIB) \ + $(SOTLIB) \ + $(UNOTOOLSLIB) \ + $(TOOLSLIB) \ + $(COMPHELPERLIB) \ + $(CPPUHELPERLIB) \ + $(CPPULIB) \ + $(SALLIB) + +SHL1LIBS=$(SLB)$/starmath.lib + +SHL1TARGET= test_starmath +SHL1RPATH = NONE +SHL1IMPLIB= i$(SHL1TARGET) +# SHL1DEF= $(MISC)/$(SHL1TARGET).def +DEF1NAME=$(SHL1TARGET) +# DEF1EXPORTFILE= export.exp +SHL1VERSIONMAP= version.map + +# --- All object files --------------------------------------------- + +SLOFILES= \ + $(SHL1OBJS) \ + + +# --- Targets ------------------------------------------------------ + +.INCLUDE : target.mk + +.IF "$(OS)" == "WNT" +my_file = file:/// +.ELSE +my_file = file:// +.END + +ALLTAR: test + +$(MISC)$/$(TARGET)$/types.rdb .ERRREMOVE : $(SOLARBINDIR)$/types.rdb + $(MKDIRHIER) $(@:d) + $(GNUCOPY) $? $@ + +$(MISC)/$(TARGET)/udkapi.rdb .ERRREMOVE : $(SOLARBINDIR)$/udkapi.rdb + $(MKDIRHIER) $(@:d) + $(GNUCOPY) $? $@ + +#Make a services.rdb with the services we know we need to get up and running +$(MISC)/$(TARGET)/services.rdb .ERRREMOVE : $(MISC)/$(TARGET)/udkapi.rdb + $(MKDIRHIER) $(@:d) + $(REGCOMP) -register -br $(MISC)/$(TARGET)/udkapi.rdb -r $@ -wop \ + -c $(DLLPRE)fwk$(DLLPOSTFIX)$(DLLPOST) \ + -c i18npool.uno$(DLLPOST) + +#Tweak things to that we use the .res files in the solver +STAR_RESOURCEPATH:=$(PWD)/$(BIN):$(SOLARBINDIR) +.EXPORT : STAR_RESOURCEPATH + +.IF "$(OS)" == "LINUX" + +test .PHONY: $(SHL1TARGETN) $(MISC)/$(TARGET)/services.rdb $(MISC)$/$(TARGET)$/types.rdb $(MISC)/$(TARGET)/udkapi.rdb + @echo ---------------------------------------------------------- + @echo - start unit test \#1 on library $(SHL1TARGETN) + @echo ---------------------------------------------------------- + $(CPPUNITTESTER) $(SHL1TARGETN) -headless -invisible \ + -env:UNO_SERVICES=$(my_file)$(PWD)/$(MISC)/$(TARGET)/services.rdb \ + -env:UNO_TYPES="$(my_file)$(PWD)/$(MISC)/$(TARGET)/types.rdb $(my_file)$(PWD)/$(MISC)/$(TARGET)/udkapi.rdb" \ + -env:OOO_BASE_DIR="$(my_file)$(PWD)/$(MISC)/$(TARGET)" \ + -env:BRAND_BASE_DIR="$(my_file)$(PWD)/$(MISC)/$(TARGET)" \ + -env:UNO_USER_PACKAGES_CACHE="$(my_file)$(PWD)/$(MISC)/$(TARGET)" + +.ELSE + +test .PHONY: $(SHL1TARGETN) + @echo ---------------------------------------------------------- + @echo - WARNING!!, test disabled on your platform + @echo - Please test manually, and enable if it works + @echo ---------------------------------------------------------- + +.ENDIF diff --git a/starmath/qa/cppunit/test_starmath.cxx b/starmath/qa/cppunit/test_starmath.cxx new file mode 100644 index 000000000000..5899fd18eaa2 --- /dev/null +++ b/starmath/qa/cppunit/test_starmath.cxx @@ -0,0 +1,138 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_starmath.hxx" + +#include "sal/config.h" + +#include <cppuhelper/bootstrap.hxx> +#include <comphelper/processfactory.hxx> + +#include <vcl/svapp.hxx> +#include <smdll.hxx> +#include <document.hxx> + +#include <sfx2/bindings.hxx> +#include <sfx2/request.hxx> + +#include <svl/stritem.hxx> + +#include <editeng/editeng.hxx> +#include <editeng/editview.hxx> + +#include "preextstl.h" +#include <cppunit/TestSuite.h> +#include <cppunit/TestFixture.h> +#include <cppunit/TestCase.h> +#include <cppunit/plugin/TestPlugIn.h> +#include <cppunit/extensions/HelperMacros.h> +#include "postextstl.h" + +SO2_DECL_REF(SmDocShell) +SO2_IMPL_REF(SmDocShell) + +using namespace ::com::sun::star; + +namespace { + +class Test : public CppUnit::TestFixture { +public: + // init + virtual void setUp(); + virtual void tearDown(); + + // tests + void createDocument(); + + CPPUNIT_TEST_SUITE(Test); + CPPUNIT_TEST(createDocument); + CPPUNIT_TEST_SUITE_END(); + +private: + uno::Reference< uno::XComponentContext > m_context; +}; + +void Test::setUp() +{ + m_context = cppu::defaultBootstrap_InitialComponentContext(); + + uno::Reference<lang::XMultiComponentFactory> xFactory(m_context->getServiceManager()); + uno::Reference<lang::XMultiServiceFactory> xSM(xFactory, uno::UNO_QUERY_THROW); + + //Without this we're crashing because callees are using + //getProcessServiceFactory. In general those should be removed in favour + //of retaining references to the root ServiceFactory as its passed around + comphelper::setProcessServiceFactory(xSM); + + InitVCL(xSM); + + SmDLL::Init(); +} + +void Test::tearDown() +{ + uno::Reference< lang::XComponent >(m_context, uno::UNO_QUERY_THROW)->dispose(); +} + +void Test::createDocument() +{ + SmDocShellRef xDocShRef = new SmDocShell(SFXOBJECTSHELL_STD_NORMAL); + + EditEngine &rEditEngine = xDocShRef->GetEditEngine(); + Window aFoo(NULL, 0); + EditView aEditView(&rEditEngine, &aFoo); + rEditEngine.SetActiveView(&aEditView); + + rtl::OUString sStringOne(RTL_CONSTASCII_USTRINGPARAM("a under b")); + { + rEditEngine.SetText(0, sStringOne); + xDocShRef->UpdateText(); + rtl::OUString sFinalText = xDocShRef->GetText(); + CPPUNIT_ASSERT_MESSAGE("Strings must match", sStringOne== sFinalText); + } + + rtl::OUString sStringTwo(RTL_CONSTASCII_USTRINGPARAM("a over b")); + { + rEditEngine.SetText(0, sStringTwo); + xDocShRef->UpdateText(); + rtl::OUString sFinalText = xDocShRef->GetText(); + CPPUNIT_ASSERT_MESSAGE("Strings must match", sStringTwo == sFinalText); + } + + SfxRequest aUndo(SID_UNDO, SFX_CALLMODE_SYNCHRON, xDocShRef->GetPool()); + + { + xDocShRef->Execute(aUndo); + rtl::OUString sFoo = rEditEngine.GetText(); + xDocShRef->UpdateText(); + rtl::OUString sFinalText = xDocShRef->GetText(); + CPPUNIT_ASSERT_MESSAGE("Strings much match", sStringOne== sFinalText); + } + + { + xDocShRef->Execute(aUndo); + rtl::OUString sFoo = rEditEngine.GetText(); + xDocShRef->UpdateText(); + rtl::OUString sFinalText = xDocShRef->GetText(); + CPPUNIT_ASSERT_MESSAGE("Must now be empty", !sFinalText.getLength()); + } + + SfxRequest aRedo(SID_REDO, SFX_CALLMODE_SYNCHRON, xDocShRef->GetPool()); + { + xDocShRef->Execute(aRedo); + rtl::OUString sFoo = rEditEngine.GetText(); + xDocShRef->UpdateText(); + rtl::OUString sFinalText = xDocShRef->GetText(); + CPPUNIT_ASSERT_MESSAGE("Strings much match", sStringOne== sFinalText); + } + + xDocShRef.Clear(); +} + +CPPUNIT_TEST_SUITE_REGISTRATION(Test); + +} + +CPPUNIT_PLUGIN_IMPLEMENT(); + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/starmath/qa/cppunit/version.map b/starmath/qa/cppunit/version.map new file mode 100644 index 000000000000..3308588ef6f8 --- /dev/null +++ b/starmath/qa/cppunit/version.map @@ -0,0 +1,34 @@ +#************************************************************************* +# +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# Copyright 2000, 2010 Oracle and/or its affiliates. +# +# OpenOffice.org - a multi-platform office productivity suite +# +# This file is part of OpenOffice.org. +# +# OpenOffice.org is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License version 3 +# only, as published by the Free Software Foundation. +# +# OpenOffice.org is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License version 3 for more details +# (a copy is included in the LICENSE file that accompanied this code). +# +# You should have received a copy of the GNU Lesser General Public License +# version 3 along with OpenOffice.org. If not, see +# <http://www.openoffice.org/license.html> +# for a copy of the LGPLv3 License. +# +#************************************************************************* + +UDK_3_0_0 { + global: + cppunitTestPlugIn; + + local: + *; +}; |