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 import lib.Status; 32*cdf0e10cSrcweir import lib.StatusException; 33*cdf0e10cSrcweir import util.ValueComparer; 34*cdf0e10cSrcweir 35*cdf0e10cSrcweir import com.sun.star.sheet.XSheetAnnotation; 36*cdf0e10cSrcweir import com.sun.star.table.CellAddress; 37*cdf0e10cSrcweir import com.sun.star.text.XSimpleText; 38*cdf0e10cSrcweir import com.sun.star.uno.UnoRuntime; 39*cdf0e10cSrcweir 40*cdf0e10cSrcweir /** 41*cdf0e10cSrcweir * Testing <code>com.sun.star.sheet.XSheetAnnotation</code> 42*cdf0e10cSrcweir * interface methods : 43*cdf0e10cSrcweir * <ul> 44*cdf0e10cSrcweir * <li><code> getPosition()</code></li> 45*cdf0e10cSrcweir * <li><code> getAuthor()</code></li> 46*cdf0e10cSrcweir * <li><code> getDate()</code></li> 47*cdf0e10cSrcweir * <li><code> getIsVisible()</code></li> 48*cdf0e10cSrcweir * <li><code> setIsVisible()</code></li> 49*cdf0e10cSrcweir * </ul> <p> 50*cdf0e10cSrcweir * This test needs the following object relations : 51*cdf0e10cSrcweir * <ul> 52*cdf0e10cSrcweir * <li> <code>'CELLPOS'</code> (of type 53*cdf0e10cSrcweir * <code>com.sun.star.table.CellAddress</code>): 54*cdf0e10cSrcweir * The position of cell with annotation. </li> 55*cdf0e10cSrcweir * <ul> <p> 56*cdf0e10cSrcweir * Test is <b> NOT </b> multithread compilant. <p> 57*cdf0e10cSrcweir * @see com.sun.star.sheet.XSheetAnnotation 58*cdf0e10cSrcweir */ 59*cdf0e10cSrcweir public class _XSheetAnnotation extends MultiMethodTest { 60*cdf0e10cSrcweir 61*cdf0e10cSrcweir public XSheetAnnotation oObj = null; 62*cdf0e10cSrcweir 63*cdf0e10cSrcweir /** 64*cdf0e10cSrcweir * Gets the author of annotation. <p> 65*cdf0e10cSrcweir * Has <b>OK</b> status if not null value returned. 66*cdf0e10cSrcweir */ 67*cdf0e10cSrcweir public void _getAuthor() { 68*cdf0e10cSrcweir String author = oObj.getAuthor(); 69*cdf0e10cSrcweir tRes.tested("getAuthor()", author != null); 70*cdf0e10cSrcweir } 71*cdf0e10cSrcweir 72*cdf0e10cSrcweir /** 73*cdf0e10cSrcweir * Gets the modification date of annotation. <p> 74*cdf0e10cSrcweir * Has <b>OK</b> status if not null value returned. 75*cdf0e10cSrcweir */ 76*cdf0e10cSrcweir public void _getDate() { 77*cdf0e10cSrcweir String date = oObj.getDate(); 78*cdf0e10cSrcweir tRes.tested("getDate()", date != null); 79*cdf0e10cSrcweir } 80*cdf0e10cSrcweir 81*cdf0e10cSrcweir /** 82*cdf0e10cSrcweir * Sets the string of annotation, then makes it visible and 83*cdf0e10cSrcweir * checks the value returned by <code>getIsVisible</code> method. <p> 84*cdf0e10cSrcweir * Has <b>OK</b> status if the method returns <code>true</code>. 85*cdf0e10cSrcweir */ 86*cdf0e10cSrcweir public void _getIsVisible() { 87*cdf0e10cSrcweir XSimpleText oText = (XSimpleText) 88*cdf0e10cSrcweir UnoRuntime.queryInterface(XSimpleText.class, oObj); 89*cdf0e10cSrcweir oText.setString("XSheetAnnotation"); 90*cdf0e10cSrcweir oObj.setIsVisible(true); 91*cdf0e10cSrcweir boolean bVis = oObj.getIsVisible(); 92*cdf0e10cSrcweir tRes.tested("getIsVisible()", bVis); 93*cdf0e10cSrcweir } 94*cdf0e10cSrcweir 95*cdf0e10cSrcweir /** 96*cdf0e10cSrcweir * Gets the position of annotated cell and compares it to 97*cdf0e10cSrcweir * the position passed as relation. <p> 98*cdf0e10cSrcweir * Has <b>OK</b> status if these positions are equal and not 99*cdf0e10cSrcweir * null. 100*cdf0e10cSrcweir */ 101*cdf0e10cSrcweir public void _getPosition() { 102*cdf0e10cSrcweir boolean bResult = false; 103*cdf0e10cSrcweir CellAddress sCAddr = (CellAddress) tEnv.getObjRelation("CELLPOS") ; 104*cdf0e10cSrcweir if (sCAddr == null) throw new StatusException(Status.failed 105*cdf0e10cSrcweir ("Relation 'CELLPOS' not found")); 106*cdf0e10cSrcweir 107*cdf0e10cSrcweir CellAddress oCAddr = oObj.getPosition(); 108*cdf0e10cSrcweir 109*cdf0e10cSrcweir bResult = (oCAddr != null) && (sCAddr != null) && 110*cdf0e10cSrcweir ValueComparer.equalValue(oCAddr, sCAddr) ; 111*cdf0e10cSrcweir 112*cdf0e10cSrcweir tRes.tested("getPosition()", bResult); 113*cdf0e10cSrcweir } 114*cdf0e10cSrcweir 115*cdf0e10cSrcweir /** 116*cdf0e10cSrcweir * Sets the string of annotation, makes it hidden and then 117*cdf0e10cSrcweir * visible. Visibility is checked in both cases. <p> 118*cdf0e10cSrcweir * Has <b>OK</b> status if the <code>getIsVisible</code> method 119*cdf0e10cSrcweir * returns <code>flase</code> in the first case and <code>true</code> 120*cdf0e10cSrcweir * in the second. 121*cdf0e10cSrcweir */ 122*cdf0e10cSrcweir public void _setIsVisible() { 123*cdf0e10cSrcweir boolean bResult = true; 124*cdf0e10cSrcweir XSimpleText oText = (XSimpleText) 125*cdf0e10cSrcweir UnoRuntime.queryInterface(XSimpleText.class, oObj); 126*cdf0e10cSrcweir oText.setString("XSheetAnnotation"); 127*cdf0e10cSrcweir oObj.setIsVisible(false); 128*cdf0e10cSrcweir boolean bVis = oObj.getIsVisible(); 129*cdf0e10cSrcweir if (!bVis) { 130*cdf0e10cSrcweir oObj.setIsVisible(true); 131*cdf0e10cSrcweir bVis = oObj.getIsVisible(); 132*cdf0e10cSrcweir if (bVis) { 133*cdf0e10cSrcweir bResult = true; 134*cdf0e10cSrcweir } 135*cdf0e10cSrcweir } 136*cdf0e10cSrcweir 137*cdf0e10cSrcweir tRes.tested("setIsVisible()", bResult); 138*cdf0e10cSrcweir } 139*cdf0e10cSrcweir 140*cdf0e10cSrcweir } // EOC _XSheetAnnotation 141*cdf0e10cSrcweir 142