blob: 04acc68ea4b1bd5cb7412099cd986d18770a5315 [file] [log] [blame]
/**************************************************************
*
* 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.
*
*************************************************************/
package ifc.sheet;
import com.sun.star.awt.Point;
import com.sun.star.sheet.TableOperationMode;
import com.sun.star.sheet.XCellAddressable;
import com.sun.star.sheet.XCellRangeAddressable;
import com.sun.star.sheet.XMultipleOperation;
import com.sun.star.sheet.XSpreadsheet;
import com.sun.star.table.XCell;
import com.sun.star.table.XCellRange;
import com.sun.star.uno.UnoRuntime;
import lib.MultiMethodTest;
import lib.Status;
import lib.StatusException;
public class _XMultipleOperation extends MultiMethodTest {
public XMultipleOperation oObj = null;
protected XSpreadsheet oSheet = null;
boolean both = true;
protected void before() {
oSheet = (XSpreadsheet) tEnv.getObjRelation("SHEET");
if (oSheet == null) {
throw new StatusException(Status.failed(
"Object relation oSheet is missing"));
}
if (UnoRuntime.queryInterface(XSpreadsheet.class, tEnv.getTestObject()) != null) {
log.println("We have a sheet and won't do TableOperationMode.BOTH");
both = false;
}
}
public void _setTableOperation() {
boolean res = true;
XCellRange cellRange = oSheet.getCellRangeByName("$A$17:$A$17");
XCellRangeAddressable CRA = (XCellRangeAddressable) UnoRuntime.queryInterface(
XCellRangeAddressable.class,
cellRange);
XCell cell = null;
XCell cell2 = null;
try {
cell = oSheet.getCellByPosition(0, 16);
cell.setFormula("=a15+a16");
cell = oSheet.getCellByPosition(0, 14);
cell2 = oSheet.getCellByPosition(0, 15);
} catch (com.sun.star.lang.IndexOutOfBoundsException e) {
log.println("Exception while getting Cell " + e.getMessage());
}
XCellAddressable CA = (XCellAddressable) UnoRuntime.queryInterface(
XCellAddressable.class, cell);
XCellAddressable CA2 = (XCellAddressable) UnoRuntime.queryInterface(
XCellAddressable.class, cell2);
Point[] cellCoords = new Point[3];
double[] cellValues = new double[3];
log.println("filling cells");
fillCells();
log.println("setting TableOperation with parameter ROW");
oObj.setTableOperation(CRA.getRangeAddress(), TableOperationMode.ROW,
CA.getCellAddress(), CA2.getCellAddress());
log.println("checking values");
cellCoords = new Point[] {
new Point(1, 1), new Point(2, 1), new Point(3, 1)
};
cellValues = new double[] { 5, 10, 15 };
res &= checkValues(cellCoords, cellValues);
log.println("filling cells");
fillCells();
log.println("setting TableOperation with parameter COLUMN");
oObj.setTableOperation(CRA.getRangeAddress(),
TableOperationMode.COLUMN, CA.getCellAddress(),
CA2.getCellAddress());
log.println("checking values");
cellCoords = new Point[] {
new Point(1, 1), new Point(1, 2), new Point(1, 3)
};
cellValues = new double[] { 12, 24, 36 };
res &= checkValues(cellCoords, cellValues);
if (both) {
log.println("filling cells");
fillCells();
log.println("setting TableOperation with parameter BOTH");
oObj.setTableOperation(CRA.getRangeAddress(),
TableOperationMode.BOTH,
CA.getCellAddress(), CA2.getCellAddress());
log.println("checking values");
cellCoords = new Point[] {
new Point(1, 1), new Point(2, 2), new Point(3, 3)
};
cellValues = new double[] { 17, 34, 51 };
res &= checkValues(cellCoords, cellValues);
}
tRes.tested("setTableOperation()", res);
}
protected void fillCells() {
XCell cell = null;
try {
for (int k = 1; k < 5; k++) {
cell = oSheet.getCellByPosition(0, k);
cell.setValue(k * 12);
cell = oSheet.getCellByPosition(k, 0);
cell.setValue(k * 5);
}
} catch (com.sun.star.lang.IndexOutOfBoundsException e) {
log.println("Exception while filling Cells " + e.getMessage());
}
}
protected boolean checkValues(Point[] cellCoords, double[] cellValues) {
boolean res = true;
for (int i = 0; i < cellValues.length; i++) {
try {
boolean locres = oSheet.getCellByPosition(cellCoords[i].X,
cellCoords[i].Y)
.getValue() == cellValues[i];
res &= locres;
if (!locres) {
log.println("Result differs for cell (" +
cellCoords[i].X + "," + cellCoords[i].Y +
")");
log.println("Expected: " + cellValues[i]);
log.println("Getting: " +
oSheet.getCellByPosition(cellCoords[i].X,
cellCoords[i].Y)
.getValue());
}
} catch (com.sun.star.lang.IndexOutOfBoundsException e) {
log.println("Exception while checking Values " +
e.getMessage());
res &= false;
}
}
return res;
}
/**
* Restores initial component text.
*/
protected void after() {
disposeEnvironment();
}
}