1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="drawing_XShapeBinder" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9'
10' Copyright 2000, 2010 Oracle and/or its affiliates.
11'
12' OpenOffice.org - a multi-platform office productivity suite
13'
14' This file is part of OpenOffice.org.
15'
16' OpenOffice.org is free software: you can redistribute it and/or modify
17' it under the terms of the GNU Lesser General Public License version 3
18' only, as published by the Free Software Foundation.
19'
20' OpenOffice.org is distributed in the hope that it will be useful,
21' but WITHOUT ANY WARRANTY; without even the implied warranty of
22' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23' GNU Lesser General Public License version 3 for more details
24' (a copy is included in the LICENSE file that accompanied this code).
25'
26' You should have received a copy of the GNU Lesser General Public License
27' version 3 along with OpenOffice.org.  If not, see
28' <http://www.openoffice.org/license.html>
29' for a copy of the LGPLv3 License.
30'
31'*************************************************************************
32'*************************************************************************
33
34
35
36'*************************************************************************
37' This Interface/Service test depends on the following GLOBAL variables,
38' which must be specified in the object creation:
39
40'     - Global oBinderCollection As Object
41
42'*************************************************************************
43
44
45
46
47Sub RunTest()
48
49'*************************************************************************
50' INTERFACE:
51' com.sun.star.drawing.XShapeBinder
52'*************************************************************************
53On Error Goto ErrHndl
54    Dim bOK As Boolean
55
56    ReCreateObj()
57
58    Test.StartMethod("bind()")
59    bOK = true
60    if hasUnoInterfaces(oObj, "com.sun.star.container.XIndexAccess") then
61        nCount = oObj.getCount()
62        Out.Log("" &amp; nCount &amp; " elements in collection")
63        oBind = oObj.bind(oBinderCollection)
64        if (isNULL(oBind)) then Out.Log("bind() returned NULL.")
65        Out.Log("" &amp; oObj.getCount &amp; " elements in collection")
66        bOK = bOK AND (NOT isNull(oBind)) AND (nCount &lt;&gt; oObj.getCount)
67    else
68        oBind = oObj.bind(oBinderCollection)
69        if (isNULL(oBind)) then Out.Log("bind() returned NULL.")
70        bOK = bOK AND NOT isNull(oBind)
71    end if
72    Test.MethodTested("bind()", bOK)
73
74    Test.StartMethod("unbind()")
75    if (NOT bOK) then
76        Out.Log("Can't test unbind() without bind()")
77    else
78        if hasUnoInterfaces( oObj, "com.sun.star.container.XIndexAccess" ) then
79            oObj.unbind(oBind)
80            Out.Log("" &amp; oObj.count &amp; " elements in collection")
81            bOK = bOK AND (nCount &lt;= oObj.getCount)
82            Test.MethodTested("unbind()", bOK)
83        else
84            oObj.unbind(oBind)
85        end if
86    end if
87
88Exit Sub
89ErrHndl:
90    Test.Exception()
91    bOK = false
92    resume next
93End Sub
94</script:module>
95