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 package ifc.sheet; 28*cdf0e10cSrcweir 29*cdf0e10cSrcweir import com.sun.star.sheet.SheetLinkMode; 30*cdf0e10cSrcweir import com.sun.star.sheet.XSheetLinkable; 31*cdf0e10cSrcweir import lib.MultiMethodTest; 32*cdf0e10cSrcweir import util.utils; 33*cdf0e10cSrcweir 34*cdf0e10cSrcweir /** 35*cdf0e10cSrcweir * 36*cdf0e10cSrcweir */ 37*cdf0e10cSrcweir public class _XSheetLinkable extends MultiMethodTest { 38*cdf0e10cSrcweir public XSheetLinkable oObj = null; 39*cdf0e10cSrcweir SheetLinkMode slm = null; 40*cdf0e10cSrcweir String linkSheetName = null; 41*cdf0e10cSrcweir String linkUrl = null; 42*cdf0e10cSrcweir String linkUrl2 = null; 43*cdf0e10cSrcweir 44*cdf0e10cSrcweir public void before() { 45*cdf0e10cSrcweir // get a document for linking. 46*cdf0e10cSrcweir linkUrl = (String)tEnv.getObjRelation("XSheetLinkable.LinkSheet"); 47*cdf0e10cSrcweir linkUrl = utils.getFullTestURL(linkUrl); 48*cdf0e10cSrcweir 49*cdf0e10cSrcweir // get a second sheet for changing the link url: if it's not set, 50*cdf0e10cSrcweir // this part of the test is omitted. 51*cdf0e10cSrcweir linkUrl2 = (String)tEnv.getObjRelation("XSheetLinkable.LinkSheet2"); 52*cdf0e10cSrcweir if (linkUrl2 != null) 53*cdf0e10cSrcweir linkUrl = utils.getFullTestURL(linkUrl); 54*cdf0e10cSrcweir 55*cdf0e10cSrcweir // set a name for the sheet. 56*cdf0e10cSrcweir linkSheetName = "Sheet1"; 57*cdf0e10cSrcweir } 58*cdf0e10cSrcweir 59*cdf0e10cSrcweir public void _getLinkMode() { 60*cdf0e10cSrcweir requiredMethod("link()"); 61*cdf0e10cSrcweir slm = oObj.getLinkMode(); 62*cdf0e10cSrcweir tRes.tested("getLinkMode()", slm == SheetLinkMode.VALUE); 63*cdf0e10cSrcweir } 64*cdf0e10cSrcweir 65*cdf0e10cSrcweir public void _getLinkSheetName() { 66*cdf0e10cSrcweir requiredMethod("link()"); 67*cdf0e10cSrcweir String lSheetName = oObj.getLinkSheetName(); 68*cdf0e10cSrcweir tRes.tested("getLinkSheetName()", linkSheetName.equals(lSheetName)); 69*cdf0e10cSrcweir } 70*cdf0e10cSrcweir 71*cdf0e10cSrcweir public void _getLinkUrl() { 72*cdf0e10cSrcweir requiredMethod("link()"); 73*cdf0e10cSrcweir String lUrl = oObj.getLinkUrl(); 74*cdf0e10cSrcweir System.out.println("URL: " + lUrl); 75*cdf0e10cSrcweir tRes.tested("getLinkUrl()", lUrl.equals(linkUrl)); 76*cdf0e10cSrcweir } 77*cdf0e10cSrcweir 78*cdf0e10cSrcweir public void _link() { 79*cdf0e10cSrcweir oObj.link(linkUrl, linkSheetName, "", "", SheetLinkMode.VALUE); 80*cdf0e10cSrcweir tRes.tested("link()", true); 81*cdf0e10cSrcweir } 82*cdf0e10cSrcweir 83*cdf0e10cSrcweir public void _setLinkMode() { 84*cdf0e10cSrcweir requiredMethod("getLinkMode()"); 85*cdf0e10cSrcweir oObj.setLinkMode(SheetLinkMode.NONE); 86*cdf0e10cSrcweir slm = oObj.getLinkMode(); 87*cdf0e10cSrcweir tRes.tested("setLinkMode()", slm == SheetLinkMode.NONE); 88*cdf0e10cSrcweir } 89*cdf0e10cSrcweir 90*cdf0e10cSrcweir public void _setLinkSheetName() { 91*cdf0e10cSrcweir requiredMethod("getLinkSheetName()"); 92*cdf0e10cSrcweir oObj.setLinkSheetName("Sheet2"); 93*cdf0e10cSrcweir linkSheetName = oObj.getLinkSheetName(); 94*cdf0e10cSrcweir tRes.tested("setLinkSheetName()", linkSheetName.equals("Sheet2")); 95*cdf0e10cSrcweir } 96*cdf0e10cSrcweir 97*cdf0e10cSrcweir public void _setLinkUrl() { 98*cdf0e10cSrcweir requiredMethod("getLinkUrl()"); 99*cdf0e10cSrcweir boolean result = false; 100*cdf0e10cSrcweir if (linkUrl2 == null) { 101*cdf0e10cSrcweir // set back to the original value 102*cdf0e10cSrcweir oObj.setLinkUrl(linkUrl); 103*cdf0e10cSrcweir result = true; 104*cdf0e10cSrcweir } 105*cdf0e10cSrcweir else { 106*cdf0e10cSrcweir oObj.setLinkUrl(linkUrl2); 107*cdf0e10cSrcweir linkUrl = oObj.getLinkUrl(); 108*cdf0e10cSrcweir result = linkUrl.equals(linkUrl2); 109*cdf0e10cSrcweir } 110*cdf0e10cSrcweir tRes.tested("setLinkUrl()", result); 111*cdf0e10cSrcweir } 112*cdf0e10cSrcweir } 113