[Libreoffice-commits] .: 2 commits - basegfx/Executable_basegfx_cppunittester_all.mk basegfx/Module_basegfx.mk basegfx/test sax/Executable_sax_cppunittester_all.mk

Tor Lillqvist tml at kemper.freedesktop.org
Wed Aug 3 07:36:39 PDT 2011


 basegfx/Executable_basegfx_cppunittester_all.mk |   74 ++++++++++++
 basegfx/Module_basegfx.mk                       |    6 +
 basegfx/test/basegfx1d.cxx                      |    3 
 basegfx/test/basegfx_cppunittester_all.cxx      |  137 ++++++++++++++++++++++++
 sax/Executable_sax_cppunittester_all.mk         |    1 
 5 files changed, 221 insertions(+)

New commits:
commit c5e654cfc2e4d1e0f05c47ccf96f579f7da64708
Author: Tor Lillqvist <tml at iki.fi>
Date:   Wed Aug 3 17:33:36 2011 +0300

    Add statically linked basegfx cppunittester for iOS

diff --git a/basegfx/Executable_basegfx_cppunittester_all.mk b/basegfx/Executable_basegfx_cppunittester_all.mk
new file mode 100644
index 0000000..da50cd2
--- /dev/null
+++ b/basegfx/Executable_basegfx_cppunittester_all.mk
@@ -0,0 +1,74 @@
+# -*- Mode: makefile; 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
+#       Tor Lillqvist. <tml at iki.fi>
+# 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_Executable_Executable,basegfx_cppunittester_all))
+
+$(eval $(call gb_Executable_set_include,basegfx_cppunittester_all,\
+    $$(INCLUDE) \
+    -I$(SRCDIR)/basegfx/inc/pch \
+))
+
+$(eval $(call gb_Executable_add_defs,basegfx_cppunittester_all,\
+	$(gb_OBJCXXFLAGS) \
+))
+
+$(eval $(call gb_Executable_add_linked_libs,basegfx_cppunittester_all, \
+	basegfx \
+	cppu \
+	cppunit \
+    sal \
+    sal_textenc \
+    $(gb_STDLIBS) \
+	objc \
+))
+
+$(eval $(call gb_Executable_use_externals,basegfx_cppunittester_all, \
+	uikit \
+	foundation \
+))
+
+$(eval $(call gb_Executable_add_exception_objects,basegfx_cppunittester_all, \
+    basegfx/test/basegfx_cppunittester_all \
+	basegfx/test/basegfx1d \
+	basegfx/test/basegfx2d \
+	basegfx/test/basegfx3d \
+	basegfx/test/boxclipper \
+	basegfx/test/basegfxtools \
+	basegfx/test/clipstate \
+	basegfx/test/genericclipper \
+	basegfx/test/testtools \
+))
+
+$(eval $(call gb_Executable_add_api,basegfx_cppunittester_all, \
+	udkapi \
+	offapi \
+))
+
+# vim: set noet sw=4 ts=4:
diff --git a/basegfx/Module_basegfx.mk b/basegfx/Module_basegfx.mk
index f2268ef..af20702 100644
--- a/basegfx/Module_basegfx.mk
+++ b/basegfx/Module_basegfx.mk
@@ -43,4 +43,10 @@ $(eval $(call gb_Module_add_check_targets,basegfx,\
 	CppunitTest_basegfx \
 ))
 
+ifeq ($(OS),IOS)
+$(eval $(call gb_Module_add_targets,basegfx,\
+	Executable_basegfx_cppunittester_all \
+))
+endif
+
 # vim: set noet sw=4 ts=4:
diff --git a/basegfx/test/basegfx1d.cxx b/basegfx/test/basegfx1d.cxx
index 7a0b1f0..28d8228 100644
--- a/basegfx/test/basegfx1d.cxx
+++ b/basegfx/test/basegfx1d.cxx
@@ -26,6 +26,9 @@
  *
  ************************************************************************/
 
+#ifdef IOS
+#define CPPUNIT_PLUGIN_EXPORTED_NAME cppunitTest_basegfx
+#endif
 
 // MARKER(update_precomp.py): autogen include statement, do not remove
 #include "precompiled_basegfx.hxx"
