/**************************************************************
*
* 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
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
package ifc.bridge;
import lib.MultiMethodTest;
import lib.StatusException;
import com.sun.star.bridge.XBridge;
import com.sun.star.bridge.XBridgeFactory;
import com.sun.star.connection.XAcceptor;
import com.sun.star.connection.XConnection;
import com.sun.star.connection.XConnector;
import com.sun.star.lang.XMultiServiceFactory;
import com.sun.star.uno.UnoRuntime;
import com.sun.star.uno.XInterface;
/**
* Tests com.sun.star.bridge.XBridgeFactory
* interface methods :
*
createBridge()
getBridge()
getExistingBridges()
* @see com.sun.star.bridge.XBridgeFactory
*/
public class _XBridgeFactory extends MultiMethodTest {
public XBridgeFactory oObj = null;
private String bridgeName = null ;
AcceptorThread acceptorThread = null;
/**
* Interrupts the acceptor after test is finished
*/
protected void after() {
acceptorThread.acc.stopAccepting();
if (acceptorThread.isAlive()) {
acceptorThread.interrupt();
}
}
/**
* Calls accept()
method in a separate thread.
* Then stores exception thrown by call if it occured, or
* return value.
*/
protected class AcceptorThread extends Thread {
/**
* the acceptor
*/
private XAcceptor acc = null ;
/**
* If exception occured during method call it is
* stored in this field.
*/
public Exception ex = null ;
/**
* If method call returns some value it stores in this field.
*/
public XConnection acceptedCall = null ;
/**
* Gets an object which can call accept
method.
*/
public AcceptorThread(XAcceptor acc) {
this.acc = acc ;
}
/**
* Call accept()
method.
*/
public void run() {
try {
acceptedCall = acc.accept(connectString);
} catch (com.sun.star.lang.IllegalArgumentException e) {
ex = e ;
} catch (com.sun.star.connection.ConnectionSetupException e) {
ex = e ;
} catch (com.sun.star.connection.AlreadyAcceptingException e) {
ex = e ;
}
}
}
/**
* Variable to make bridge names unique in different threads.
*/
public static int uniqueSuffix = 0 ;
/**
* Object for synchronizing uniqueSuffix
increment.
*/
public static Object synchFlag = new Object() ;
/**
* Connection string
*/
public String connectString;
/**
* Gets array of existing bridges.
* Has OK status if method returns not null.
*/
public void _getExistingBridges() {
XBridge[] bridges = oObj.getExistingBridges() ;
log.println("Existing bridges :") ;
for (int i = 0; i < bridges.length; i++)
log.println(" " + bridges[i].getDescription()) ;
if (bridges.length > 0) bridgeName = bridges[0].getName() ;
tRes.tested("getExistingBridges()", bridges != null) ;
}
/**
* First creates connection with StarOffice process, using environment
* property 'CNCSTR'
. Then cerates bridge with unique name
* using protocol specified in environment as 'PROTOCOL'
* property. After that bridge is disposed.
* Has OK status if value returned is not null * and no exceptions were thrown.
*/ public void _createBridge() { XBridge bridge = null; XConnection conn = null ; boolean result = false ; // first creating a connection try { XInterface x = (XInterface) ((XMultiServiceFactory)tParam.getMSF()).createInstance ("com.sun.star.connection.Connector") ; XConnector xCntr = (XConnector) UnoRuntime.queryInterface (XConnector.class, x) ; x = (XInterface) ((XMultiServiceFactory)tParam.getMSF()).createInstance ("com.sun.star.connection.Acceptor") ; XAcceptor xAccptr = (XAcceptor)UnoRuntime.queryInterface( XAcceptor.class, x); connectString = (String)tEnv.getObjRelation("CNNCTSTR"); acceptorThread = new AcceptorThread(xAccptr) ; acceptorThread.start(); try { Thread.sleep(500); } catch (java.lang.InterruptedException e) {} conn = xCntr.connect(connectString) ; } catch (com.sun.star.uno.Exception e) { e.printStackTrace(log) ; throw new StatusException("Can't create connection", e); } try { String protocol = (String) tParam.get("PROTOCOL") ; if (protocol == null) protocol = "urp" ; String brName ; synchronized (synchFlag) { brName = "MyBridge" + (uniqueSuffix++) ; } log.println("Creating bridge with name " + brName) ; bridge = oObj.createBridge(brName, protocol, conn, null) ; result = bridge != null ; } catch (com.sun.star.bridge.BridgeExistsException e) { log.println("Exception while bridge creating :" + e) ; } catch (com.sun.star.lang.IllegalArgumentException e) { log.println("Exception while bridge creating :" + e) ; } tRes.tested("createBridge()", result) ; } /** * Gets bridge by name and checks the bridge name returned.
* The following method tests are to be executed before : *
getExestingBridges
: to have some bridge name
* to retrieve * Has OK status if bridge successfully returned and it's name * equals to name passed as parameter. */ public void _getBridge() { executeMethod("getExistingBridges()") ; if (bridgeName == null) { log.println("No name for getting the bridge") ; return ; } XBridge br = oObj.getBridge(bridgeName) ; tRes.tested("getBridge()", br != null && bridgeName.equals(br.getName())) ; } }