211 lines
7.2 KiB
Java
211 lines
7.2 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.table;
|
|
|
|
import lib.MultiMethodTest;
|
|
|
|
import com.sun.star.sheet.XCellRangeAddressable;
|
|
import com.sun.star.sheet.XSheetCellCursor;
|
|
import com.sun.star.sheet.XSheetCellRange;
|
|
import com.sun.star.sheet.XSpreadsheet;
|
|
import com.sun.star.table.CellRangeAddress;
|
|
import com.sun.star.table.XCellCursor;
|
|
import com.sun.star.table.XCellRange;
|
|
import com.sun.star.uno.UnoRuntime;
|
|
|
|
/**
|
|
* Testing <code>com.sun.star.table.XCellCursor</code>
|
|
* interface methods :
|
|
* <ul>
|
|
* <li><code> gotoStart()</code></li>
|
|
* <li><code> gotoEnd()</code></li>
|
|
* <li><code> gotoNext()</code></li>
|
|
* <li><code> gotoPrevious()</code></li>
|
|
* <li><code> gotoOffset()</code></li>
|
|
* </ul> <p>
|
|
* This test needs the following object relations :
|
|
* <ul>
|
|
* <li> <code>'SHEET'</code> (of type <code>XSpreadsheet</code>):
|
|
* is used for creating a new cell range.</li>
|
|
* <ul> <p>
|
|
*
|
|
* The component tested <b>must implement</b>
|
|
* <code>XCellRangeAddressable</code> interface. <p>
|
|
*
|
|
* Test is <b> NOT </b> multithread compliant. <p>
|
|
* After test completion object environment has to be recreated.
|
|
* @see com.sun.star.table.XCellCursor
|
|
*/
|
|
public class _XCellCursor extends MultiMethodTest {
|
|
|
|
public XCellCursor oObj = null;
|
|
|
|
/**
|
|
* <code>XCellRangeAddressable</code> interface is queried
|
|
* first for getting current position of cursor. The cursor
|
|
* is moved to next cell. Address of cursor obtained before
|
|
* and after moving. <p>
|
|
* Has <b> OK </b> status if cursor column is changed after
|
|
* movement. <p>
|
|
*/
|
|
public void _gotoNext(){
|
|
boolean bResult = false;
|
|
int startCol;
|
|
int startCol2;
|
|
|
|
XCellRangeAddressable oRange = UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
|
|
CellRangeAddress oAddr = oRange.getRangeAddress();
|
|
startCol = oAddr.StartColumn;
|
|
oObj.gotoNext();
|
|
|
|
oAddr = oRange.getRangeAddress();
|
|
startCol2 = oAddr.StartColumn;
|
|
if (startCol != startCol2){
|
|
bResult = true;
|
|
}
|
|
tRes.tested( "gotoNext()", bResult );
|
|
}
|
|
|
|
/**
|
|
* <code>XCellRangeAddressable</code> interface is queried
|
|
* first for getting current position of cursor. The cursor
|
|
* is moved then. Address of cursor obtained before
|
|
* and after moving. <p>
|
|
* Has <b> OK </b> status if starting column and row of
|
|
* cursor is changed after movement. <p>
|
|
*/
|
|
public void _gotoOffset(){
|
|
boolean bResult = false;
|
|
int startCol, startRow;
|
|
int startCol2, startRow2;
|
|
|
|
XCellRangeAddressable oRange = UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
|
|
CellRangeAddress oAddr = oRange.getRangeAddress();
|
|
startRow = oAddr.StartRow;
|
|
startCol = oAddr.StartColumn;
|
|
oObj.gotoOffset(4,4);
|
|
|
|
oAddr = oRange.getRangeAddress();
|
|
startRow2 = oAddr.StartRow;
|
|
startCol2 = oAddr.StartColumn;
|
|
if ((startCol != startCol2) || (startRow == startRow2)){
|
|
bResult = true;
|
|
}
|
|
tRes.tested( "gotoOffset()", bResult );
|
|
}
|
|
|
|
/**
|
|
* <code>XCellRangeAddressable</code> interface is queried
|
|
* first for getting current position of cursor. The cursor
|
|
* is moved to previous cell. Address of cursor obtained before
|
|
* and after moving. <p>
|
|
* Has <b> OK </b> status if cursor column is changed after
|
|
* movement. <p>
|
|
*/
|
|
public void _gotoPrevious(){
|
|
boolean bResult = false;
|
|
int startCol;
|
|
int startCol2;
|
|
|
|
XCellRangeAddressable oRange = UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
|
|
CellRangeAddress oAddr = oRange.getRangeAddress();
|
|
startCol = oAddr.StartColumn;
|
|
oObj.gotoPrevious();
|
|
|
|
oAddr = oRange.getRangeAddress();
|
|
startCol2 = oAddr.StartColumn;
|
|
if (startCol != startCol2){
|
|
bResult = true;
|
|
}
|
|
tRes.tested( "gotoPrevious()", bResult );
|
|
}
|
|
|
|
/**
|
|
* <code>XCellRangeAddressable</code> interface is queried
|
|
* first for getting current position of cursor. The cursor
|
|
* is moved to the start of its range .
|
|
* Address of cursor obtained before and after moving. <p>
|
|
* Has <b> OK </b> status if cursor was collapsed to a single
|
|
* cell (i.e. start column is the same as end column) after
|
|
* movement. <p>
|
|
*/
|
|
public void _gotoStart(){
|
|
boolean bResult = false;
|
|
int startCol, endCol, startRow, endRow = 0;
|
|
|
|
XCellRangeAddressable oRange = UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
|
|
oObj.gotoStart();
|
|
CellRangeAddress oAddr = oRange.getRangeAddress();
|
|
startRow = oAddr.StartRow;
|
|
startCol = oAddr.StartColumn;
|
|
endRow = oAddr.EndRow;
|
|
endCol = oAddr.EndColumn;
|
|
if ((startCol == endCol) && (endRow == startRow)){
|
|
bResult = true;
|
|
}
|
|
|
|
tRes.tested( "gotoStart()", bResult );
|
|
}
|
|
|
|
/**
|
|
* A new cell range is created using spreadsheet passed by relation.
|
|
* The method is tested on that range. <code>gotoEnd</code> is
|
|
* called and range address is checked.<p>
|
|
* Has <b> OK </b> status if cursor was collapsed to a single
|
|
* cell (i.e. start column is the same as end column) after
|
|
* movement. <p>
|
|
*/
|
|
public void _gotoEnd(){
|
|
//gotoEnd gets it's own cursor to see a change
|
|
XSpreadsheet oSheet = (XSpreadsheet) tEnv.getObjRelation("SHEET");
|
|
XCellRange testRange = oSheet.getCellRangeByName("$A$1:$g$7") ;
|
|
XSheetCellRange testSheetRange = UnoRuntime.queryInterface(XSheetCellRange.class,testRange);
|
|
XSheetCellCursor oCellCursor = oSheet.createCursorByRange
|
|
(testSheetRange);
|
|
XCellCursor oCursor = UnoRuntime.queryInterface(XCellCursor.class,oCellCursor);
|
|
|
|
boolean bResult = false;
|
|
int startCol, endCol, startRow, endRow = 0;
|
|
|
|
XCellRangeAddressable oRange = UnoRuntime.queryInterface(XCellRangeAddressable.class, oCursor);
|
|
oCursor.gotoEnd();
|
|
CellRangeAddress oAddr = oRange.getRangeAddress();
|
|
startRow = oAddr.StartRow;
|
|
startCol = oAddr.StartColumn;
|
|
endRow = oAddr.EndRow;
|
|
endCol = oAddr.EndColumn;
|
|
if ((startCol == endCol) && (endRow == startRow)){
|
|
bResult = true;
|
|
}
|
|
|
|
tRes.tested( "gotoEnd()", bResult );
|
|
}
|
|
|
|
/**
|
|
* Forces object environment recreation.
|
|
*/
|
|
@Override
|
|
protected void after() {
|
|
disposeEnvironment();
|
|
}
|
|
|
|
|
|
} //EOC _XCellCursor
|
|
|