diff --git a/basegfx/test/basegfx_cppunittester_all.cxx b/basegfx/test/basegfx_cppunittester_all.cxx
new file mode 100644
index 0000000..7508fe1
--- /dev/null
+++ b/basegfx/test/basegfx_cppunittester_all.cxx
@@ -0,0 +1,137 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*************************************************************************
+*
+* 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.
+*
+************************************************************************/
+
+#include "sal/config.h"
+
+#include <cstdlib>
+#include <iostream>
+#include <limits>
+#include <string>
+#include "protectorfactory.hxx"
+#include "osl/module.h"
+#include "osl/module.hxx"
+#include "osl/thread.h"
+#include "rtl/process.h"
+#include "rtl/string.h"
+#include "rtl/string.hxx"
+#include "rtl/textcvt.h"
+#include "rtl/ustring.hxx"
+#include "sal/main.h"
+#include "sal/types.h"
+
+#include "cppunit/CompilerOutputter.h"
+#include "cppunit/TestResult.h"
+#include "cppunit/TestResultCollector.h"
+#include "cppunit/TestRunner.h"
+#include "cppunit/plugin/TestPlugIn.h"
+#include "cppunit/plugin/PlugInParameters.h"
+#include "cppunit/extensions/TestFactoryRegistry.h"
+#include "cppunit/portability/Stream.h"
+
+#include "boost/noncopyable.hpp"
+
+namespace {
+
+void usageFailure() {
+    std::cerr
+        << ("Usage: cppunittester (--protector <shared-library-path>"
+            " <function-symbol>)* <shared-library-path>")
+        << std::endl;
+    std::exit(EXIT_FAILURE);
+}
+
+rtl::OUString getArgument(sal_Int32 index) {
+    rtl::OUString arg;
+    rtl_getAppCommandArg(index, &arg.pData);
+    return arg;
+}
+
+std::string convertLazy(rtl::OUString const & s16) {
+    rtl::OString s8(rtl::OUStringToOString(s16, osl_getThreadTextEncoding()));
+    return std::string(
+        s8.getStr(),
+        ((static_cast< sal_uInt32 >(s8.getLength())
+          > (std::numeric_limits< std::string::size_type >::max)())
+         ? (std::numeric_limits< std::string::size_type >::max)()
+         : static_cast< std::string::size_type >(s8.getLength())));
+}
+
+//Allow the whole uniting testing framework to be run inside a "Protector"
+//which knows about uno exceptions, so it can print the content of the
+//exception before falling over and dying
+class CPPUNIT_API ProtectedFixtureFunctor : public CppUnit::Functor, private boost::noncopyable
+{
+private:
+    const std::string &args;
+    CppUnit::TestResult &result;
+public:
+    ProtectedFixtureFunctor(const std::string &args_, CppUnit::TestResult &result_)
+        : args(args_)
+        , result(result_)
+    {
+    }
+    bool run() const
+    {
+        CppUnit::TestRunner runner;
+        runner.addTest(CppUnit::TestFactoryRegistry::getRegistry().makeTest());
+        CppUnit::TestResultCollector collector;
+        result.addListener(&collector);
+        runner.run(result);
+        CppUnit::CompilerOutputter(&collector, CppUnit::stdCErr()).write();
+        return collector.wasSuccessful();
+    }
+    virtual bool operator()() const
+    {
+        return run();
+    }
+};
+}
+
+extern "C" CppUnitTestPlugIn
+           *cppunitTest_basegfx(void);
+
+SAL_IMPLEMENT_MAIN() {
+    TestPlugInSignature plugs[] = {
+        cppunitTest_basegfx,
+        NULL
+    };
+    CppUnit::TestResult result;
+    std::string args;
+    bool ok = false;
+    for (TestPlugInSignature *plug = plugs; *plug != NULL; plug++) {
+        CppUnitTestPlugIn *iface;
+        iface = (*plug)();
+        iface->initialize(&CppUnit::TestFactoryRegistry::getRegistry(), CppUnit::PlugInParameters());
+    }
+    ProtectedFixtureFunctor tests(args, result);
+    ok = tests.run();
+
+    return ok ? EXIT_SUCCESS : EXIT_FAILURE;
+}
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
commit 5f35c52d3b2b4e510d1a27359988a32349447e9e
Author: Tor Lillqvist <tml at iki.fi>
Date:   Wed Aug 3 16:22:49 2011 +0300

    Need to link with sal_textenc, too, now

diff --git a/sax/Executable_sax_cppunittester_all.mk b/sax/Executable_sax_cppunittester_all.mk
index ef07dae..c39fe8b 100644
--- a/sax/Executable_sax_cppunittester_all.mk
+++ b/sax/Executable_sax_cppunittester_all.mk
@@ -41,6 +41,7 @@ $(eval $(call gb_Executable_add_linked_libs,sax_cppunittester_all,\
 	cppu \
 	cppunit \
 	sal \
+	sal_textenc \
 	sax \
 	$(gb_STDLIBS) \
     objc \


More information about the Libreoffice-commits mailing list