2 * This file is part of the LibreOffice project.
4 * This Source Code Form is subject to the terms of the Mozilla Public
5 * License, v. 2.0. If a copy of the MPL was not distributed with this
6 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 * This file incorporates work covered by the following license notice:
10 * Licensed to the Apache Software Foundation (ASF) under one or more
11 * contributor license agreements. See the NOTICE file distributed
12 * with this work for additional information regarding copyright
13 * ownership. The ASF licenses this file to you under the Apache
14 * License, Version 2.0 (the "License"); you may not use this file
15 * except in compliance with the License. You may obtain a copy of
16 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
21 import lib
.MultiMethodTest
;
23 import com
.sun
.star
.table
.XCell
;
24 import com
.sun
.star
.text
.XTextTableCursor
;
28 * Testing <code>com.sun.star.text.XTextTableCursor</code>
31 * <li><code> getRangeName()</code></li>
32 * <li><code> gotoCellByName()</code></li>
33 * <li><code> goLeft()</code></li>
34 * <li><code> goRight()</code></li>
35 * <li><code> goUp()</code></li>
36 * <li><code> goDown()</code></li>
37 * <li><code> gotoStart()</code></li>
38 * <li><code> gotoEnd()</code></li>
39 * <li><code> mergeRange()</code></li>
40 * <li><code> splitRange()</code></li>
43 * <b>Prerequisites : </b> the table must have a size
44 * 2x2 and current cursor position must be in the upper
47 * Test is <b> NOT </b> multithread compliant. <p>
49 * After test completion object environment has to be recreated
50 * because after merging and splitting cells their names
51 * differ from initial.
53 * @see com.sun.star.text.XTextTableCursor
55 public class _XTextTableCursor
extends MultiMethodTest
{
57 public XTextTableCursor oObj
= null; // oObj filled by MultiMethodTest
62 * Moves the cursor to upper-left cell and checks
65 * Has <b>OK</b> status if the name returned is 'A1'.
67 public void _getRangeName(){
68 log
.println( "test for getRangeName()" );
69 oObj
.gotoStart(false);
70 String oCellName
= oObj
.getRangeName();
71 log
.println( "CellName = " + oCellName
);
73 tRes
.tested("getRangeName()", oCellName
.equals("A1") );
77 * Calls the method which moves the cursor down by 1 cell,
78 * after that returns cursor to the old position. <p>
80 * Has <b>OK</b> status if the method returns
83 public void _goDown(){
84 boolean bDown
= false;
85 log
.println( "test for goDown()" );
88 bDown
= oObj
.goDown(i
,false);
90 tRes
.tested("goDown()", bDown
);
95 * Calls the method which moves the cursor to the right by 1 cell,
96 * after that returns cursor to the old position. <p>
98 * Has <b>OK</b> status if the method returns
101 public void _goRight(){
102 boolean bRight
= false;
103 log
.println( "test for goRight()" );
106 bRight
= oObj
.goRight(i
,false);
108 tRes
.tested("goRight()", bRight
);
109 oObj
.goLeft(i
,false);
113 * Calls the method which moves the cursor to the left by 1 cell,
114 * after that returns cursor to the old position. <p>
116 * Has <b>OK</b> status if the method returns
119 public void _goLeft(){
120 boolean bLeft
= false;
121 log
.println( "test for goLeft()" );
124 oObj
.goRight(i
,false);
125 bLeft
= oObj
.goLeft(i
,false);
127 tRes
.tested("goLeft()", bLeft
);
131 * Calls the method which moves the cursor up by 1 cell,
132 * after that returns cursor to the old position. <p>
134 * Has <b>OK</b> status if the method returns
139 log
.println( "test for goUp()" );
144 bUp
= oObj
.goUp(i
,false);
145 tRes
.tested("goUp()", bUp
);
149 * Moves the cursor to the cell with name 'B1', then
150 * checks the current range name. <p>
151 * Has <b>OK</b> status if the returned range name is
154 public void _gotoCellByName(){
155 log
.println( "test for gotoCellByName()" );
157 oObj
.gotoCellByName("B1",false);
158 String oCellName
= oObj
.getRangeName();
160 tRes
.tested("gotoCellByName()", oCellName
.equals("B1") );
164 * Moves cursor to the start (upper-left cell). Then
165 * checks the current range name. <p>
167 * Has <b>OK</b> status if current range name is 'A1'.
169 public void _gotoStart(){
170 log
.println( "test for gotoStart()" );
172 oObj
.gotoStart(false);
173 String oCellName
= oObj
.getRangeName();
175 tRes
.tested("gotoStart()", oCellName
.equals("A1") );
179 * Moves cursor to the end (lower-right cell). Then
180 * checks the current range name. <p>
182 * Has <b>OK</b> status if current range name is 'B2'
183 * (the table is assumed to be of size 2x2).
185 public void _gotoEnd(){
186 log
.println( "test for gotoEnd()" );
189 String oCellName
= oObj
.getRangeName();
191 tRes
.tested("gotoEnd()", oCellName
.equals("B2") );
195 * Selects all cells in the table and merges them.
196 * Finally move the cursor to the end and checks
197 * current range name.<p>
199 * Has <b>OK</b> status if the end cell has a name
202 * The following method tests are to be executed before :
204 * <li> <code> getRangeName(), gotoStart(), gotoEnd()
205 * goLeft(), goRight(), goUp(), goDown(), gotoCellByName()</code>
206 * : these methods must be completed before all cells of the
207 * table are merged into one cell </li>
210 public void _mergeRange(){
211 executeMethod("getRangeName()") ;
212 executeMethod("gotoStart()") ;
213 executeMethod("gotoEnd()") ;
214 executeMethod("goLeft()") ;
215 executeMethod("goRight()") ;
216 executeMethod("goUp()") ;
217 executeMethod("goDown()") ;
218 executeMethod("gotoCellByName()") ;
220 boolean bMerge
= false;
221 log
.println( "test for mergeRange()" );
223 oObj
.gotoStart(false);
225 bMerge
= oObj
.mergeRange();
229 String curName
= oObj
.getRangeName() ;
230 bMerge
&= "A1".equals(curName
) ;
232 tRes
.tested("mergeRange()", bMerge
);
236 * First splits the cell horyzontally. Then the end cell
237 * name is checked. Second split all cells vertically and
238 * again the end cell name is checked<p>
240 * Has <b> OK </b> status if in the first case the end cell name
241 * is not 'A1', and in the second case the end cell name is not
242 * equal to the name gotten in the first case. <p>
244 * The following method tests are to be completed successfully before :
246 * <li> <code> mergeRange() </code> : to have one cell in a table
247 * which this test splits. </li>
250 public void _splitRange(){
251 requiredMethod("mergeRange()") ;
253 boolean bSplit
= true ;
254 log
.println( "test for splitRange" ) ;
257 bSplit
&= oObj
.splitRange(i
, true) ;
260 String horName
= oObj
.getRangeName() ;
261 log
.println("The end cell after horiz. split : " + horName
) ;
262 bSplit
&= !"A1".equals(horName
) ;
264 oObj
.gotoStart(false);
266 bSplit
&= oObj
.splitRange(i
, false) ;
269 String vertName
= oObj
.getRangeName() ;
270 log
.println("The end cell after vert. split : " + vertName
) ;
271 bSplit
&= !horName
.equals(vertName
) ;
273 tRes
.tested("splitRange()", bSplit
) ;
277 * Forces object environment recreation.
280 public void after() {
281 disposeEnvironment() ;
284 } // finish class _XTextTableCursor