forked from amazingfate/loongoffice
197 lines
7.8 KiB
Java
197 lines
7.8 KiB
Java
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* 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 .
|
|
*/
|
|
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 = UnoRuntime.queryInterface(XDrawPageSupplier.class, oObj);
|
|
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 = 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 = 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 = UnoRuntime.queryInterface(XPropertySet.class, xAddress);
|
|
Object o = xPropertySet.getPropertyValue("Validation");
|
|
XPropertySet xValidation = 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(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 that 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 = UnoRuntime.queryInterface(XShape.class, o);
|
|
System.out.println("Shape Type: " + xShape.getShapeType());
|
|
}
|
|
catch(com.sun.star.uno.Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
}
|