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 com.sun.star.table.XCellRange;
27*b1cdbd2cSJim Jagielski import lib.MultiMethodTest;
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski import com.sun.star.table.XTableRows;
30*b1cdbd2cSJim Jagielski import lib.Status;
31*b1cdbd2cSJim Jagielski import lib.StatusException;
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski /**
34*b1cdbd2cSJim Jagielski * Testing <code>com.sun.star.table.XTableRows</code>
35*b1cdbd2cSJim Jagielski * interface methods :
36*b1cdbd2cSJim Jagielski * <ul>
37*b1cdbd2cSJim Jagielski *  <li><code> insertByIndex()</code></li>
38*b1cdbd2cSJim Jagielski *  <li><code> removeByIndex()</code></li>
39*b1cdbd2cSJim Jagielski * </ul>
40*b1cdbd2cSJim Jagielski */
41*b1cdbd2cSJim Jagielski public class _XTableRows extends MultiMethodTest {
42*b1cdbd2cSJim Jagielski 
43*b1cdbd2cSJim Jagielski     public XTableRows oObj = null;
44*b1cdbd2cSJim Jagielski     public XCellRange range = null;
45*b1cdbd2cSJim Jagielski 
before()46*b1cdbd2cSJim Jagielski     public void before() {
47*b1cdbd2cSJim Jagielski         range = (XCellRange) tEnv.getObjRelation("XTableRows.XCellRange");
48*b1cdbd2cSJim Jagielski         if (range==null) {
49*b1cdbd2cSJim Jagielski             throw new StatusException(Status.failed("ObjectRelation missing"));
50*b1cdbd2cSJim Jagielski         }
51*b1cdbd2cSJim Jagielski         try {
52*b1cdbd2cSJim Jagielski             range.getCellByPosition(0,0).setValue(17);
53*b1cdbd2cSJim Jagielski             range.getCellByPosition(0,1).setValue(15);
54*b1cdbd2cSJim Jagielski         } catch (com.sun.star.lang.IndexOutOfBoundsException e) {
55*b1cdbd2cSJim Jagielski             log.println("Couldn't set value for Cell A1");
56*b1cdbd2cSJim Jagielski         }
57*b1cdbd2cSJim Jagielski     }
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski     /**
60*b1cdbd2cSJim Jagielski      * First a row inserted to valid position, then to invalid. <p>
61*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if in the first case number of rows increases
62*b1cdbd2cSJim Jagielski      * by 1, and in the second an exception is thrown. <p>
63*b1cdbd2cSJim Jagielski      */
_insertByIndex()64*b1cdbd2cSJim Jagielski     public void _insertByIndex() {
65*b1cdbd2cSJim Jagielski 
66*b1cdbd2cSJim Jagielski         boolean result = true;
67*b1cdbd2cSJim Jagielski 
68*b1cdbd2cSJim Jagielski         requiredMethod("removeByIndex()");
69*b1cdbd2cSJim Jagielski 
70*b1cdbd2cSJim Jagielski         int origCnt = oObj.getCount();
71*b1cdbd2cSJim Jagielski         log.println("Inserting row before first row");
72*b1cdbd2cSJim Jagielski         oObj.insertByIndex(0,1);
73*b1cdbd2cSJim Jagielski         result &= checkCell(1,15);
74*b1cdbd2cSJim Jagielski         if (checkCell(1,15)) log.println("... successful");
75*b1cdbd2cSJim Jagielski 
76*b1cdbd2cSJim Jagielski         try {
77*b1cdbd2cSJim Jagielski             oObj.insertByIndex(-1,1);
78*b1cdbd2cSJim Jagielski             log.println("No Exception occurred while inserting row at -1");
79*b1cdbd2cSJim Jagielski             result &= false;
80*b1cdbd2cSJim Jagielski         } catch (Exception e) {
81*b1cdbd2cSJim Jagielski             log.println("Inserting row at Index -1 ... OK");
82*b1cdbd2cSJim Jagielski             result &= true;
83*b1cdbd2cSJim Jagielski         }
84*b1cdbd2cSJim Jagielski 
85*b1cdbd2cSJim Jagielski         tRes.tested( "insertByIndex()", result );
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski     } // end insertByIndex()
88*b1cdbd2cSJim Jagielski 
89*b1cdbd2cSJim Jagielski     /**
90*b1cdbd2cSJim Jagielski      * First a row removed from valid position, then from invalid. <p>
91*b1cdbd2cSJim Jagielski      *
92*b1cdbd2cSJim Jagielski      * Has <b> OK </b> status if in the first case number of columns decreases
93*b1cdbd2cSJim Jagielski      * by 1, and in the second an exception is thrown. <p>
94*b1cdbd2cSJim Jagielski      */
_removeByIndex()95*b1cdbd2cSJim Jagielski     public void _removeByIndex() {
96*b1cdbd2cSJim Jagielski 
97*b1cdbd2cSJim Jagielski         boolean result = true;
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski         oObj.removeByIndex(0,1);
100*b1cdbd2cSJim Jagielski         log.println("Removing first row");
101*b1cdbd2cSJim Jagielski         result &= checkCell(0,15);
102*b1cdbd2cSJim Jagielski         if (checkCell(0,15)) log.println("... successful");
103*b1cdbd2cSJim Jagielski 
104*b1cdbd2cSJim Jagielski         try {
105*b1cdbd2cSJim Jagielski             oObj.removeByIndex(-1,1);
106*b1cdbd2cSJim Jagielski             log.println("No Exception occurred while Removing row at -1");
107*b1cdbd2cSJim Jagielski             result &= false;
108*b1cdbd2cSJim Jagielski         } catch (Exception e) {
109*b1cdbd2cSJim Jagielski             log.println("Removing row at Index -1 ... OK");
110*b1cdbd2cSJim Jagielski             result &= true;
111*b1cdbd2cSJim Jagielski         }
112*b1cdbd2cSJim Jagielski 
113*b1cdbd2cSJim Jagielski         tRes.tested( "removeByIndex()", result );
114*b1cdbd2cSJim Jagielski     } // end removeByIndex()
115*b1cdbd2cSJim Jagielski 
checkCell(int row,double expected)116*b1cdbd2cSJim Jagielski     public boolean checkCell(int row,double expected) {
117*b1cdbd2cSJim Jagielski         double getting=0;
118*b1cdbd2cSJim Jagielski         try {
119*b1cdbd2cSJim Jagielski             getting = range.getCellByPosition(0,row).getValue();
120*b1cdbd2cSJim Jagielski         } catch (com.sun.star.lang.IndexOutOfBoundsException e) {
121*b1cdbd2cSJim Jagielski             log.println("Couldn't set value for Cell A1");
122*b1cdbd2cSJim Jagielski         }
123*b1cdbd2cSJim Jagielski 
124*b1cdbd2cSJim Jagielski         boolean res = (getting==expected);
125*b1cdbd2cSJim Jagielski         if (!res) {
126*b1cdbd2cSJim Jagielski             log.println("Expected for row "+row+" was "+expected);
127*b1cdbd2cSJim Jagielski             log.println("Getting for row "+row+" - "+getting);
128*b1cdbd2cSJim Jagielski             log.println("=> FAILED");
129*b1cdbd2cSJim Jagielski         }
130*b1cdbd2cSJim Jagielski         return res;
131*b1cdbd2cSJim Jagielski     }
132*b1cdbd2cSJim Jagielski 
133*b1cdbd2cSJim Jagielski } //finish class _XTableRows
134*b1cdbd2cSJim Jagielski 
135