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="container_XNameAccess" 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' Be sure that all variables are dimensioned:
38option explicit
39
40
41
42Sub RunTest()
43
44'*************************************************************************
45' INTERFACE:
46' com.sun.star.container.XNameAccess
47'*************************************************************************
48On Error Goto ErrHndl
49    Dim aElementNames() As Variant
50    Dim bOK As Boolean
51    Dim oElem As Variant
52    Dim cName As String
53
54    Test.StartMethod("getElementNames()")
55    bOK = true
56    aElementnames() = oObj.getElementNames()
57    if hasUnoInterfaces(oObj, "com.sun.star.container.XIndexAccess") then
58        bOK = bOK AND (uBound(aElementnames()) = oObj.count - 1)
59    else
60        bOK = bOK AND (uBound(aElementnames()) &gt; -1)
61    end if
62    Test.MethodTested("getElementNames()", bOK)
63
64    Test.StartMethod("getByName()")
65    bOK = true
66    oElem = oObj.getByName(aElementNames(0))
67    bOK = bOK AND NOT isNull(oElem)
68    Test.MethodTested("getByName()", bOK)
69
70    Test.StartMethod("hasByName()")
71    bOK = true
72    cName = aElementNames(uBound(aElementNames()))
73    bOK = bOK AND oObj.hasByName(cName)
74    Test.MethodTested("hasByName()", bOK)
75
76Exit Sub
77ErrHndl:
78    Test.Exception()
79    bOK = false
80    resume next
81End Sub
82</script:module>
83