| <?xml version="1.0" encoding="UTF-8"?> |
| <!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd"> |
| <script:module xmlns:script="http://openoffice.org/2000/script" script:name="chart_XChartDataArray" script:language="StarBasic"> |
| |
| |
| '************************************************************************* |
| ' |
| ' Licensed to the Apache Software Foundation (ASF) under one |
| ' or more contributor license agreements. See the NOTICE file |
| ' distributed with this work for additional information |
| ' regarding copyright ownership. The ASF licenses this file |
| ' to you under the Apache License, Version 2.0 (the |
| ' "License"); you may not use this file except in compliance |
| ' with the License. You may obtain a copy of the License at |
| ' |
| ' http://www.apache.org/licenses/LICENSE-2.0 |
| ' |
| ' Unless required by applicable law or agreed to in writing, |
| ' software distributed under the License is distributed on an |
| ' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| ' KIND, either express or implied. See the License for the |
| ' specific language governing permissions and limitations |
| ' under the License. |
| ' |
| '************************************************************************* |
| |
| |
| |
| |
| |
| ' Be sure that all variables are dimensioned: |
| option explicit |
| |
| '************************************************************************* |
| ' This Interface/Service test depends on the following GLOBAL variables, |
| ' which must be specified in the object creation: |
| |
| ' Global nTableH As Integer |
| ' Global nTableW As Integer |
| |
| '************************************************************************* |
| |
| |
| |
| |
| |
| Sub RunTest() |
| |
| '************************************************************************* |
| ' INTERFACE: |
| ' com.sun.star.chart.XChartDataArray |
| '************************************************************************* |
| On Error Goto ErrHndl |
| |
| Dim bOK As Boolean |
| Dim i As Integer, j As Integer |
| Dim objRowDsc As Variant, objColDsc As Variant |
| Dim objEl As Variant, newEl As Variant |
| Dim chData As Variant |
| |
| Out.Log("Object is '" + cObjectName + "'") |
| if (cObjectName = "sw.SwXTextTable") then |
| Out.Log("Object is 'SwXTextTable'. First, remove labels.") |
| oObj.setPropertyValue("ChartRowAsLabel", false) |
| oObj.setPropertyValue("ChartColumnAsLabel", false) |
| end if |
| |
| Test.StartMethod("getData()") |
| bOK = true |
| |
| Dim oData As Object |
| oData = oObj.getData() |
| bOK = bOK AND NOT isNULL(oData) |
| Test.MethodTested("getData()", bOK) |
| |
| Test.StartMethod("setData()") |
| bOK = true |
| |
| Dim newData(nTableH - 1) As Variant |
| Dim a(nTableW - 1) As Double |
| |
| for i = 0 to nTableH - 1 |
| ReDim a(nTableW - 1) As Double |
| for j = 0 to nTableW - 1 |
| a(j) = ((nTableW * 4) / (i + 2) + j * 2) + 16 |
| next j |
| newData(i) = a() |
| next i |
| |
| oObj.setData(newData()) |
| chData = oObj.getData() |
| |
| bOK = bOK AND ubound(oObj.getRowDescriptions()) = nTableH - 1 |
| bOK = bOK AND ubound(oObj.getColumnDescriptions()) = nTableW - 1 |
| |
| for i = 0 to nTableH - 1 |
| objEl = chData(i) |
| newEl = newData(i) |
| for j = 0 to nTableW - 1 |
| bOK = bOK AND objEl(j) = newEl(j) |
| next j |
| next i |
| |
| Test.MethodTested("setData()", bOK) |
| |
| if (cObjectName = "sw.SwXTextTable") then |
| Out.Log("Object is 'SwXTextTable'. Initialize labels.") |
| oObj.setPropertyValue("ChartRowAsLabel", true) |
| oObj.setPropertyValue("ChartColumnAsLabel", true) |
| end if |
| |
| Test.StartMethod("getRowDescriptions()") |
| bOK = true |
| |
| Dim oRowDsc() As String |
| oRowDsc = oObj.getRowDescriptions() |
| bOK = bOK AND NOT isNULL(oRowDsc) |
| Test.MethodTested("getRowDescriptions()", bOK) |
| |
| Test.StartMethod("setRowDescriptions()") |
| bOK = true |
| |
| Dim newRowDsc(nTableH - 2) As String |
| for i = 0 to nTableH - 2 ' -1 for 0-index and -1 for columns labels |
| newRowDsc(i) = "RowDsc " + i |
| next i |
| |
| oObj.setRowDescriptions(newRowDsc()) |
| |
| objRowDsc = oObj.getRowDescriptions() |
| |
| for i = 0 to nTableH - 2 |
| bOK = bOK AND newRowDsc(i) = objRowDsc(i) |
| next i |
| |
| Test.MethodTested("setRowDescriptions()", bOK) |
| |
| Test.StartMethod("getColumnDescriptions()") |
| bOK = true |
| bOK = bOK AND NOT isNULL(oObj.getColumnDescriptions()) |
| Test.MethodTested("getColumnDescriptions()", bOK) |
| |
| Test.StartMethod("setColumnDescriptions()") |
| bOK = true |
| |
| Dim newColDsc(nTableW - 2) As String |
| for i = 0 to nTableW - 2 |
| newColDsc(i) = "ColDsc " + i |
| next i |
| |
| oObj.setColumnDescriptions(newColDsc()) |
| |
| objColDsc = oObj.getColumnDescriptions() |
| |
| for i = 0 to nTableW - 2 |
| bOK = bOK AND newColDsc(i) = objColDsc(i) |
| next i |
| |
| if (cObjectName = "sw.SwXTextTable") then |
| Out.Log("Object is 'SwXTextTable'. Remove labels finally.") |
| oObj.setPropertyValue("ChartRowAsLabel", false) |
| oObj.setPropertyValue("ChartColumnAsLabel", false) |
| end if |
| |
| Test.MethodTested("setColumnDescriptions()", bOK) |
| |
| |
| Exit Sub |
| ErrHndl: |
| Test.Exception() |
| bOK = false |
| resume next |
| End Sub |
| </script:module> |