1*cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="form_XUpdateBroadcaster" script:language="StarBasic">
4*cdf0e10cSrcweir
5*cdf0e10cSrcweir
6*cdf0e10cSrcweir'*************************************************************************
7*cdf0e10cSrcweir'
8*cdf0e10cSrcweir' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*cdf0e10cSrcweir'
10*cdf0e10cSrcweir' Copyright 2000, 2010 Oracle and/or its affiliates.
11*cdf0e10cSrcweir'
12*cdf0e10cSrcweir' OpenOffice.org - a multi-platform office productivity suite
13*cdf0e10cSrcweir'
14*cdf0e10cSrcweir' This file is part of OpenOffice.org.
15*cdf0e10cSrcweir'
16*cdf0e10cSrcweir' OpenOffice.org is free software: you can redistribute it and/or modify
17*cdf0e10cSrcweir' it under the terms of the GNU Lesser General Public License version 3
18*cdf0e10cSrcweir' only, as published by the Free Software Foundation.
19*cdf0e10cSrcweir'
20*cdf0e10cSrcweir' OpenOffice.org is distributed in the hope that it will be useful,
21*cdf0e10cSrcweir' but WITHOUT ANY WARRANTY; without even the implied warranty of
22*cdf0e10cSrcweir' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23*cdf0e10cSrcweir' GNU Lesser General Public License version 3 for more details
24*cdf0e10cSrcweir' (a copy is included in the LICENSE file that accompanied this code).
25*cdf0e10cSrcweir'
26*cdf0e10cSrcweir' You should have received a copy of the GNU Lesser General Public License
27*cdf0e10cSrcweir' version 3 along with OpenOffice.org.  If not, see
28*cdf0e10cSrcweir' <http://www.openoffice.org/license.html>
29*cdf0e10cSrcweir' for a copy of the LGPLv3 License.
30*cdf0e10cSrcweir'
31*cdf0e10cSrcweir'*************************************************************************
32*cdf0e10cSrcweir'*************************************************************************
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir
36*cdf0e10cSrcweir' Be sure that all variables are dimensioned:
37*cdf0e10cSrcweiroption explicit
38*cdf0e10cSrcweir
39*cdf0e10cSrcweir'*************************************************************************
40*cdf0e10cSrcweir' This Interface/Service test depends on the following GLOBAL variables,
41*cdf0e10cSrcweir' which must be specified in the object creation:
42*cdf0e10cSrcweir
43*cdf0e10cSrcweir'     - Global bCustomUpdate As Boolean
44*cdf0e10cSrcweir'       properties are not changed to call listener
45*cdf0e10cSrcweir'       Sub UpdateComponent()
46*cdf0e10cSrcweir
47*cdf0e10cSrcweir'*************************************************************************
48*cdf0e10cSrcweir
49*cdf0e10cSrcweir
50*cdf0e10cSrcweir
51*cdf0e10cSrcweir
52*cdf0e10cSrcweirConst BOUND = 2
53*cdf0e10cSrcweirConst CONSTRAINED = 4
54*cdf0e10cSrcweirConst MAYBENULL = 8
55*cdf0e10cSrcweirConst READONLY = 16
56*cdf0e10cSrcweir
57*cdf0e10cSrcweirDim oListener1 As Object
58*cdf0e10cSrcweirDim oListener2 As Object
59*cdf0e10cSrcweirDim nCB1appVal As Boolean
60*cdf0e10cSrcweirDim nCB2appVal As Boolean
61*cdf0e10cSrcweirDim nCB1updVal As Boolean
62*cdf0e10cSrcweirDim nCB2updVal As Boolean
63*cdf0e10cSrcweir
64*cdf0e10cSrcweir
65*cdf0e10cSrcweirSub RunTest()
66*cdf0e10cSrcweir
67*cdf0e10cSrcweir'*************************************************************************
68*cdf0e10cSrcweir' INTERFACE:
69*cdf0e10cSrcweir' com.sun.star.form.XUpdateBroadcaster
70*cdf0e10cSrcweir'*************************************************************************
71*cdf0e10cSrcweirOn Error Goto ErrHndl
72*cdf0e10cSrcweir    Dim bOK As Boolean
73*cdf0e10cSrcweir    Dim bAllOK As Boolean
74*cdf0e10cSrcweir
75*cdf0e10cSrcweir    Out.Log("Creating Listeners...")
76*cdf0e10cSrcweir    oListener1 = createUNOListener("CB1_","com.sun.star.form.XUpdateListener")
77*cdf0e10cSrcweir    oListener2 = createUNOListener("CB2_","com.sun.star.form.XUpdateListener")
78*cdf0e10cSrcweir    bOK = NOT isNULL(oListener1) AND NOT isNULL(oListener2)
79*cdf0e10cSrcweir
80*cdf0e10cSrcweir    CountersReset()
81*cdf0e10cSrcweir
82*cdf0e10cSrcweir    bAllOK = bOK
83*cdf0e10cSrcweir
84*cdf0e10cSrcweir    Test.StartMethod("addUpdateListener()")
85*cdf0e10cSrcweir    bOK = true
86*cdf0e10cSrcweir    oObj.addUpdateListener(oListener1)
87*cdf0e10cSrcweir    oObj.addUpdateListener(oListener2)
88*cdf0e10cSrcweir
89*cdf0e10cSrcweir    if bCustomUpdate then
90*cdf0e10cSrcweir		Out.Log("Object specific update function was called.")
91*cdf0e10cSrcweir        UpdateComponent()
92*cdf0e10cSrcweir    else
93*cdf0e10cSrcweir		Out.Log("Interfacetest update function was called.")
94*cdf0e10cSrcweir        TryToUpdate()
95*cdf0e10cSrcweir    end if
96*cdf0e10cSrcweir	wait(1000)
97*cdf0e10cSrcweir
98*cdf0e10cSrcweir    bOK = bOK AND nCB1appVal AND nCB2appVal AND nCB1updVal AND nCB2updVal
99*cdf0e10cSrcweir
100*cdf0e10cSrcweir    Test.MethodTested("addUpdateListener()", bOK)
101*cdf0e10cSrcweir
102*cdf0e10cSrcweir    Test.StartMethod("removeUpdateListener()")
103*cdf0e10cSrcweir    bOK = true
104*cdf0e10cSrcweir    Out.Log("Removing Listener 1")
105*cdf0e10cSrcweir    oObj.removeUpdateListener(oListener1)
106*cdf0e10cSrcweir    countersReset()
107*cdf0e10cSrcweir
108*cdf0e10cSrcweir    if bCustomUpdate then
109*cdf0e10cSrcweir		Out.Log("Object specific update function was called.")
110*cdf0e10cSrcweir        UpdateComponent()
111*cdf0e10cSrcweir    else
112*cdf0e10cSrcweir		Out.Log("Interfacetest update function was called.")
113*cdf0e10cSrcweir        TryToUpdate()
114*cdf0e10cSrcweir    end if
115*cdf0e10cSrcweir	wait(1000)
116*cdf0e10cSrcweir
117*cdf0e10cSrcweir    bOK = bOK AND NOT nCB1appVal AND nCB2appVal AND NOT nCB1updVal AND nCB2updVal
118*cdf0e10cSrcweir    Test.MethodTested("removeUpdateListener()", bOK)
119*cdf0e10cSrcweir
120*cdf0e10cSrcweir    Out.Log("Removing Listener 2")
121*cdf0e10cSrcweir    oObj.removeUpdateListener(oListener2)
122*cdf0e10cSrcweir
123*cdf0e10cSrcweirExit Sub
124*cdf0e10cSrcweirErrHndl:
125*cdf0e10cSrcweir    Test.Exception()
126*cdf0e10cSrcweir    bOK = false
127*cdf0e10cSrcweir    resume next
128*cdf0e10cSrcweirEnd Sub
129*cdf0e10cSrcweirFunction CB1_approveUpdate As Boolean
130*cdf0e10cSrcweir    Out.Log("CallBack for Listener1 approveUpdate was called.")
131*cdf0e10cSrcweir    nCB1appVal = TRUE
132*cdf0e10cSrcweir    CB1_approveUpdate = TRUE
133*cdf0e10cSrcweirEnd Function
134*cdf0e10cSrcweir
135*cdf0e10cSrcweirFunction CB2_approveUpdate As Boolean
136*cdf0e10cSrcweir    Out.Log("CallBack for Listener2 approveUpdate was called.")
137*cdf0e10cSrcweir    nCB2appVal = TRUE
138*cdf0e10cSrcweir    CB2_approveUpdate = TRUE
139*cdf0e10cSrcweirEnd Function
140*cdf0e10cSrcweir
141*cdf0e10cSrcweirSub CB1_Updated
142*cdf0e10cSrcweir    Out.Log("CallBack for Listener1 Updated was called.")
143*cdf0e10cSrcweir    nCB1updVal = TRUE
144*cdf0e10cSrcweirEnd Sub
145*cdf0e10cSrcweir
146*cdf0e10cSrcweirSub CB2_Updated
147*cdf0e10cSrcweir    Out.Log("CallBack for Listener2 Updated was called.")
148*cdf0e10cSrcweir    nCB2updVal = TRUE
149*cdf0e10cSrcweirEnd Sub
150*cdf0e10cSrcweir
151*cdf0e10cSrcweirSub TryToUpdate()
152*cdf0e10cSrcweir    Dim i as Integer
153*cdf0e10cSrcweir    Dim props as Variant, attr As Variant
154*cdf0e10cSrcweir
155*cdf0e10cSrcweir    if hasUnoInterfaces(oObj, "com.sun.star.beans.XPropertySet") then
156*cdf0e10cSrcweir        props() = oObj.getPropertySetInfo().getProperties()
157*cdf0e10cSrcweir
158*cdf0e10cSrcweir        for i = lbound(props()) to ubound(props())
159*cdf0e10cSrcweir            PropertyTester.TestProperty(props(i).Name)
160*cdf0e10cSrcweir        next i
161*cdf0e10cSrcweir    else
162*cdf0e10cSrcweir        Out.Log("XPropertySet isn't supported.")
163*cdf0e10cSrcweir    end if
164*cdf0e10cSrcweirEnd Sub
165*cdf0e10cSrcweir
166*cdf0e10cSrcweirSub countersReset()
167*cdf0e10cSrcweir    nCB1updVal = FALSE
168*cdf0e10cSrcweir    nCB2updVal = FALSE
169*cdf0e10cSrcweir    nCB1appVal = FALSE
170*cdf0e10cSrcweir    nCB2appVal = FALSE
171*cdf0e10cSrcweirEnd sub
172*cdf0e10cSrcweir</script:module>
173