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="sheet_XRecentFunctions" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8'  Licensed to the Apache Software Foundation (ASF) under one
9'  or more contributor license agreements.  See the NOTICE file
10'  distributed with this work for additional information
11'  regarding copyright ownership.  The ASF licenses this file
12'  to you under the Apache License, Version 2.0 (the
13'  "License"); you may not use this file except in compliance
14'  with the License.  You may obtain a copy of the License at
15'
16'    http://www.apache.org/licenses/LICENSE-2.0
17'
18'  Unless required by applicable law or agreed to in writing,
19'  software distributed under the License is distributed on an
20'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21'  KIND, either express or implied.  See the License for the
22'  specific language governing permissions and limitations
23'  under the License.
24'
25'*************************************************************************
26
27
28
29
30
31' Be sure that all variables are dimensioned:
32option explicit
33
34'*************************************************************************
35' This Interface/Service test depends on the following GLOBAL variables,
36' which must be specified in the object creation:
37
38'     - Global AllFunctions As Variant
39
40'*************************************************************************
41
42
43
44
45
46
47Sub RunTest()
48
49'*************************************************************************
50' INTERFACE:
51' com.sun.star.sheet.XRecentFunctions
52'*************************************************************************
53On Error Goto ErrHndl
54    Dim bOK As Boolean
55    Dim recentFunctions As Variant
56    Dim i, j As Integer
57    Dim props As Variant
58
59
60    Test.StartMethod("getRecentFunctionIds()")
61    bOK = true
62    recentFunctions = oObj.getRecentFunctionIds()
63    bOK = bOK AND NOT isNULL(recentFunctions)
64    bOK = bOK AND ubound(recentFunctions) &lt;= oObj.getMaxRecentFunctions
65    for i = 0 to ubound(recentFunctions) - 1
66        for j = i + 1 to ubound(recentFunctions)
67            if recentFunctions(i) = recentFunctions(j) then bOK = false
68        next j
69    next i
70    Test.MethodTested("getRecentFunctionIds()", bOK)
71
72    Test.StartMethod("setRecentFunctionIds()")
73    bOK = true
74    Dim Max As Integer
75    Max = oObj.getMaxRecentFunctions
76    Dim newList(Max) As Integer
77
78    for i = 0 to ubound(newList())
79        props = AllFunctions.getByIndex(i)
80        for j = 0 to ubound(props())
81            if props(j).Name = "Id" then
82                newList(i) = props(j).Value
83                exit for
84            end if
85        next j
86    next i
87
88    oObj.setRecentFunctionIds(newList())
89    bOK = bOK AND (Max = oObj.getMaxRecentFunctions)
90    Test.MethodTested("setRecentFunctionIds()", bOK)
91
92    Test.StartMethod("getMaxRecentFunctions()")
93    bOK = true
94    Max = oObj.getMaxRecentFunctions
95    Out.Log("MaxRecentFunctions = " &amp; Max)
96    bOK = bOK AND Max &gt; 0
97    Test.MethodTested("getMaxRecentFunctions()", bOK)
98
99Exit Sub
100ErrHndl:
101    Test.Exception()
102    bOK = false
103    resume next
104End Sub
105</script:module>
106