[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