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_XHierarchicalNameAccess" 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' This Interface/Service test depends on the following object relations
35' variables, which must be specified in the object creation:
36
37'      ObjectRelation: oObjRelation(0).Name = "ElementName"
38'      ObjectRelation: oObjRelation(0).Value = "MyAccessibleElementName"
39
40Sub RunTest()
41
42'*************************************************************************
43' INTERFACE:
44' com.sun.star.container.XHierarchicalNameAccess
45'*************************************************************************
46On Error Goto ErrHndl
47    Dim bOK As Boolean
48
49    Dim cObjRelation as Variant
50    cObjRelation = utils.getObjectRelation("ElementName")
51    if isNull(cObjRelation) then
52        cObjRelation = cIfcLongName
53    end if
54
55    Test.StartMethod("getByHierarchicalName()")
56    bOK = true
57    Dim oRet as Variant
58    oRet = oObj.getByHierarchicalName(cObjRelation)
59    if TypeName(oRet) = "String" then
60        out.log("oRet = " + oRet)
61        bOK = bOK and (oRet = cObjRelation)
62    else
63        bOK = bOK AND oRet.Name = cObjRelation
64    end if
65    Test.MethodTested("getByHierarchicalName()", bOK)
66
67    Test.StartMethod("hasByHierarchicalName()")
68    bOK = true
69    bOK = bOK AND oObj.hasByHierarchicalName(cObjRelation)
70    bOK = bOK AND NOT oObj.hasByHierarchicalName(cObjRelation + "ThisIsAnInvalidName")
71    Test.MethodTested("hasByHierarchicalName()", bOK)
72
73Exit Sub
74ErrHndl:
75    Test.Exception()
76    bOK = false
77    resume next
78End Sub
79</script:module>
80