1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski package ifc.sheet;
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski import lib.MultiMethodTest;
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski import com.sun.star.beans.PropertyValue;
29*b1cdbd2cSJim Jagielski import com.sun.star.sheet.ConditionOperator;
30*b1cdbd2cSJim Jagielski import com.sun.star.sheet.XSheetConditionalEntries;
31*b1cdbd2cSJim Jagielski import com.sun.star.table.CellAddress;
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski /**
34*b1cdbd2cSJim Jagielski * Testing <code>com.sun.star.sheet.XSheetConditionalEntries</code>
35*b1cdbd2cSJim Jagielski * interface methods :
36*b1cdbd2cSJim Jagielski * <ul>
37*b1cdbd2cSJim Jagielski *  <li><code> addNew()</code></li>
38*b1cdbd2cSJim Jagielski *  <li><code> removeByIndex()</code></li>
39*b1cdbd2cSJim Jagielski *  <li><code> clear()</code></li>
40*b1cdbd2cSJim Jagielski * </ul> <p>
41*b1cdbd2cSJim Jagielski * @see com.sun.star.sheet.XSheetConditionalEntries
42*b1cdbd2cSJim Jagielski */
43*b1cdbd2cSJim Jagielski public class _XSheetConditionalEntries extends MultiMethodTest {
44*b1cdbd2cSJim Jagielski     public XSheetConditionalEntries oObj = null;
45*b1cdbd2cSJim Jagielski     int nNum = 0;
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski     /**
48*b1cdbd2cSJim Jagielski     * Test adds a conditional entry to the format. <p>
49*b1cdbd2cSJim Jagielski     * Has <b> OK </b> status if the method successfully returns. <p>
50*b1cdbd2cSJim Jagielski     */
_addNew()51*b1cdbd2cSJim Jagielski     public void _addNew() {
52*b1cdbd2cSJim Jagielski         nNum = oObj.getCount();
53*b1cdbd2cSJim Jagielski         oObj.addNew( Conditions(4) );
54*b1cdbd2cSJim Jagielski         boolean res = (nNum + 1) == oObj.getCount();
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski         tRes.tested("addNew()", res);
57*b1cdbd2cSJim Jagielski     }
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski     /**
60*b1cdbd2cSJim Jagielski     * Test calls the method and checks number of conditional entries in
61*b1cdbd2cSJim Jagielski     * collection. <p>
62*b1cdbd2cSJim Jagielski     * Has <b> OK </b> status if number of conditional entries in co0llection
63*b1cdbd2cSJim Jagielski     * after method call is equal zero. <p>
64*b1cdbd2cSJim Jagielski     * The following method tests are to be completed successfully before :
65*b1cdbd2cSJim Jagielski     * <ul>
66*b1cdbd2cSJim Jagielski     *  <li> <code> addNew() </code> : to have one conditional entry in
67*b1cdbd2cSJim Jagielski     *  collection at least </li>
68*b1cdbd2cSJim Jagielski     * </ul>
69*b1cdbd2cSJim Jagielski     */
_clear()70*b1cdbd2cSJim Jagielski     public void _clear() {
71*b1cdbd2cSJim Jagielski         requiredMethod("removeByIndex()");
72*b1cdbd2cSJim Jagielski         oObj.clear();
73*b1cdbd2cSJim Jagielski         int anz = oObj.getCount();
74*b1cdbd2cSJim Jagielski         tRes.tested("clear()", anz == 0);
75*b1cdbd2cSJim Jagielski     }
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski     /**
78*b1cdbd2cSJim Jagielski     * Test adds a conditional entry, removes entry with index 0
79*b1cdbd2cSJim Jagielski     * and compares number of entries after adding to number of entries after
80*b1cdbd2cSJim Jagielski     * removing. <p>
81*b1cdbd2cSJim Jagielski     * Has <b> OK </b> status if number of entries after adding is greater
82*b1cdbd2cSJim Jagielski     * than number of entries after removing. <p>
83*b1cdbd2cSJim Jagielski     * The following method tests are to be completed successfully before :
84*b1cdbd2cSJim Jagielski     * <ul>
85*b1cdbd2cSJim Jagielski     *  <li> <code> clear() </code> : to be sure that collection hasn't
86*b1cdbd2cSJim Jagielski     *  elements </li>
87*b1cdbd2cSJim Jagielski     * </ul>
88*b1cdbd2cSJim Jagielski     */
_removeByIndex()89*b1cdbd2cSJim Jagielski     public void _removeByIndex() {
90*b1cdbd2cSJim Jagielski         requiredMethod("addNew()");
91*b1cdbd2cSJim Jagielski         oObj.removeByIndex(0);
92*b1cdbd2cSJim Jagielski         int pastNum = oObj.getCount();
93*b1cdbd2cSJim Jagielski         tRes.tested("removeByIndex()", pastNum == nNum);
94*b1cdbd2cSJim Jagielski     }
95*b1cdbd2cSJim Jagielski 
96*b1cdbd2cSJim Jagielski     /**
97*b1cdbd2cSJim Jagielski     * Method creates array of property value for conditional entry using
98*b1cdbd2cSJim Jagielski     * passed parameter <code>nr</code>.
99*b1cdbd2cSJim Jagielski     * @param nr number of row for conditional entry
100*b1cdbd2cSJim Jagielski     */
Conditions(int nr)101*b1cdbd2cSJim Jagielski     protected PropertyValue[] Conditions(int nr) {
102*b1cdbd2cSJim Jagielski         PropertyValue[] con = new PropertyValue[5];
103*b1cdbd2cSJim Jagielski         CellAddress ca = new CellAddress();
104*b1cdbd2cSJim Jagielski         ca.Column = 1;
105*b1cdbd2cSJim Jagielski         ca.Row = 5;
106*b1cdbd2cSJim Jagielski         ca.Sheet = 0;
107*b1cdbd2cSJim Jagielski         con[0] = new PropertyValue();
108*b1cdbd2cSJim Jagielski         con[0].Name = "StyleName";
109*b1cdbd2cSJim Jagielski         con[0].Value = "Result2";
110*b1cdbd2cSJim Jagielski         con[1] = new PropertyValue();
111*b1cdbd2cSJim Jagielski         con[1].Name = "Formula1";
112*b1cdbd2cSJim Jagielski         con[1].Value = "$Sheet1.$B$"+nr;
113*b1cdbd2cSJim Jagielski         con[2] = new PropertyValue();
114*b1cdbd2cSJim Jagielski         con[2].Name = "Formula2";
115*b1cdbd2cSJim Jagielski         con[2].Value = "";
116*b1cdbd2cSJim Jagielski         con[3] = new PropertyValue();
117*b1cdbd2cSJim Jagielski         con[3].Name = "Operator";
118*b1cdbd2cSJim Jagielski         con[3].Value = ConditionOperator.EQUAL;
119*b1cdbd2cSJim Jagielski         con[4] = new PropertyValue();
120*b1cdbd2cSJim Jagielski         con[4].Name = "SourcePosition";
121*b1cdbd2cSJim Jagielski         con[4].Value = ca;
122*b1cdbd2cSJim Jagielski         return con;
123*b1cdbd2cSJim Jagielski     }
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski     /**
126*b1cdbd2cSJim Jagielski     * Forces object environment recreation.
127*b1cdbd2cSJim Jagielski     */
after()128*b1cdbd2cSJim Jagielski     protected void after() {
129*b1cdbd2cSJim Jagielski         this.disposeEnvironment();
130*b1cdbd2cSJim Jagielski     }
131*b1cdbd2cSJim Jagielski }  // finish class _XSheetConditionalEntries
132*b1cdbd2cSJim Jagielski 
133*b1cdbd2cSJim Jagielski 
134