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.table;
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski import lib.MultiMethodTest;
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski import com.sun.star.sheet.XCellRangeAddressable;
29*b1cdbd2cSJim Jagielski import com.sun.star.sheet.XSheetCellCursor;
30*b1cdbd2cSJim Jagielski import com.sun.star.sheet.XSheetCellRange;
31*b1cdbd2cSJim Jagielski import com.sun.star.sheet.XSpreadsheet;
32*b1cdbd2cSJim Jagielski import com.sun.star.table.CellRangeAddress;
33*b1cdbd2cSJim Jagielski import com.sun.star.table.XCellCursor;
34*b1cdbd2cSJim Jagielski import com.sun.star.table.XCellRange;
35*b1cdbd2cSJim Jagielski import com.sun.star.uno.UnoRuntime;
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski /**
38*b1cdbd2cSJim Jagielski * Testing <code>com.sun.star.table.XCellCursor</code>
39*b1cdbd2cSJim Jagielski * interface methods :
40*b1cdbd2cSJim Jagielski * <ul>
41*b1cdbd2cSJim Jagielski *  <li><code> gotoStart()</code></li>
42*b1cdbd2cSJim Jagielski *  <li><code> gotoEnd()</code></li>
43*b1cdbd2cSJim Jagielski *  <li><code> gotoNext()</code></li>
44*b1cdbd2cSJim Jagielski *  <li><code> gotoPrevious()</code></li>
45*b1cdbd2cSJim Jagielski *  <li><code> gotoOffset()</code></li>
46*b1cdbd2cSJim Jagielski * </ul> <p>
47*b1cdbd2cSJim Jagielski * This test needs the following object relations :
48*b1cdbd2cSJim Jagielski * <ul>
49*b1cdbd2cSJim Jagielski *  <li> <code>'SHEET'</code> (of type <code>XSpreadsheet</code>):
50*b1cdbd2cSJim Jagielski *   is used for creating a new cell range.</li>
51*b1cdbd2cSJim Jagielski * <ul> <p>
52*b1cdbd2cSJim Jagielski *
53*b1cdbd2cSJim Jagielski * The component tested <b>must implement</b>
54*b1cdbd2cSJim Jagielski * <code>XCellRangeAddressable</code> interface. <p>
55*b1cdbd2cSJim Jagielski *
56*b1cdbd2cSJim Jagielski * Test is <b> NOT </b> multithread compilant. <p>
57*b1cdbd2cSJim Jagielski * After test completion object environment has to be recreated.
58*b1cdbd2cSJim Jagielski * @see com.sun.star.table.XCellCursor
59*b1cdbd2cSJim Jagielski */
60*b1cdbd2cSJim Jagielski public class _XCellCursor extends MultiMethodTest {
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski     public static XCellCursor oObj = null;
63*b1cdbd2cSJim Jagielski     public static XSpreadsheet oSheet = null;
64*b1cdbd2cSJim Jagielski 
65*b1cdbd2cSJim Jagielski     /**
66*b1cdbd2cSJim Jagielski      * <code>XCellRangeAddressable</code> interface is queried
67*b1cdbd2cSJim Jagielski      * first for getting current position of cursor. The cursor
68*b1cdbd2cSJim Jagielski      * is moved to next cell. Address of cursor obtained before
69*b1cdbd2cSJim Jagielski      * and after moving. <p>
70*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if cursor column is changed after
71*b1cdbd2cSJim Jagielski      * movement. <p>
72*b1cdbd2cSJim Jagielski      */
_gotoNext()73*b1cdbd2cSJim Jagielski     public void _gotoNext(){
74*b1cdbd2cSJim Jagielski         boolean bResult = false;
75*b1cdbd2cSJim Jagielski         int startCol, endCol, startRow, endRow = 0;
76*b1cdbd2cSJim Jagielski         int startCol2, endCol2, startRow2, endRow2 = 0;
77*b1cdbd2cSJim Jagielski 
78*b1cdbd2cSJim Jagielski         XCellRangeAddressable oRange = (XCellRangeAddressable)
79*b1cdbd2cSJim Jagielski             UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
80*b1cdbd2cSJim Jagielski         CellRangeAddress oAddr = oRange.getRangeAddress();
81*b1cdbd2cSJim Jagielski         startRow = oAddr.StartRow;
82*b1cdbd2cSJim Jagielski         startCol = oAddr.StartColumn;
83*b1cdbd2cSJim Jagielski         endRow = oAddr.EndRow;
84*b1cdbd2cSJim Jagielski         endCol = oAddr.EndColumn;
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski         oObj.gotoNext();
87*b1cdbd2cSJim Jagielski 
88*b1cdbd2cSJim Jagielski         oAddr = oRange.getRangeAddress();
89*b1cdbd2cSJim Jagielski         startRow2 = oAddr.StartRow;
90*b1cdbd2cSJim Jagielski         startCol2 = oAddr.StartColumn;
91*b1cdbd2cSJim Jagielski         endRow2 = oAddr.EndRow;
92*b1cdbd2cSJim Jagielski         endCol2 = oAddr.EndColumn;
93*b1cdbd2cSJim Jagielski 
94*b1cdbd2cSJim Jagielski         if (!(startCol == startCol2)){
95*b1cdbd2cSJim Jagielski             bResult = true;
96*b1cdbd2cSJim Jagielski         }
97*b1cdbd2cSJim Jagielski         tRes.tested( "gotoNext()", bResult );
98*b1cdbd2cSJim Jagielski     }
99*b1cdbd2cSJim Jagielski 
100*b1cdbd2cSJim Jagielski     /**
101*b1cdbd2cSJim Jagielski      * <code>XCellRangeAddressable</code> interface is queried
102*b1cdbd2cSJim Jagielski      * first for getting current position of cursor. The cursor
103*b1cdbd2cSJim Jagielski      * is moved then. Address of cursor obtained before
104*b1cdbd2cSJim Jagielski      * and after moving. <p>
105*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if starting column and row of
106*b1cdbd2cSJim Jagielski      * cursor is changed after movement. <p>
107*b1cdbd2cSJim Jagielski      */
_gotoOffset()108*b1cdbd2cSJim Jagielski     public void _gotoOffset(){
109*b1cdbd2cSJim Jagielski         boolean bResult = false;
110*b1cdbd2cSJim Jagielski         int startCol, endCol, startRow, endRow = 0;
111*b1cdbd2cSJim Jagielski         int startCol2, endCol2, startRow2, endRow2 = 0;
112*b1cdbd2cSJim Jagielski 
113*b1cdbd2cSJim Jagielski         XCellRangeAddressable oRange = (XCellRangeAddressable)
114*b1cdbd2cSJim Jagielski             UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
115*b1cdbd2cSJim Jagielski         CellRangeAddress oAddr = oRange.getRangeAddress();
116*b1cdbd2cSJim Jagielski         startRow = oAddr.StartRow;
117*b1cdbd2cSJim Jagielski         startCol = oAddr.StartColumn;
118*b1cdbd2cSJim Jagielski         endRow = oAddr.EndRow;
119*b1cdbd2cSJim Jagielski         endCol = oAddr.EndColumn;
120*b1cdbd2cSJim Jagielski 
121*b1cdbd2cSJim Jagielski         oObj.gotoOffset(4,4);
122*b1cdbd2cSJim Jagielski 
123*b1cdbd2cSJim Jagielski         oAddr = oRange.getRangeAddress();
124*b1cdbd2cSJim Jagielski         startRow2 = oAddr.StartRow;
125*b1cdbd2cSJim Jagielski         startCol2 = oAddr.StartColumn;
126*b1cdbd2cSJim Jagielski         endRow2 = oAddr.EndRow;
127*b1cdbd2cSJim Jagielski         endCol2 = oAddr.EndColumn;
128*b1cdbd2cSJim Jagielski         if (!(startCol == startCol2) || (startRow == startRow2)){
129*b1cdbd2cSJim Jagielski             bResult = true;
130*b1cdbd2cSJim Jagielski         }
131*b1cdbd2cSJim Jagielski         tRes.tested( "gotoOffset()", bResult );
132*b1cdbd2cSJim Jagielski     }
133*b1cdbd2cSJim Jagielski 
134*b1cdbd2cSJim Jagielski     /**
135*b1cdbd2cSJim Jagielski      * <code>XCellRangeAddressable</code> interface is queried
136*b1cdbd2cSJim Jagielski      * first for getting current position of cursor. The cursor
137*b1cdbd2cSJim Jagielski      * is moved to previous cell. Address of cursor obtained before
138*b1cdbd2cSJim Jagielski      * and after moving. <p>
139*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if cursor column is changed after
140*b1cdbd2cSJim Jagielski      * movement. <p>
141*b1cdbd2cSJim Jagielski      */
_gotoPrevious()142*b1cdbd2cSJim Jagielski     public void _gotoPrevious(){
143*b1cdbd2cSJim Jagielski         boolean bResult = false;
144*b1cdbd2cSJim Jagielski         int startCol, endCol, startRow, endRow = 0;
145*b1cdbd2cSJim Jagielski         int startCol2, endCol2, startRow2, endRow2 = 0;
146*b1cdbd2cSJim Jagielski 
147*b1cdbd2cSJim Jagielski         XCellRangeAddressable oRange = (XCellRangeAddressable)
148*b1cdbd2cSJim Jagielski                   UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
149*b1cdbd2cSJim Jagielski         CellRangeAddress oAddr = oRange.getRangeAddress();
150*b1cdbd2cSJim Jagielski         startRow = oAddr.StartRow;
151*b1cdbd2cSJim Jagielski         startCol = oAddr.StartColumn;
152*b1cdbd2cSJim Jagielski         endRow = oAddr.EndRow;
153*b1cdbd2cSJim Jagielski         endCol = oAddr.EndColumn;
154*b1cdbd2cSJim Jagielski 
155*b1cdbd2cSJim Jagielski         oObj.gotoPrevious();
156*b1cdbd2cSJim Jagielski 
157*b1cdbd2cSJim Jagielski         oAddr = oRange.getRangeAddress();
158*b1cdbd2cSJim Jagielski         startRow2 = oAddr.StartRow;
159*b1cdbd2cSJim Jagielski         startCol2 = oAddr.StartColumn;
160*b1cdbd2cSJim Jagielski         endRow2 = oAddr.EndRow;
161*b1cdbd2cSJim Jagielski         endCol2 = oAddr.EndColumn;
162*b1cdbd2cSJim Jagielski 
163*b1cdbd2cSJim Jagielski         if (!(startCol == startCol2)){
164*b1cdbd2cSJim Jagielski             bResult = true;
165*b1cdbd2cSJim Jagielski         }
166*b1cdbd2cSJim Jagielski         tRes.tested( "gotoPrevious()", bResult );
167*b1cdbd2cSJim Jagielski     }
168*b1cdbd2cSJim Jagielski 
169*b1cdbd2cSJim Jagielski     /**
170*b1cdbd2cSJim Jagielski      * <code>XCellRangeAddressable</code> interface is queried
171*b1cdbd2cSJim Jagielski      * first for getting current position of cursor. The cursor
172*b1cdbd2cSJim Jagielski      * is moved to the start of its range .
173*b1cdbd2cSJim Jagielski      * Address of cursor obtained before and after moving. <p>
174*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if cursor was collapsed to a single
175*b1cdbd2cSJim Jagielski      * cell (i.e. start column is the same as end column) after
176*b1cdbd2cSJim Jagielski      * movement. <p>
177*b1cdbd2cSJim Jagielski      */
_gotoStart()178*b1cdbd2cSJim Jagielski     public void _gotoStart(){
179*b1cdbd2cSJim Jagielski         boolean bResult = false;
180*b1cdbd2cSJim Jagielski         int startCol, endCol, startRow, endRow = 0;
181*b1cdbd2cSJim Jagielski 
182*b1cdbd2cSJim Jagielski         XCellRangeAddressable oRange = (XCellRangeAddressable)
183*b1cdbd2cSJim Jagielski                 UnoRuntime.queryInterface(XCellRangeAddressable.class, oObj);
184*b1cdbd2cSJim Jagielski         oObj.gotoStart();
185*b1cdbd2cSJim Jagielski         CellRangeAddress oAddr = oRange.getRangeAddress();
186*b1cdbd2cSJim Jagielski         startRow = oAddr.StartRow;
187*b1cdbd2cSJim Jagielski         startCol = oAddr.StartColumn;
188*b1cdbd2cSJim Jagielski         endRow = oAddr.EndRow;
189*b1cdbd2cSJim Jagielski         endCol = oAddr.EndColumn;
190*b1cdbd2cSJim Jagielski         if ((startCol == endCol) && (endRow == startRow)){
191*b1cdbd2cSJim Jagielski             bResult = true;
192*b1cdbd2cSJim Jagielski         }
193*b1cdbd2cSJim Jagielski 
194*b1cdbd2cSJim Jagielski         tRes.tested( "gotoStart()", bResult );
195*b1cdbd2cSJim Jagielski     }
196*b1cdbd2cSJim Jagielski 
197*b1cdbd2cSJim Jagielski     /**
198*b1cdbd2cSJim Jagielski      * A new cell range is created using spreadsheet passed by relation.
199*b1cdbd2cSJim Jagielski      * The method is tested on that range. <code>gotoEnd</code> is
200*b1cdbd2cSJim Jagielski      * called and range address is checked.<p>
201*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if cursor was collapsed to a single
202*b1cdbd2cSJim Jagielski      * cell (i.e. start column is the same as end column) after
203*b1cdbd2cSJim Jagielski      * movement. <p>
204*b1cdbd2cSJim Jagielski      */
_gotoEnd()205*b1cdbd2cSJim Jagielski     public void _gotoEnd(){
206*b1cdbd2cSJim Jagielski         //gotoEnd gets it's own cursor to see a change
207*b1cdbd2cSJim Jagielski         oSheet = (XSpreadsheet) tEnv.getObjRelation("SHEET");
208*b1cdbd2cSJim Jagielski         XCellRange testRange = oSheet.getCellRangeByName("$A$1:$g$7") ;
209*b1cdbd2cSJim Jagielski         XSheetCellRange testSheetRange = (XSheetCellRange)
210*b1cdbd2cSJim Jagielski                     UnoRuntime.queryInterface(XSheetCellRange.class,testRange);
211*b1cdbd2cSJim Jagielski         XSheetCellCursor oCellCursor = oSheet.createCursorByRange
212*b1cdbd2cSJim Jagielski             (testSheetRange);
213*b1cdbd2cSJim Jagielski         XCellCursor oCursor = (XCellCursor)
214*b1cdbd2cSJim Jagielski             UnoRuntime.queryInterface(XCellCursor.class,oCellCursor);
215*b1cdbd2cSJim Jagielski 
216*b1cdbd2cSJim Jagielski         boolean bResult = false;
217*b1cdbd2cSJim Jagielski         int startCol, endCol, startRow, endRow = 0;
218*b1cdbd2cSJim Jagielski 
219*b1cdbd2cSJim Jagielski         XCellRangeAddressable oRange = (XCellRangeAddressable)
220*b1cdbd2cSJim Jagielski             UnoRuntime.queryInterface(XCellRangeAddressable.class, oCursor);
221*b1cdbd2cSJim Jagielski         oCursor.gotoEnd();
222*b1cdbd2cSJim Jagielski         CellRangeAddress oAddr = oRange.getRangeAddress();
223*b1cdbd2cSJim Jagielski         startRow = oAddr.StartRow;
224*b1cdbd2cSJim Jagielski         startCol = oAddr.StartColumn;
225*b1cdbd2cSJim Jagielski         endRow = oAddr.EndRow;
226*b1cdbd2cSJim Jagielski         endCol = oAddr.EndColumn;
227*b1cdbd2cSJim Jagielski         if ((startCol == endCol) && (endRow == startRow)){
228*b1cdbd2cSJim Jagielski             bResult = true;
229*b1cdbd2cSJim Jagielski         }
230*b1cdbd2cSJim Jagielski 
231*b1cdbd2cSJim Jagielski         tRes.tested( "gotoEnd()", bResult );
232*b1cdbd2cSJim Jagielski     }
233*b1cdbd2cSJim Jagielski 
234*b1cdbd2cSJim Jagielski     /**
235*b1cdbd2cSJim Jagielski     * Forces object environment recreation.
236*b1cdbd2cSJim Jagielski     */
after()237*b1cdbd2cSJim Jagielski     protected void after() {
238*b1cdbd2cSJim Jagielski         disposeEnvironment();
239*b1cdbd2cSJim Jagielski     }
240*b1cdbd2cSJim Jagielski 
241*b1cdbd2cSJim Jagielski 
242*b1cdbd2cSJim Jagielski } //EOC _XCellCursor
243*b1cdbd2cSJim Jagielski 
244