1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir package ifc.sheet;
29*cdf0e10cSrcweir 
30*cdf0e10cSrcweir import lib.MultiMethodTest;
31*cdf0e10cSrcweir 
32*cdf0e10cSrcweir import com.sun.star.sheet.XAreaLink;
33*cdf0e10cSrcweir import com.sun.star.table.CellRangeAddress;
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir /**
36*cdf0e10cSrcweir * Testing <code>com.sun.star.sheet.XAreaLink</code>
37*cdf0e10cSrcweir * interface methods :
38*cdf0e10cSrcweir * <ul>
39*cdf0e10cSrcweir *  <li><code> getSourceArea()</code></li>
40*cdf0e10cSrcweir *  <li><code> setSourceArea()</code></li>
41*cdf0e10cSrcweir *  <li><code> getDestArea()</code></li>
42*cdf0e10cSrcweir *  <li><code> setDestArea()</code></li>
43*cdf0e10cSrcweir * </ul> <p>
44*cdf0e10cSrcweir * Test is <b> NOT </b> multithread compilant. <p>
45*cdf0e10cSrcweir * @see com.sun.star.sheet.XAreaLink
46*cdf0e10cSrcweir */
47*cdf0e10cSrcweir public class _XAreaLink extends MultiMethodTest {
48*cdf0e10cSrcweir 
49*cdf0e10cSrcweir     public XAreaLink oObj = null;
50*cdf0e10cSrcweir     CellRangeAddress oORAdd, oNRAdd, oCRAdd = null;
51*cdf0e10cSrcweir 
52*cdf0e10cSrcweir     /**
53*cdf0e10cSrcweir     * Just calls the method and checks the value returned.
54*cdf0e10cSrcweir     * (More complicated testing done in <code>setDestArea</code>)<p>
55*cdf0e10cSrcweir     * Has <b>OK</b> status if not null value returned.
56*cdf0e10cSrcweir     */
57*cdf0e10cSrcweir     public void _getDestArea(){
58*cdf0e10cSrcweir         log.println("testing getDestArea()");
59*cdf0e10cSrcweir         boolean bResult = false;
60*cdf0e10cSrcweir         oORAdd = oObj.getDestArea();
61*cdf0e10cSrcweir         if (!(oORAdd == null)){ bResult = true; }
62*cdf0e10cSrcweir         tRes.tested("getDestArea()", bResult) ;
63*cdf0e10cSrcweir     }
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir     /**
66*cdf0e10cSrcweir     * Just calls the method and checks the value returned.
67*cdf0e10cSrcweir     * (More complicated testing done in <code>setSourceArea</code>)<p>
68*cdf0e10cSrcweir     * Has <b>OK</b> status if not null value returned.
69*cdf0e10cSrcweir     */
70*cdf0e10cSrcweir     public void _getSourceArea(){
71*cdf0e10cSrcweir         log.println("testing getSourceArea()");
72*cdf0e10cSrcweir         boolean bResult = false;
73*cdf0e10cSrcweir         String src = null;
74*cdf0e10cSrcweir         src = oObj.getSourceArea() ;
75*cdf0e10cSrcweir         if (!(src == null)){ bResult = true; }
76*cdf0e10cSrcweir         tRes.tested("getSourceArea()", bResult) ;
77*cdf0e10cSrcweir     }
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir     /**
80*cdf0e10cSrcweir     * Creates a new desination CellRange address and sets it for
81*cdf0e10cSrcweir     * the link object. <p>
82*cdf0e10cSrcweir     * After setting the DestArea, the link is refreshed and the area is
83*cdf0e10cSrcweir     * adjusted to the size of the source data.
84*cdf0e10cSrcweir     * Therefore EndCol and EndRow will change after setting. <p>
85*cdf0e10cSrcweir     * Has <b>OK</b> status if Sheet, Starting Column and Row
86*cdf0e10cSrcweir     * of the destination range is changed correctly.
87*cdf0e10cSrcweir     */
88*cdf0e10cSrcweir     public void _setDestArea(){
89*cdf0e10cSrcweir         log.println("testing setDestArea()");
90*cdf0e10cSrcweir         boolean bResult = false;
91*cdf0e10cSrcweir         int newStartCol = 3, newStartRow = 4, newEndCol = 5, newEndRow = 8 ;
92*cdf0e10cSrcweir         oORAdd = oObj.getDestArea();
93*cdf0e10cSrcweir         log.print("Getting: ");
94*cdf0e10cSrcweir         log.println(getCRA(oORAdd));
95*cdf0e10cSrcweir         oNRAdd = new CellRangeAddress ((short) 2, newStartCol, newStartRow,
96*cdf0e10cSrcweir                                                     newEndCol, newEndRow) ;
97*cdf0e10cSrcweir         oObj.setDestArea(oNRAdd) ;
98*cdf0e10cSrcweir         log.print("Setting: ");
99*cdf0e10cSrcweir         log.println(getCRA(oNRAdd));
100*cdf0e10cSrcweir         oCRAdd = oObj.getDestArea();
101*cdf0e10cSrcweir         log.print("Getting: ");
102*cdf0e10cSrcweir         log.println(getCRA(oCRAdd));
103*cdf0e10cSrcweir         // After setting the DestArea, the link is refreshed and the area is
104*cdf0e10cSrcweir         // adjusted to the size of the source data.
105*cdf0e10cSrcweir         // Therefore EndCol and EndRow will change after setting.
106*cdf0e10cSrcweir         log.println("After setting the DestArea, the link is refreshed "+
107*cdf0e10cSrcweir             "and the area is");
108*cdf0e10cSrcweir         log.println("adjusted to the size of the source data.");
109*cdf0e10cSrcweir         log.println("Therefore only 'Sheet', 'StartCol' and 'StartRow' "+
110*cdf0e10cSrcweir             "are compared.");
111*cdf0e10cSrcweir         if ((oCRAdd.StartColumn == oNRAdd.StartColumn) &&
112*cdf0e10cSrcweir                 (oCRAdd.Sheet == oNRAdd.Sheet) &&
113*cdf0e10cSrcweir                 (oCRAdd.StartRow == oNRAdd.StartRow)){
114*cdf0e10cSrcweir             bResult = true;
115*cdf0e10cSrcweir             oObj.setDestArea(oORAdd);
116*cdf0e10cSrcweir         }
117*cdf0e10cSrcweir         tRes.tested("setDestArea()", bResult) ;
118*cdf0e10cSrcweir     }
119*cdf0e10cSrcweir 
120*cdf0e10cSrcweir     /**
121*cdf0e10cSrcweir     * Sets a new source area for the link and then check
122*cdf0e10cSrcweir     * it using <code>getSourceArea</code>  method. <p>
123*cdf0e10cSrcweir     * Has <b>OK</b> status if areas set and get are equal.
124*cdf0e10cSrcweir     */
125*cdf0e10cSrcweir     public void _setSourceArea(){
126*cdf0e10cSrcweir         log.println("testing setSourceArea()");
127*cdf0e10cSrcweir         boolean bResult = false;
128*cdf0e10cSrcweir         String oSrc = oObj.getSourceArea() ;
129*cdf0e10cSrcweir         String nSrc = "a1:b2";
130*cdf0e10cSrcweir         oObj.setSourceArea(nSrc);
131*cdf0e10cSrcweir         String cSrc = oObj.getSourceArea();
132*cdf0e10cSrcweir         if( nSrc.equals(cSrc)){
133*cdf0e10cSrcweir             bResult = true;
134*cdf0e10cSrcweir             oObj.setSourceArea(oSrc);
135*cdf0e10cSrcweir         }
136*cdf0e10cSrcweir         tRes.tested("setSourceArea()", bResult) ;
137*cdf0e10cSrcweir     }
138*cdf0e10cSrcweir 
139*cdf0e10cSrcweir     /**
140*cdf0e10cSrcweir     * Prints cell range structure to LOG
141*cdf0e10cSrcweir     */
142*cdf0e10cSrcweir     public String getCRA ( CellRangeAddress oCRA ) {
143*cdf0e10cSrcweir         String res = "( Sheet: ";
144*cdf0e10cSrcweir         res += oCRA.Sheet;
145*cdf0e10cSrcweir         res += ";StartColumn: ";
146*cdf0e10cSrcweir         res += oCRA.StartColumn;
147*cdf0e10cSrcweir         res += ";StartRow: ";
148*cdf0e10cSrcweir         res += oCRA.StartRow;
149*cdf0e10cSrcweir         res += ";EndColumn: ";
150*cdf0e10cSrcweir         res += oCRA.EndColumn;
151*cdf0e10cSrcweir         res += ";EndRow: ";
152*cdf0e10cSrcweir         res += oCRA.EndRow;
153*cdf0e10cSrcweir         res += " )";
154*cdf0e10cSrcweir         return res;
155*cdf0e10cSrcweir     }
156*cdf0e10cSrcweir 
157*cdf0e10cSrcweir } // EOC _XAreaLink
158*cdf0e10cSrcweir 
159*cdf0e10cSrcweir 
160