summaryrefslogtreecommitdiff
path: root/qadevOOo/tests/java/ifc/sheet/_XMultipleOperation.java
diff options
context:
space:
mode:
Diffstat (limited to 'qadevOOo/tests/java/ifc/sheet/_XMultipleOperation.java')
-rw-r--r--qadevOOo/tests/java/ifc/sheet/_XMultipleOperation.java185
1 files changed, 185 insertions, 0 deletions
diff --git a/qadevOOo/tests/java/ifc/sheet/_XMultipleOperation.java b/qadevOOo/tests/java/ifc/sheet/_XMultipleOperation.java
new file mode 100644
index 000000000000..db672d4f8a7b
--- /dev/null
+++ b/qadevOOo/tests/java/ifc/sheet/_XMultipleOperation.java
@@ -0,0 +1,185 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2008 by Sun Microsystems, Inc.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: _XMultipleOperation.java,v $
+ * $Revision: 1.5 $
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 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();
+ }
+} \ No newline at end of file