'************************************************************************* '* '* $RCSfile: connection_XAcceptor.xba,v $ '* '* $Revision: 1.1 $ '* '* last change:$Date: 2003-01-27 17:45:53 $ '* '* The Contents of this file are made available subject to the terms of '* either of the following licenses '* '* - GNU Lesser General Public License Version 2.1 '* - Sun Industry Standards Source License Version 1.1 '* '* Sun Microsystems Inc., October, 2000 '* '* GNU Lesser General Public License Version 2.1 '* ============================================= '* Copyright 2000 by Sun Microsystems, Inc. '* 901 San Antonio Road, Palo Alto, CA 94303, USA '* '* This library is free software; you can redistribute it and/or '* modify it under the terms of the GNU Lesser General Public '* License version 2.1, as published by the Free Software Foundation. '* '* This library 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 for more details. '* '* You should have received a copy of the GNU Lesser General Public '* License along with this library; if not, write to the Free Software '* Foundation, Inc., 59 Temple Place, Suite 330, Boston, '* MA 02111-1307 USA '* '* '* Sun Industry Standards Source License Version 1.1 '* ================================================= '* The contents of this file are subject to the Sun Industry Standards '* Source License Version 1.1 (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.openoffice.org/license.html. '* '* Software provided under this License is provided on an "AS IS" basis, '* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, '* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, '* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. '* See the License for the specific provisions governing your rights and '* obligations concerning the Software. '* '* The Initial Developer of the Original Code is: Sun Microsystems, Inc. '* '* Copyright: 2000 by Sun Microsystems, Inc. '* '* All Rights Reserved. '* '* Contributor(s): _______________________________________ '* '* '************************************************************************* '************************************************************************* ' Be sure that all variables are dimensioned: option explicit Sub RunTest() '************************************************************************* ' INTERFACE: ' com.sun.star.connection.XAcceptor '************************************************************************* On Error Goto ErrHndl Dim bOK As Boolean Dim oConnector As Object Dim xConnection As Object Dim sConnectionString As String Dim args(1) As Variant bOK = true Test.startMethod("accept()") oConnector = createUnoService("basichelper.Connector") Dim iPos1 As Integer, iPos2 As Integer iPos1 = inStr(1, CNCSTR, "socket") iPos2 = inStr(iPos1, CNCSTR, "port=") sConnectionString = mid(CNCSTR, iPos1, iPos2 - iPos1 + 5) & "18888" Out.Log("Connection string is '" & sConnectionString & "'") args(0) = createUnoService("com.sun.star.connection.Connector") args(1) = sConnectionString ' When call initialize() method, a new thread is created and tries to ' connect to Acceptor after some seconds. oConnector.initialize(args()) ' Starting acception. xConnection = oObj.accept(sConnectionString) wait(500) 'Just to be sure that component had a chance to change it's state. bOK = bOK AND hasUNOInterfaces(xConnection, "com.sun.star.connection.XConnection") Out.Log("Connector's state is '" & oConnector.getByName("State") & "'") bOK = bOK AND oConnector.getByName("State") = "connected" ' This means that connection was established. if (bOK) then Out.Log("Connection established! Trying to get data from stream.") Dim aStr As String Dim aByte As Integer Dim readData() As Variant aStr = "" aByte = 1 while (aByte <> 0) ReDim readData() As Variant xConnection.read(readData, 1) aByte = readData(0) if (aByte <> 0) then aStr = aStr & chr(aByte) end if wend Out.Log("Returned data from stream is " & aStr) bOK = bOK AND aStr = sConnectionString end if Test.MethodTested("accept()", bOK) Test.startMethod("stopAccepting()") bOK = true ' Now stopping acception and trying to connect again ' (we can do this, if connection string is the same.) oObj.stopAccepting() Out.Log("Trying to connect after stopping accepting...") oConnector.initialize(args()) Out.Log("Connector's state is '" & oConnector.getByName("State") & "'") ' Now oConnector shouldn't connect. So, check it's state ' after few seconds (= Connection's Timeout + 3 sec) wait(3000 + oConnector.getByName("Timeout")) Out.Log("Connector's state is '" & oConnector.getByName("State") & "'") bOK = bOK AND oConnector.getByName("State") = "NoConnectException" Test.MethodTested("stopAccepting()", bOK) Exit Sub ErrHndl: Test.Exception() resume next End Sub