1*ef39d40dSAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*ef39d40dSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*ef39d40dSAndrew Rist * or more contributor license agreements. See the NOTICE file 5*ef39d40dSAndrew Rist * distributed with this work for additional information 6*ef39d40dSAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*ef39d40dSAndrew Rist * to you under the Apache License, Version 2.0 (the 8*ef39d40dSAndrew Rist * "License"); you may not use this file except in compliance 9*ef39d40dSAndrew Rist * with the License. You may obtain a copy of the License at 10*ef39d40dSAndrew Rist * 11*ef39d40dSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*ef39d40dSAndrew Rist * 13*ef39d40dSAndrew Rist * Unless required by applicable law or agreed to in writing, 14*ef39d40dSAndrew Rist * software distributed under the License is distributed on an 15*ef39d40dSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*ef39d40dSAndrew Rist * KIND, either express or implied. See the License for the 17*ef39d40dSAndrew Rist * specific language governing permissions and limitations 18*ef39d40dSAndrew Rist * under the License. 19*ef39d40dSAndrew Rist * 20*ef39d40dSAndrew Rist *************************************************************/ 21*ef39d40dSAndrew Rist 22*ef39d40dSAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir package ifc.sheet; 25cdf0e10cSrcweir 26cdf0e10cSrcweir import lib.MultiMethodTest; 27cdf0e10cSrcweir import lib.Status; 28cdf0e10cSrcweir import lib.StatusException; 29cdf0e10cSrcweir 30cdf0e10cSrcweir import com.sun.star.sheet.XCellRangeAddressable; 31cdf0e10cSrcweir import com.sun.star.sheet.XCellRangeReferrer; 32cdf0e10cSrcweir import com.sun.star.table.CellRangeAddress; 33cdf0e10cSrcweir import com.sun.star.table.XCellRange; 34cdf0e10cSrcweir import com.sun.star.uno.UnoRuntime; 35cdf0e10cSrcweir 36cdf0e10cSrcweir /** 37cdf0e10cSrcweir * Testing <code>com.sun.star.sheet.XCellRangeReferrer</code> 38cdf0e10cSrcweir * interface methods : 39cdf0e10cSrcweir * <ul> 40cdf0e10cSrcweir * <li><code> getReferredCells() </code></li> 41cdf0e10cSrcweir * </ul> <p> 42cdf0e10cSrcweir * This test needs the following object relations : 43cdf0e10cSrcweir * <ul> 44cdf0e10cSrcweir * <li> <code>'DATAAREA'</code> (of type <code>CellRangeAddress</code>): 45cdf0e10cSrcweir * to have cell range address </li> 46cdf0e10cSrcweir * <ul> <p> 47cdf0e10cSrcweir * @see com.sun.star.sheet.XCellRangeReferrer 48cdf0e10cSrcweir * @see com.sun.star.table.CellRangeAddress 49cdf0e10cSrcweir */ 50cdf0e10cSrcweir public class _XCellRangeReferrer extends MultiMethodTest { 51cdf0e10cSrcweir 52cdf0e10cSrcweir public XCellRangeReferrer oObj = null; 53cdf0e10cSrcweir 54cdf0e10cSrcweir /** 55cdf0e10cSrcweir * Test calls the method and compares cell range address of returned cell range 56cdf0e10cSrcweir * with cell range address gotten by relation <code>'DATAAREA'</code>. <p> 57cdf0e10cSrcweir * Has <b> OK </b> status if all fields of cell range addresses are equal. <p> 58cdf0e10cSrcweir */ _getReferredCells()59cdf0e10cSrcweir public void _getReferredCells() { 60cdf0e10cSrcweir boolean bResult = true; 61cdf0e10cSrcweir 62cdf0e10cSrcweir CellRangeAddress oldCRA = (CellRangeAddress) 63cdf0e10cSrcweir tEnv.getObjRelation("DATAAREA"); 64cdf0e10cSrcweir if (oldCRA == null) throw new StatusException(Status.failed 65cdf0e10cSrcweir ("Relation 'DATAAREA' not found")); 66cdf0e10cSrcweir 67cdf0e10cSrcweir XCellRange cr = oObj.getReferredCells(); 68cdf0e10cSrcweir log.println(cr.toString()); 69cdf0e10cSrcweir 70cdf0e10cSrcweir if (cr == null) { 71cdf0e10cSrcweir log.println("getReferredCells returned NULL."); 72cdf0e10cSrcweir tRes.tested("getReferredCells()", false); 73cdf0e10cSrcweir return; 74cdf0e10cSrcweir } 75cdf0e10cSrcweir 76cdf0e10cSrcweir XCellRangeAddressable xCRA = (XCellRangeAddressable) 77cdf0e10cSrcweir UnoRuntime.queryInterface(XCellRangeAddressable.class, cr); 78cdf0e10cSrcweir 79cdf0e10cSrcweir CellRangeAddress objCRA = xCRA.getRangeAddress(); 80cdf0e10cSrcweir 81cdf0e10cSrcweir log.println("The named range was 'ANamedRange A1:B2'"); 82cdf0e10cSrcweir log.println("Expected CellRangeAddress: (" + oldCRA.Sheet + 83cdf0e10cSrcweir "," + oldCRA.StartColumn + "," + oldCRA.StartRow + "," + 84cdf0e10cSrcweir oldCRA.EndColumn + "," + objCRA.EndRow + ")"); 85cdf0e10cSrcweir log.println("CellRangeAddress gotten: (" + objCRA.Sheet + "," 86cdf0e10cSrcweir + objCRA.StartColumn + "," + objCRA.StartRow + "," + 87cdf0e10cSrcweir objCRA.EndColumn + "," + objCRA.EndRow + ")"); 88cdf0e10cSrcweir 89cdf0e10cSrcweir bResult &= objCRA.EndColumn == oldCRA.EndColumn; 90cdf0e10cSrcweir bResult &= objCRA.EndRow == oldCRA.EndRow; 91cdf0e10cSrcweir bResult &= objCRA.Sheet == oldCRA.Sheet; 92cdf0e10cSrcweir bResult &= objCRA.StartColumn == oldCRA.StartColumn; 93cdf0e10cSrcweir bResult &= objCRA.StartRow == oldCRA.StartRow; 94cdf0e10cSrcweir 95cdf0e10cSrcweir tRes.tested("getReferredCells()", bResult); 96cdf0e10cSrcweir } 97cdf0e10cSrcweir } 98cdf0e10cSrcweir 99cdf0e10cSrcweir 100