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