1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?> 2cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd"> 3cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sheet_XArrayFormulaRange" script:language="StarBasic"> 4cdf0e10cSrcweir 5cdf0e10cSrcweir 6cdf0e10cSrcweir'************************************************************************* 7cdf0e10cSrcweir' 8*eebed415SAndrew Rist' Licensed to the Apache Software Foundation (ASF) under one 9*eebed415SAndrew Rist' or more contributor license agreements. See the NOTICE file 10*eebed415SAndrew Rist' distributed with this work for additional information 11*eebed415SAndrew Rist' regarding copyright ownership. The ASF licenses this file 12*eebed415SAndrew Rist' to you under the Apache License, Version 2.0 (the 13*eebed415SAndrew Rist' "License"); you may not use this file except in compliance 14*eebed415SAndrew Rist' with the License. You may obtain a copy of the License at 15*eebed415SAndrew Rist' 16*eebed415SAndrew Rist' http://www.apache.org/licenses/LICENSE-2.0 17*eebed415SAndrew Rist' 18*eebed415SAndrew Rist' Unless required by applicable law or agreed to in writing, 19*eebed415SAndrew Rist' software distributed under the License is distributed on an 20*eebed415SAndrew Rist' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 21*eebed415SAndrew Rist' KIND, either express or implied. See the License for the 22*eebed415SAndrew Rist' specific language governing permissions and limitations 23*eebed415SAndrew Rist' under the License. 24cdf0e10cSrcweir' 25cdf0e10cSrcweir'************************************************************************* 26cdf0e10cSrcweir 27cdf0e10cSrcweir 28cdf0e10cSrcweir 29*eebed415SAndrew Rist 30*eebed415SAndrew Rist 31cdf0e10cSrcweir' Be sure that all variables are dimensioned: 32cdf0e10cSrcweiroption explicit 33cdf0e10cSrcweir 34cdf0e10cSrcweir 35cdf0e10cSrcweir 36cdf0e10cSrcweirSub RunTest() 37cdf0e10cSrcweir 38cdf0e10cSrcweir'************************************************************************* 39cdf0e10cSrcweir' INTERFACE: 40cdf0e10cSrcweir' com.sun.star.sheet.XArrayFormulaRange 41cdf0e10cSrcweir'************************************************************************* 42cdf0e10cSrcweirOn Error Goto ErrHndl 43cdf0e10cSrcweir Dim bOK As Boolean 44cdf0e10cSrcweir Dim bExpectedException As Boolean 45cdf0e10cSrcweir 46cdf0e10cSrcweir Test.StartMethod("setArrayFormula()") 47cdf0e10cSrcweir Test.StartMethod("getArrayFormula()") 48cdf0e10cSrcweir bOK = true 49cdf0e10cSrcweir 50cdf0e10cSrcweir if (cObjectName = "sc.ScTableSheetObj") then 51cdf0e10cSrcweir bExpectedException = true 52cdf0e10cSrcweir oObj.setArrayFormula("=1+2") 53cdf0e10cSrcweir wait(1) ' additional operator should exists here to avoid 54cdf0e10cSrcweir ' resuming on 'else' after exception handling 55cdf0e10cSrcweir else 56cdf0e10cSrcweir oObj.setArrayFormula("=1+2") 57cdf0e10cSrcweir bOK = bOK AND (oObj.getArrayFormula() = "{=1+2}") 58cdf0e10cSrcweir Out.Log("2") 59cdf0e10cSrcweir end if 60cdf0e10cSrcweir 61cdf0e10cSrcweir ' Setting of _empty_ formula should work for all objects. 62cdf0e10cSrcweir bExpectedException = false 63cdf0e10cSrcweir oObj.setArrayFormula("") 64cdf0e10cSrcweir bOK = bOK AND (oObj.getArrayFormula() = "") 65cdf0e10cSrcweir 66cdf0e10cSrcweir Test.MethodTested("getArrayFormula()", bOK) 67cdf0e10cSrcweir Test.MethodTested("setArrayFormula()", bOK) 68cdf0e10cSrcweir 69cdf0e10cSrcweirExit Sub 70cdf0e10cSrcweirErrHndl: 71cdf0e10cSrcweir if (bExpectedException) then 72cdf0e10cSrcweir Out.Log("It doesn't make sense to set formula over whole page.") 73cdf0e10cSrcweir Out.Log("Expected exception: " & error) 74cdf0e10cSrcweir else 75cdf0e10cSrcweir Test.Exception() 76cdf0e10cSrcweir bOK = false 77cdf0e10cSrcweir end if 78cdf0e10cSrcweir resume next 79cdf0e10cSrcweirEnd Sub 80cdf0e10cSrcweir</script:module> 81