1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 package mod._sc; 24 import java.io.PrintWriter; 25 26 import lib.StatusException; 27 import lib.TestCase; 28 import lib.TestEnvironment; 29 import lib.TestParameters; 30 import util.SOfficeFactory; 31 import util.ValueComparer; 32 33 import com.sun.star.beans.XPropertySet; 34 import com.sun.star.lang.XComponent; 35 import com.sun.star.lang.XMultiServiceFactory; 36 import com.sun.star.sheet.XSheetCellRange; 37 import com.sun.star.sheet.XSpreadsheet; 38 import com.sun.star.sheet.XSpreadsheetDocument; 39 import com.sun.star.sheet.XSpreadsheets; 40 import com.sun.star.table.XCell; 41 import com.sun.star.table.XCellRange; 42 import com.sun.star.uno.AnyConverter; 43 import com.sun.star.uno.Type; 44 import com.sun.star.uno.UnoRuntime; 45 import com.sun.star.uno.XInterface; 46 import ifc.sheet._XCellRangesQuery; 47 48 49 /** 50 * Test for object which is represented by service 51 * <code>com.sun.star.sheet.SheetCellCursor</code>. <p> 52 * Object implements the following interfaces : 53 * <ul> 54 * <li> <code>com::sun::star::style::ParagraphProperties</code></li> 55 * <li> <code>com::sun::star::sheet::XUsedAreaCursor</code></li> 56 * <li> <code>com::sun::star::table::CellProperties</code></li> 57 * <li> <code>com::sun::star::table::XCellRange</code></li> 58 * <li> <code>com::sun::star::sheet::XCellRangeAddressable</code></li> 59 * <li> <code>com::sun::star::table::XCellCursor</code></li> 60 * <li> <code>com::sun::star::sheet::XSheetCellCursor</code></li> 61 * <li> <code>com::sun::star::style::CharacterProperties</code></li> 62 * <li> <code>com::sun::star::sheet::XSheetOperation</code></li> 63 * <li> <code>com::sun::star::sheet::XArrayFormulaRange</code></li> 64 * <li> <code>com::sun::star::sheet::XSheetCellRange</code></li> 65 * <li> <code>com::sun::star::sheet::SheetCellRange</code></li> 66 * <li> <code>com::sun::star::chart::XChartData</code></li> 67 * <li> <code>com::sun::star::beans::XPropertySet</code></li> 68 * <li> <code>com::sun::star::util::XMergeable</code></li> 69 * <li> <code>com::sun::star::table::XColumnRowRange</code></li> 70 * </ul> 71 * @see com.sun.star.sheet.SheetCellCursor 72 * @see com.sun.star.style.ParagraphProperties 73 * @see com.sun.star.sheet.XUsedAreaCursor 74 * @see com.sun.star.table.CellProperties 75 * @see com.sun.star.table.XCellRange 76 * @see com.sun.star.sheet.XCellRangeAddressable 77 * @see com.sun.star.table.XCellCursor 78 * @see com.sun.star.sheet.XSheetCellCursor 79 * @see com.sun.star.style.CharacterProperties 80 * @see com.sun.star.sheet.XSheetOperation 81 * @see com.sun.star.sheet.XArrayFormulaRange 82 * @see com.sun.star.sheet.XSheetCellRange 83 * @see com.sun.star.sheet.SheetCellRange 84 * @see com.sun.star.chart.XChartData 85 * @see com.sun.star.beans.XPropertySet 86 * @see com.sun.star.util.XMergeable 87 * @see com.sun.star.table.XColumnRowRange 88 * @see ifc.style._ParagraphProperties 89 * @see ifc.sheet._XUsedAreaCursor 90 * @see ifc.table._CellProperties 91 * @see ifc.table._XCellRange 92 * @see ifc.sheet._XCellRangeAddressable 93 * @see ifc.table._XCellCursor 94 * @see ifc.sheet._XSheetCellCursor 95 * @see ifc.style._CharacterProperties 96 * @see ifc.sheet._XSheetOperation 97 * @see ifc.sheet._XArrayFormulaRange 98 * @see ifc.sheet._XSheetCellRange 99 * @see ifc.sheet._SheetCellRange 100 * @see ifc.chart._XChartData 101 * @see ifc.beans._XPropertySet 102 * @see ifc.util._XMergeable 103 * @see ifc.table._XColumnRowRange 104 */ 105 public class ScCellCursorObj extends TestCase { 106 static XSpreadsheetDocument xSheetDoc = null; 107 108 /** 109 * Creates Spreadsheet document. 110 */ 111 protected void initialize(TestParameters tParam, PrintWriter log) { 112 SOfficeFactory SOF = SOfficeFactory.getFactory( 113 (XMultiServiceFactory) tParam.getMSF()); 114 115 try { 116 log.println("creating a Spreadsheet document"); 117 xSheetDoc = SOF.createCalcDoc(null); 118 } catch (com.sun.star.uno.Exception e) { 119 // Some exception occures.FAILED 120 e.printStackTrace(log); 121 throw new StatusException("Couldn't create document", e); 122 } 123 } 124 125 /** 126 * Disposes Spreadsheet document. 127 */ 128 protected void cleanup(TestParameters tParam, PrintWriter log) { 129 log.println(" disposing xSheetDoc "); 130 131 XComponent oComp = (XComponent) UnoRuntime.queryInterface( 132 XComponent.class, xSheetDoc); 133 134 util.DesktopTools.closeDoc(oComp); 135 } 136 137 /** 138 * Creating a Testenvironment for the interfaces to be tested. 139 * Retrieves a collection of spreadsheets from a document, 140 * and takes one of them, retrieves some cell range and creates cursor range 141 * that is instance of the service 142 * <code>com.sun.star.sheet.SheetCellCursor</code>, 143 * fills some cells in the cell range. 144 * Object relations created : 145 * <ul> 146 * <li> <code>'SHEET'</code> for 147 * {@link ifc.table._XCellCursor}, 148 * {@link ifc.sheet._XArrayFormulaRange} (the spreadsheet that was 149 * retieved from collection)</li> 150 * </ul> 151 */ 152 protected synchronized TestEnvironment createTestEnvironment(TestParameters Param, 153 PrintWriter log) { 154 XInterface oObj = null; 155 TestEnvironment tEnv = null; 156 XSpreadsheet oSheet = null; 157 XCellRange testRange = null; 158 159 160 // creation of testobject here 161 // first we write what we are intend to do to log file 162 log.println("Creating a test environment"); 163 164 XSpreadsheets oSpreadsheets = ((XSpreadsheetDocument) UnoRuntime.queryInterface( 165 XSpreadsheetDocument.class, 166 xSheetDoc)).getSheets(); 167 168 try { 169 oSheet = (XSpreadsheet) AnyConverter.toObject( 170 new Type(XSpreadsheet.class), 171 oSpreadsheets.getByName( 172 oSpreadsheets.getElementNames()[0])); 173 174 testRange = oSheet.getCellRangeByName("$A$1:$D$4"); 175 176 XSheetCellRange testSheetRange = (XSheetCellRange) UnoRuntime.queryInterface( 177 XSheetCellRange.class, 178 testRange); 179 oObj = oSheet.createCursorByRange(testSheetRange); 180 oSheet.getCellByPosition(1, 1).setValue(1); 181 oSheet.getCellByPosition(4, 5).setValue(1); 182 oSheet.getCellByPosition(3, 2).setFormula("xTextDoc"); 183 oSheet.getCellByPosition(3, 3).setFormula("xTextDoc"); 184 } catch (com.sun.star.lang.WrappedTargetException e) { 185 log.println("Exception occured while creating test object:"); 186 e.printStackTrace(log); 187 throw new StatusException("Couldn't create test object", e); 188 } catch (com.sun.star.container.NoSuchElementException e) { 189 log.println("Exception occured while creating test object:"); 190 e.printStackTrace(log); 191 throw new StatusException("Couldn't create test object", e); 192 } catch (com.sun.star.lang.IndexOutOfBoundsException e) { 193 log.println("Exception occured while creating test object:"); 194 e.printStackTrace(log); 195 throw new StatusException("Couldn't create test object", e); 196 } catch (com.sun.star.lang.IllegalArgumentException e) { 197 log.println("Exception occured while creating test object:"); 198 e.printStackTrace(log); 199 throw new StatusException("Couldn't create test object", e); 200 } 201 202 log.println("Test object successfully created."); 203 204 tEnv = new TestEnvironment(oObj); 205 206 tEnv.addObjRelation("CRDESC", 207 "Column and RowDescriptions can't be changed for this Object"); 208 209 tEnv.addObjRelation("SHEET", oSheet); 210 // add expected results for the XCellRangesQuery interface test 211 String[]expectedResults = new String[7]; 212 expectedResults[_XCellRangesQuery.QUERYCOLUMNDIFFERENCES] = "Sheet1.B1"; 213 expectedResults[_XCellRangesQuery.QUERYCONTENTCELLS] = "Sheet1.B2"; 214 expectedResults[_XCellRangesQuery.QUERYEMPTYCELLS] = "Sheet1.A1 ... Sheet1.B1 ... Sheet1.B3 ... Sheet1.C1 ... Sheet1.D1"; 215 expectedResults[_XCellRangesQuery.QUERYFORMULACELLS] = ""; 216 expectedResults[_XCellRangesQuery.QUERYINTERSECTION] = "Sheet1.D4"; 217 expectedResults[_XCellRangesQuery.QUERYROWDIFFERENCES] = "Sheet1.A2;Sheet1.C2"; 218 expectedResults[_XCellRangesQuery.QUERYVISIBLECELLS] = "Sheet1.A2"; 219 tEnv.addObjRelation("XCellRangesQuery.EXPECTEDRESULTS", expectedResults); 220 221 tEnv.addObjRelation("NewData", 222 new Object[][] 223 { 224 { "", "", "", "" }, 225 { "", "2", "3", "4" }, 226 { "", "2", "3", "4" }, 227 { "", "2", "3", "4" } 228 }); 229 230 XPropertySet PropSet = (XPropertySet) UnoRuntime.queryInterface( 231 XPropertySet.class, oObj); 232 tEnv.addObjRelation("PropSet", PropSet); 233 234 //Adding relation for util.XSortable 235 final PrintWriter finalLog = log; 236 final XCellRange oTable = testRange; 237 tEnv.addObjRelation("SORTCHECKER", 238 new ifc.util._XSortable.XSortChecker() { 239 PrintWriter out = finalLog; 240 241 public void setPrintWriter(PrintWriter log) { 242 out = log; 243 } 244 245 public void prepareToSort() { 246 try { 247 oTable.getCellByPosition(0, 0).setValue(4); 248 oTable.getCellByPosition(0, 1).setFormula("b"); 249 oTable.getCellByPosition(0, 2).setValue(3); 250 oTable.getCellByPosition(0, 3).setValue(23); 251 } catch (com.sun.star.lang.IndexOutOfBoundsException e) { 252 out.println("Exception while checking sort"); 253 } 254 } 255 256 public boolean checkSort(boolean isSortNumbering, 257 boolean isSortAscending) { 258 out.println("Sort checking..."); 259 260 boolean res = false; 261 String[] value = new String[4]; 262 263 for (int i = 0; i < 4; i++) { 264 try { 265 XCell cell = oTable.getCellByPosition(0, i); 266 value[i] = cell.getFormula(); 267 } catch (com.sun.star.lang.IndexOutOfBoundsException e) { 268 out.println("Exception while checking sort"); 269 } 270 } 271 272 if (isSortNumbering) { 273 if (isSortAscending) { 274 out.println("Sorting ascending"); 275 276 String[] rightVal = { "3", "4", "23", "b" }; 277 String[] vals = { value[0], value[1], value[2], value[3] }; 278 res = ValueComparer.equalValue(vals, rightVal); 279 out.println("Expected 3, 4, 23, b"); 280 out.println("getting: " + value[0] + ", " + 281 value[1] + ", " + value[2] + ", " + 282 value[3]); 283 } else { 284 String[] rightVal = { "b", "23", "4", "3" }; 285 String[] vals = { value[0], value[1], value[2], value[3] }; 286 res = ValueComparer.equalValue(vals, rightVal); 287 out.println("Expected b, 23, 4, 3"); 288 out.println("getting: " + value[0] + ", " + 289 value[1] + ", " + value[2] + ", " + 290 value[3]); 291 } 292 } else { 293 if (isSortAscending) { 294 String[] rightVal = { "3", "4", "23", "b" }; 295 res = ValueComparer.equalValue(value, rightVal); 296 out.println("Expected 3, 4, 23, b"); 297 out.println("getting: " + value[0] + ", " + 298 value[1] + ", " + value[2] + ", " + 299 value[3]); 300 } else { 301 String[] rightVal = { "b", "23", "4", "3" }; 302 res = ValueComparer.equalValue(value, rightVal); 303 out.println("Expected b, 23, 4, 3"); 304 out.println("getting: " + value[0] + ", " + 305 value[1] + ", " + value[2] + ", " + 306 value[3]); 307 } 308 } 309 310 if (res) { 311 out.println("Sorted correctly"); 312 } else { 313 out.println("Sorted uncorrectly"); 314 } 315 316 return res; 317 } 318 }); 319 320 return tEnv; 321 } 322 } // finish class ScCellCursorObj 323