[Libreoffice-commits] .: 3 commits - sax/Module_sax.mk tools/Executable_tools_cppunittester_all.mk tools/Module_tools.mk tools/qa

Tor Lillqvist tml at kemper.freedesktop.org
Tue Aug 2 15:14:03 PDT 2011


 sax/Module_sax.mk                            |    4 
 tools/Executable_tools_cppunittester_all.mk  |   70 +++++++++++++
 tools/Module_tools.mk                        |    6 +
 tools/qa/cppunit/test_reversemap.cxx         |    4 
 tools/qa/cppunit/tools_cppunittester_all.cxx |  137 +++++++++++++++++++++++++++
 5 files changed, 219 insertions(+), 2 deletions(-)

New commits:
commit 11edb3ad231e6ec8ac1a518f3fa7e4912cd33312
Author: Tor Lillqvist <tml at iki.fi>
Date:   Wed Aug 3 01:12:12 2011 +0300

    Link with sal_textenc on iOS

diff --git a/tools/Executable_tools_cppunittester_all.mk b/tools/Executable_tools_cppunittester_all.mk
index 962d4ff..28ed5c6 100644
--- a/tools/Executable_tools_cppunittester_all.mk
+++ b/tools/Executable_tools_cppunittester_all.mk
@@ -44,6 +44,7 @@ $(eval $(call gb_Executable_add_linked_libs,tools_cppunittester_all, \
 	cppu \
 	cppunit \
     sal \
+    sal_textenc \
     tl \
     $(gb_STDLIBS) \
 	objc \
commit 101ab08978b8f5858a09afbf2d6979b724b543db
Author: Tor Lillqvist <tml at iki.fi>
Date:   Wed Aug 3 01:06:38 2011 +0300

    Simplify a bit now that gb_Module_add_check_targets is a no-op for iOS anyway

diff --git a/sax/Module_sax.mk b/sax/Module_sax.mk
index 325b78a..b55aebe 100644
--- a/sax/Module_sax.mk
+++ b/sax/Module_sax.mk
@@ -35,11 +35,11 @@ $(eval $(call gb_Module_add_targets,sax,\
 	Package_inc \
 ))
 
-ifneq ($(OS),IOS)
 $(eval $(call gb_Module_add_check_targets,sax,\
 	CppunitTest_sax \
 ))
-else
+
+ifeq ($(OS),IOS)
 $(eval $(call gb_Module_add_targets,sax,\
 	Executable_sax_cppunittester_all \
 ))
commit 70b15bb5c65d06625c188d3e7873fd19ab6d7278
Author: Tor Lillqvist <tml at iki.fi>
Date:   Wed Aug 3 00:26:40 2011 +0300

    Add statically linked unit tester for iOS

diff --git a/tools/Executable_tools_cppunittester_all.mk b/tools/Executable_tools_cppunittester_all.mk
new file mode 100644
index 0000000..962d4ff
--- /dev/null
+++ b/tools/Executable_tools_cppunittester_all.mk
@@ -0,0 +1,69 @@
+# -*- 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
+#       Caolán McNamara, Red Hat, Inc. <caolanm at redhat.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_Executable_Executable,tools_cppunittester_all))
+
+$(eval $(call gb_Executable_set_include,tools_cppunittester_all,\
+    $$(INCLUDE) \
+    -I$(SRCDIR)/tools/inc \
+    -I$(SRCDIR)/tools/inc/pch \
+))
+
+$(eval $(call gb_Executable_add_defs,tools_cppunittester_all,\
+	$(gb_OBJCXXFLAGS) \
+))
+
+$(eval $(call gb_Executable_add_linked_libs,tools_cppunittester_all, \
+	cppu \
+	cppunit \
+    sal \
+    tl \
+    $(gb_STDLIBS) \
+	objc \
+))
+
+$(eval $(call gb_Executable_use_externals,tools_cppunittester_all, \
+	uikit \
+	foundation \
+))
+
+$(eval $(call gb_Executable_add_exception_objects,tools_cppunittester_all, \
+    tools/qa/cppunit/tools_cppunittester_all \
+    tools/qa/cppunit/test_reversemap \
+    tools/qa/cppunit/test_pathutils \
+    tools/qa/cppunit/test_streamstate \
+))
+
+$(eval $(call gb_Executable_add_api,tools_cppunittester_all, \
+	udkapi \
+	offapi \
+))
+
+# vim: set noet sw=4 ts=4:
diff --git a/tools/Module_tools.mk b/tools/Module_tools.mk
index e4a6189..0948d0b 100644
--- a/tools/Module_tools.mk
+++ b/tools/Module_tools.mk
@@ -50,4 +50,10 @@ $(eval $(call gb_Module_add_targets,tools,\
 ))
 endif
 
+ifeq ($(OS),IOS)
+$(eval $(call gb_Module_add_targets,tools,\
+	Executable_tools_cppunittester_all \
+))
+endif
+
 # vim: set noet sw=4 ts=4:
diff --git a/tools/qa/cppunit/test_reversemap.cxx b/tools/qa/cppunit/test_reversemap.cxx
index a6e1314..92c349c 100644
--- a/tools/qa/cppunit/test_reversemap.cxx
+++ b/tools/qa/cppunit/test_reversemap.cxx
@@ -26,6 +26,10 @@
  * instead of those above.
  */
 
+#ifdef IOS
+#define CPPUNIT_PLUGIN_EXPORTED_NAME cppunitTest_tools_reversemap
+#endif
+
 #include "precompiled_tools.hxx"
 #include <sal/cppunit.h>
 
diff --git a/tools/qa/cppunit/tools_cppunittester_all.cxx b/tools/qa/cppunit/tools_cppunittester_all.cxx
new file mode 100644
index 0000000..dff2597
--- /dev/null
+++ b/tools/qa/cppunit/tools_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_tools_reversemap(void);
+
+SAL_IMPLEMENT_MAIN() {
+    TestPlugInSignature plugs[] = {
+        cppunitTest_tools_reversemap,
+        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: */


More information about the Libreoffice-commits mailing list