1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir package ifc.sheet;
28*cdf0e10cSrcweir 
29*cdf0e10cSrcweir import com.sun.star.sheet.XCalculatable;
30*cdf0e10cSrcweir import com.sun.star.table.XCell;
31*cdf0e10cSrcweir import lib.MultiMethodTest;
32*cdf0e10cSrcweir import lib.Status;
33*cdf0e10cSrcweir import lib.StatusException;
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir /**
36*cdf0e10cSrcweir  *
37*cdf0e10cSrcweir  */
38*cdf0e10cSrcweir public class _XCalculatable extends MultiMethodTest {
39*cdf0e10cSrcweir     public XCalculatable oObj = null;
40*cdf0e10cSrcweir     private boolean bIsAutomaticCalculationEnabled = false;
41*cdf0e10cSrcweir     private XCell[] xCells = null;
42*cdf0e10cSrcweir 
43*cdf0e10cSrcweir     /**
44*cdf0e10cSrcweir      * Get object relation: four cells with values and formulas.
45*cdf0e10cSrcweir      * @see mod._sc.ScModelObj
46*cdf0e10cSrcweir      */
47*cdf0e10cSrcweir     public void before() {
48*cdf0e10cSrcweir         xCells = (XCell[])tEnv.getObjRelation("XCalculatable.Cells");
49*cdf0e10cSrcweir         if (xCells == null || xCells.length != 3)
50*cdf0e10cSrcweir             throw new StatusException(Status.failed("Couldn't find correct object relation 'XCalculatable.Cells'"));
51*cdf0e10cSrcweir 
52*cdf0e10cSrcweir     }
53*cdf0e10cSrcweir 
54*cdf0e10cSrcweir     /**
55*cdf0e10cSrcweir      * Restore begin setting
56*cdf0e10cSrcweir      */
57*cdf0e10cSrcweir     public void after() {
58*cdf0e10cSrcweir         // reset to begin value
59*cdf0e10cSrcweir         oObj.enableAutomaticCalculation(bIsAutomaticCalculationEnabled);
60*cdf0e10cSrcweir     }
61*cdf0e10cSrcweir 
62*cdf0e10cSrcweir 
63*cdf0e10cSrcweir     public void _calculate() {
64*cdf0e10cSrcweir         requiredMethod("isAutomaticCalculationEnabled()");
65*cdf0e10cSrcweir         boolean result = true;
66*cdf0e10cSrcweir         double ergValue1 = xCells[2].getValue();
67*cdf0e10cSrcweir         double sourceValue1 = xCells[0].getValue();
68*cdf0e10cSrcweir         xCells[0].setValue(sourceValue1 +1);
69*cdf0e10cSrcweir         double ergValue2 = xCells[2].getValue();
70*cdf0e10cSrcweir         result &= ergValue1 == ergValue2;
71*cdf0e10cSrcweir         oObj.calculate();
72*cdf0e10cSrcweir         ergValue2 = xCells[2].getValue();
73*cdf0e10cSrcweir         result &= ergValue1 != ergValue2;
74*cdf0e10cSrcweir         tRes.tested("calculate()", result);
75*cdf0e10cSrcweir     }
76*cdf0e10cSrcweir 
77*cdf0e10cSrcweir     public void _calculateAll() {
78*cdf0e10cSrcweir         requiredMethod("isAutomaticCalculationEnabled()");
79*cdf0e10cSrcweir         boolean result = true;
80*cdf0e10cSrcweir         double ergValue1 = xCells[2].getValue();
81*cdf0e10cSrcweir         double sourceValue1 = xCells[0].getValue();
82*cdf0e10cSrcweir         xCells[0].setValue(sourceValue1 +1);
83*cdf0e10cSrcweir         double ergValue2 = xCells[2].getValue();
84*cdf0e10cSrcweir         result &= ergValue1 == ergValue2;
85*cdf0e10cSrcweir         oObj.calculateAll();
86*cdf0e10cSrcweir         ergValue2 = xCells[2].getValue();
87*cdf0e10cSrcweir         result &= ergValue1 != ergValue2;
88*cdf0e10cSrcweir         oObj.calculateAll();
89*cdf0e10cSrcweir         tRes.tested("calculateAll()", result);
90*cdf0e10cSrcweir     }
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir     public void _enableAutomaticCalculation() {
93*cdf0e10cSrcweir         bIsAutomaticCalculationEnabled = oObj.isAutomaticCalculationEnabled();
94*cdf0e10cSrcweir         oObj.enableAutomaticCalculation(!bIsAutomaticCalculationEnabled);
95*cdf0e10cSrcweir         tRes.tested("enableAutomaticCalculation()", true);
96*cdf0e10cSrcweir     }
97*cdf0e10cSrcweir 
98*cdf0e10cSrcweir     public void _isAutomaticCalculationEnabled() {
99*cdf0e10cSrcweir         requiredMethod("enableAutomaticCalculation()");
100*cdf0e10cSrcweir         boolean result = oObj.isAutomaticCalculationEnabled();
101*cdf0e10cSrcweir         oObj.enableAutomaticCalculation(false);
102*cdf0e10cSrcweir         tRes.tested("isAutomaticCalculationEnabled()", result != bIsAutomaticCalculationEnabled);
103*cdf0e10cSrcweir     }
104*cdf0e10cSrcweir 
105*cdf0e10cSrcweir }
106