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_XDataPilotTable" 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' Be sure that all variables are dimensioned:
37option explicit
38
39'*************************************************************************
40' This Interface/Service test depends on the following GLOBAL variables,
41' which must be specified in the object creation:
42
43'     - Global oOutputRange As New com.sun.star.table.CellAddress
44
45'*************************************************************************
46
47
48
49
50
51
52Sub RunTest()
53
54'*************************************************************************
55' INTERFACE:
56' com.sun.star.sheet.XDataPilotTable
57'*************************************************************************
58On Error Goto ErrHndl
59    Dim bOK As Boolean
60    Dim Range, oSheet As Object
61    Dim oldData, newData, CellRow, CellCol As Integer
62
63    Test.StartMethod("getOutputRange()")
64    bOK = true
65    Range = oObj.getOutputRange()
66    bOK = bOK AND NOT isNULL(Range)
67    if (bOK) then
68        bOK = bOK AND Range.Sheet = oOutputRange.Sheet
69        bOK = bOK AND Range.StartRow = oOutputRange.Row
70        bOK = bOK AND Range.StartColumn = oOutputRange.Column
71    end if
72    Test.MethodTested("getOutputRange()", bOK)
73
74    Test.StartMethod("refresh()")
75    bOK = true
76    CellRow = oObj.getSourceRange.EndRow
77    CellCol = oObj.getSourceRange.EndColumn
78    oSheet = oDoc.Sheets.getByIndex(0)
79    oSheet.getCellByPosition(CellCol, CellRow).Value = 5
80    oldData = oSheet.getCellByPosition(oOutputRange.Column, oOutputRange.Row+3).Value
81    oObj.refresh()
82    newData = oSheet.getCellByPosition(oOutputRange.Column, oOutputRange.Row+3).Value
83    bOK = bOK AND (oldData &lt;&gt; newData)
84    Test.MethodTested("refresh()", bOK)
85
86Exit Sub
87ErrHndl:
88    Test.Exception()
89    bOK = false
90    resume next
91End Sub
92</script:module>
93