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="form_XGridFieldDataSupplier" 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
36Sub RunTest()
37
38'*************************************************************************
39' INTERFACE:
40' com.sun.star.form.XGridFieldDataSupplier
41'*************************************************************************
42On Error Goto ErrHndl
43    Dim bOK As Boolean
44    Dim types As Variant
45    Dim data As Variant
46    Dim tmp as String
47    Dim i as Integer
48    Dim fieldCount as Integer
49    Dim row As Long
50    Dim dat As Variant
51
52    Test.StartMethod("queryFieldDataType()")
53    bOK = true
54    types = oObj.queryFieldDataType(oCoreRefl.forName("string"))
55
56    tmp = ""
57    fieldCount = 0
58    for i = lbound(types()) to ubound(types())
59        tmp = tmp + " " + types(i)
60        if types(i) then fieldCount = fieldCount + 1
61    next i
62    Out.Log("array returned : (" + tmp + ")")
63    bOK = bOK AND (ubound(types()) > 0)
64
65    Test.MethodTested("queryFieldDataType()", bOK)
66
67    Test.StartMethod("queryFieldData()")
68    bOK = true
69    row = 1
70    dat = oObj.queryFieldData(row, oCoreRefl.forName("string"))
71    if isNull(dat) OR isEmpty(dat) then
72        Out.Log("NULL value returned.")
73        bOK = false
74    else
75        Out.Log("The length of array returned :" + (ubound(data()) + 1)
76        bOK = bOK AND ((ubound(data()) + 1) = fieldCount)
77    end if
78    Test.MethodTested("queryFieldData()", bOK)
79
80Exit Sub
81ErrHndl:
82    Test.Exception()
83    bOK = false
84    resume next
85End Sub
86</script:module>
87