/************************************************************** * * 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 : *

* @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 : *

* 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())) ; } }