blob: edf47dc9f2f8de87151f34f7342e1a73a2f87e8d [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.beans.XPropertySet;
import com.sun.star.drawing.XDrawPage;
import com.sun.star.drawing.XDrawPageSupplier;
import com.sun.star.drawing.XShape;
import com.sun.star.sheet.ValidationType;
import com.sun.star.sheet.XSheetAuditing;
import com.sun.star.sheet.XSpreadsheet;
import com.sun.star.table.CellAddress;
import com.sun.star.table.XCell;
import com.sun.star.text.XText;
import com.sun.star.uno.UnoRuntime;
import lib.MultiMethodTest;
import lib.Status;
import lib.StatusException;
/**
*
*/
public class _XSheetAuditing extends MultiMethodTest {
public XSheetAuditing oObj = null;
CellAddress address = null;
CellAddress precedentAddress = null;
CellAddress dependentAddress = null;
XCell xAddress = null;
XCell xPrecedentAddress = null;
XCell xDependentAddress = null;
XDrawPage xDrawPage = null;
int elementCount = 0;
public void before() {
address = (CellAddress)tEnv.getObjRelation("XSheetAuditing.CellAddress");
precedentAddress = (CellAddress)tEnv.getObjRelation("XSheetAuditing.PrecedentCellAddress");
dependentAddress= (CellAddress)tEnv.getObjRelation("XSheetAuditing.DependentCellAddress");
if (address == null || precedentAddress == null || dependentAddress == null) {
throw new StatusException(Status.failed("Necessary CellAddress object relations not found."));
}
// get the draw page for checking the shapes
xDrawPage = (XDrawPage)tEnv.getObjRelation("XSheetAuditing.DrawPage");
if (xDrawPage == null) { // get from object
XDrawPageSupplier oDPS = (XDrawPageSupplier)
UnoRuntime.queryInterface(XDrawPageSupplier.class, oObj);
xDrawPage = (XDrawPage) oDPS.getDrawPage();
}
if (xDrawPage == null) {
throw new StatusException(Status.failed("'XSheetAuditing.DrawPage' object relation not found."));
}
if (xDrawPage.hasElements()) {
elementCount = xDrawPage.getCount();
}
// get a sheet for changing the cells
XSpreadsheet xSheet = (XSpreadsheet)tEnv.getObjRelation("XSheetAuditing.Spreadsheet");
if (xSheet == null) // query on ther object
xSheet = (XSpreadsheet)UnoRuntime.queryInterface(XSpreadsheet.class, oObj);
if (xSheet == null)
throw new StatusException(Status.failed("'XSheetAuditing.Spreadsheet' object relation not found."));
try {
xAddress = xSheet.getCellByPosition(address.Column, address.Row);
xDependentAddress = xSheet.getCellByPosition(dependentAddress.Column, dependentAddress.Row);
xPrecedentAddress = xSheet.getCellByPosition(precedentAddress.Column, precedentAddress.Row);
}
catch(com.sun.star.lang.IndexOutOfBoundsException e) {
throw new StatusException(Status.failed("Invalid cell addresses in object relations."));
}
}
public void _clearArrows() {
requiredMethod("hideDependents()");
boolean erg = false;
oObj.showDependents(address);
oObj.showPrecedents(address);
erg = hasRightAmountOfShapes(3);
oObj.clearArrows();
erg &= hasRightAmountOfShapes(0);
tRes.tested("clearArrows()", erg);
}
public void _hideDependents() {
requiredMethod("showDependents()");
oObj.hideDependents(address);
tRes.tested("hideDependents()", hasRightAmountOfShapes(0));
}
public void _hidePrecedents() {
requiredMethod("showPrecedents()");
// requiredMethod("showPrecedents()");
oObj.hidePrecedents(address);
tRes.tested("hidePrecedents()", hasRightAmountOfShapes(0));
}
public void _showDependents() {
requiredMethod("hidePrecedents()");
oObj.showDependents(address);
tRes.tested("showDependents()", hasRightAmountOfShapes(1));
}
public void _showErrors() {
requiredMethod("clearArrows()");
// construct an error: square root from -3
xPrecedentAddress.setValue(-9);
String cellAddress = new String(new byte[]{(byte)(precedentAddress.Column + 65)}) + (precedentAddress.Row+1);
xAddress.setFormula("=SQRT(" + cellAddress + ")");
XText xText = (XText)UnoRuntime.queryInterface(XText.class, xAddress);
// correct error in cell:
String error = xText.getString();
boolean erg = error.equals("Err:502");
log.println("Content: " + error);
oObj.showErrors(dependentAddress);
erg &= hasRightAmountOfShapes(2);
tRes.tested("showErrors()", erg);
}
public void _showInvalid() {
requiredMethod("showErrors()");
boolean result = true;
// insert a value
xAddress.setValue(2.5);
try {
// add a validitation to a cell: only whole numbers are allowed
XPropertySet xPropertySet = (XPropertySet)UnoRuntime.queryInterface(XPropertySet.class, xAddress);
Object o = xPropertySet.getPropertyValue("Validation");
XPropertySet xValidation = (XPropertySet)UnoRuntime.queryInterface(XPropertySet.class, o);
xValidation.setPropertyValue("Type", ValidationType.WHOLE);
xPropertySet.setPropertyValue("Validation", xValidation);
// test
oObj.showInvalid();
result = hasRightAmountOfShapes(1);
oObj.clearArrows();
result &= hasRightAmountOfShapes(0);
// revoke the validitation to a cell
xValidation.setPropertyValue("Type", ValidationType.ANY);
xPropertySet.setPropertyValue("Validation", xValidation);
// test again
oObj.showInvalid();
result &= hasRightAmountOfShapes(0);
}
catch(com.sun.star.uno.Exception e) {
e.printStackTrace((java.io.PrintWriter)log);
result = false;
}
tRes.tested("showInvalid()", result);
}
public void _showPrecedents() {
oObj.showPrecedents(address);
tRes.tested("showPrecedents()", hasRightAmountOfShapes(2));
}
/**
* Check if the amount of shapes is the right one after displaying that stuff
* 2do improve this: check taht the shapes are the correct ones -> convwatch
* @desiredValue That's the amount of shapes that have to be here.
* @return True, if the actual count of shapes is the same
*/
private boolean hasRightAmountOfShapes(int desiredValue) {
int newCount = xDrawPage.getCount();
if (newCount != elementCount + desiredValue) {
return false;
}
else {
if (desiredValue >= 0) {
for (int i=elementCount; i<newCount; i++) {
try {
Object o = xDrawPage.getByIndex(i);
XShape xShape = (XShape)UnoRuntime.queryInterface(XShape.class, o);
System.out.println("Shape Type: " + xShape.getShapeType());
}
catch(com.sun.star.uno.Exception e) {
e.printStackTrace();
}
}
}
}
return true;
}
}