'************************************************************************* ' ' 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. ' '************************************************************************* ' Be sure that all variables are dimensioned: option explicit '************************************************************************* ' This Interface/Service test depends on the following GLOBAL variables, ' which must be specified in the object creation: ' - Global bCustomUpdate As Boolean ' properties are not changed to call listener ' Sub UpdateComponent() '************************************************************************* Const BOUND = 2 Const CONSTRAINED = 4 Const MAYBENULL = 8 Const READONLY = 16 Dim oListener1 As Object Dim oListener2 As Object Dim nCB1appVal As Boolean Dim nCB2appVal As Boolean Dim nCB1updVal As Boolean Dim nCB2updVal As Boolean Sub RunTest() '************************************************************************* ' INTERFACE: ' com.sun.star.form.XUpdateBroadcaster '************************************************************************* On Error Goto ErrHndl Dim bOK As Boolean Dim bAllOK As Boolean Out.Log("Creating Listeners...") oListener1 = createUNOListener("CB1_","com.sun.star.form.XUpdateListener") oListener2 = createUNOListener("CB2_","com.sun.star.form.XUpdateListener") bOK = NOT isNULL(oListener1) AND NOT isNULL(oListener2) CountersReset() bAllOK = bOK Test.StartMethod("addUpdateListener()") bOK = true oObj.addUpdateListener(oListener1) oObj.addUpdateListener(oListener2) if bCustomUpdate then Out.Log("Object specific update function was called.") UpdateComponent() else Out.Log("Interfacetest update function was called.") TryToUpdate() end if wait(1000) bOK = bOK AND nCB1appVal AND nCB2appVal AND nCB1updVal AND nCB2updVal Test.MethodTested("addUpdateListener()", bOK) Test.StartMethod("removeUpdateListener()") bOK = true Out.Log("Removing Listener 1") oObj.removeUpdateListener(oListener1) countersReset() if bCustomUpdate then Out.Log("Object specific update function was called.") UpdateComponent() else Out.Log("Interfacetest update function was called.") TryToUpdate() end if wait(1000) bOK = bOK AND NOT nCB1appVal AND nCB2appVal AND NOT nCB1updVal AND nCB2updVal Test.MethodTested("removeUpdateListener()", bOK) Out.Log("Removing Listener 2") oObj.removeUpdateListener(oListener2) Exit Sub ErrHndl: Test.Exception() bOK = false resume next End Sub Function CB1_approveUpdate As Boolean Out.Log("CallBack for Listener1 approveUpdate was called.") nCB1appVal = TRUE CB1_approveUpdate = TRUE End Function Function CB2_approveUpdate As Boolean Out.Log("CallBack for Listener2 approveUpdate was called.") nCB2appVal = TRUE CB2_approveUpdate = TRUE End Function Sub CB1_Updated Out.Log("CallBack for Listener1 Updated was called.") nCB1updVal = TRUE End Sub Sub CB2_Updated Out.Log("CallBack for Listener2 Updated was called.") nCB2updVal = TRUE End Sub Sub TryToUpdate() Dim i as Integer Dim props as Variant, attr As Variant if hasUnoInterfaces(oObj, "com.sun.star.beans.XPropertySet") then props() = oObj.getPropertySetInfo().getProperties() for i = lbound(props()) to ubound(props()) PropertyTester.TestProperty(props(i).Name) next i else Out.Log("XPropertySet isn't supported.") end if End Sub Sub countersReset() nCB1updVal = FALSE nCB2updVal = FALSE nCB1appVal = FALSE nCB2appVal = FALSE End sub