1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
/*************************************************************************
*
* 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.
*
************************************************************************/
package mod._invocation.uno;
import com.sun.star.lang.XMultiServiceFactory;
import com.sun.star.uno.XInterface;
import java.io.PrintWriter;
import lib.StatusException;
import lib.TestCase;
import lib.TestEnvironment;
import lib.TestParameters;
/**
* Test for object which is represented by service
* <code>com.sun.star.script.Invocation</code>. <p>
* Object implements the following interfaces :
* <ul>
* <li> <code>com::sun::star::lang::XSingleServiceFactory</code></li>
* </ul>
* @see com.sun.star.script.Invocation
* @see com.sun.star.lang.XSingleServiceFactory
* @see ifc.lang._XSingleServiceFactory
*/
public class Invocation extends TestCase {
/**
* Creating a Testenvironment for the interfaces to be tested.
* Creates service <code>com.sun.star.script.Invocation</code>.
* Object relations created :
* <ul>
* <li> <code>'XSingleServiceFactory.createInstance.negative'</code> :
* for interface {@link _ifc.lang.XSingleServiceFactory} ;
* <code>String</code> relation; If its value 'true' then
* <code>createInstance</code> method for the object isn't
* supported. In this case object doesn't support this method.</li>
* <li> <code>'XSingleServiceFactory.arguments'</code> :
* for interface {@link _ifc.lang.XSingleServiceFactory} ;
* has <code>Object[]</code> type. This relation is used as
* a parameter for <code>createInstanceWithArguments</code>
* method call. If this relation doesn't exist test pass
* zerro length array as argument. Here
* <code>com.sun.star.io.Pipe</code> instance is passed.</li>
* <li> <code>'XSingleServiceFactory.MustSupport'</code> :
* for interface {@link _ifc.lang.XSingleServiceFactory}.
* Specifies that created instance must support
* <code>com.sun.star.script.XInvocation</code> interface.
* </ul>
*/
protected TestEnvironment createTestEnvironment(TestParameters tParam, PrintWriter log) {
XMultiServiceFactory xMSF = (XMultiServiceFactory)tParam.getMSF();
try {
XInterface xInt = (XInterface)xMSF.createInstance(
"com.sun.star.script.Invocation");
TestEnvironment tEnv = new TestEnvironment(xInt);
// the createInstance should fail according to the documentation
tEnv.addObjRelation(
"XSingleServiceFactory.createInstance.negative", "true");
// creating parameters to createInstanceWithArguments
Object[] args = new Object[1];
args[0] = xMSF.createInstance("com.suns.star.io.Pipe");
tEnv.addObjRelation(
"XSingleServiceFactory.arguments", args);
tEnv.addObjRelation("XSingleServiceFactory.MustSupport",
new Class[] {com.sun.star.script.XInvocation.class});
return tEnv;
} catch (com.sun.star.uno.Exception e) {
e.printStackTrace(log);
throw new StatusException("Unexpected exception", e);
}
}
}
|