office-gobmx/ure/source/uretest
..
cppmain.cc
cppserver.cc
cpptest.cc
JavaClient.java
javaclient.mf.template
JavaMain.java
javamain.mf.template
JavaNative.java
javanative.mf.template
JavaTest.java
javatest.mf.template
Makefile
Makefile.pln
README
Runner.java
runner.mf.template
services.rdb.in
Tester.java
tester.mf.template
types.idl
types.mf.template

#
# This file is part of the LibreOffice project.
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# This file incorporates work covered by the following license notice:
#
#   Licensed to the Apache Software Foundation (ASF) under one or more
#   contributor license agreements. See the NOTICE file distributed
#   with this work for additional information regarding copyright
#   ownership. The ASF licenses this file to you under the Apache
#   License, Version 2.0 (the "License"); you may not use this file
#   except in compliance with the License. You may obtain a copy of
#   the License at http://www.apache.org/licenses/LICENSE-2.0 .
#

This directory contains test files for the UNO Runtime Environment (URE) as well
as the Makefile and Makefile.pln makefiles.  To execute the makefiles, you need
GNU make 3.80 or later.


Makefile
--------

Before you execute Makefile, you need to configure the Software Development Kit
(SDK) environment to work with a URE installation, a C++ compiler, and a JDK.
For more information, read the .../docs/install.html file in the SDK
installation.

NOTE: On Linux x86, if the Makefile accesses a GCC that is incompatible with the
GCC that was used to build the URE, use the GCCS_COMPAT environment variable as
a workaround.  For more details, see the UDK README file.


Makefile.pln
------------

You can only run Makefile.pln on Linux x86.  You do not need to configure your
SDK environment to use this makefile, however, you do need to set the following
environment variables:

- SDK_HOME
Points to the base directory of an OpenOffice.org SDK so that you can access UNO
programming tools and files that are not part of the URE.  For example, unoidl-write,
cppumaker, javamaker, and C++ headers.

- PATH
Points to a GCC installation (including g++) as well as a JDK installation that
contains the java, javac, and jar executables.  For the minimum version
requirements, see the SDK Installation Guide ($SDK_HOME/docs/install.html).

- URE_HOME (optional)
Overwrites the default URE location, that is, /opt/libreoffice.

- GCCS_COMPAT (optional)
Fixes incompatibility issues between the GCC that was used to build the URE and
the GCC that Makefile.pln accesses.  For more details, see the UDK README file.


Tests
-----

Makefile and Makefile.pln can execute the following tests:

- test-cpptest
Builds a C++ UNO component, cppmain.uno, and runs the component with the uno
executable.  The component first attempts to instantiate all the UNO services
and singletons that are part of the URE installation.  The component then tries
to instantiate and to call another C++ UNO component (cpptest.uno) as well as a
Java UNO component (javatest.uno).  The test completes when these components
throw a special exception that is caught by cppmain.uno.

- test-javatest
Builds a Java UNO component, javamain.uno, and runs the component with the uno
executable.  The component tries to instantiate and to call a C++ UNO component
(cpptest.uno) as well as a Java UNO component (javatest.uno).  The test
completes when these components throw a special exception that is caught by
javamain.uno.

- test-javanative
Builds a Java UNO application, javanative.jar, and runs the application with the
java executable.  The application bootstraps a native UNO environment, and then
tries to instantiate and to call a C++ UNO component (cpptest.uno) as well as a
Java UNO component( javatest.uno).  The test completes when these components
throw a special exception that is caught by javanative.jar.

- test-clientserver
Builds a server C++ UNO component, cppserver.uno, and a Java UNO application,
javaclient.uno.  The uno executable runs the cppserver.uno component which
listens on a pipe connection.  The java executable runs the javaclient.uno
component which connects to the server after a five second pause so that the
server has enough time to start.

- test-regview (Makefile.pln only)
Checks that the regview executable of the URE installation works reliably.

NOTE: The files that are generated when Makefile and Makefile.pln execute are
saved to different local directories.  Makefile outputs the generated files to
./out.sdk whereas Makefile.pln outputs the files to ./out.pln.