blob: 419a5529ed3da1880393c3a36c448b8eeb244056 [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
<script:module xmlns:script="http://openoffice.org/2000/script" script:name="form_XUpdateBroadcaster" script:language="StarBasic">
'*************************************************************************
'
' 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
</script:module>