/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ package ifc.table; import lib.MultiMethodTest; import com.sun.star.table.XCell; import com.sun.star.table.XCellRange; /** * Testing com.sun.star.table.XCellRange * interface methods : *

* This test needs the following object relations : *

* Test is NOT multithread compilant.

* @see com.sun.star.table.XCellRange */ public class _XCellRange extends MultiMethodTest { public XCellRange oObj = null; /** * First a cell get from valid position, second - from invalid.

* Has OK status if in the first case not null value is * returned and no exceptions are thrown, and in the second * case IndexOutOfBoundsException is thrown.

*/ public void _getCellByPosition() { boolean result = false; try { XCell cell = oObj.getCellByPosition(0,0); result = cell != null ; log.println("Getting cell by position with a valid position ... OK"); } catch (com.sun.star.lang.IndexOutOfBoundsException e) { log.println("Exception occurred while getting cell by position with a valid position"); e.printStackTrace(log); result = false; } try { oObj.getCellByPosition(-1,1); log.println("No Exception occurred while getting cell by position with invalid position"); result &= false; } catch (com.sun.star.lang.IndexOutOfBoundsException e) { log.println("Getting cell by position with a invalid position ... OK"); result &= true; } tRes.tested( "getCellByPosition()", result ); } // end getCellByPosition() /** * A range is tried to obtain with valid name.

* Has OK status if not null range is * returned.

*/ public void _getCellRangeByName() { boolean result = false; String valid = (String) tEnv.getObjRelation("ValidRange"); if (valid == null ) valid = "A1:A1"; XCellRange range = oObj.getCellRangeByName(valid); result = range != null ; log.println("Getting cellrange by name with a valid name ... OK"); tRes.tested( "getCellRangeByName()", result ); } // end getCellRangeByName() /** * First a range is tried to obtain with valid bounds, * second - with invalid.

* Has OK status if in the first case not null range is * returned and no exceptions are thrown, and in the second * case IndexOutOfBoundsException is thrown.

*/ public void _getCellRangeByPosition() { boolean result = false; try { XCellRange range = oObj.getCellRangeByPosition(0,0,0,0); result = range != null; log.println("Getting cellrange by Position with a valid position ... OK"); } catch (com.sun.star.lang.IndexOutOfBoundsException e) { log.println("Exception occurred while getting cellrange by position with a valid position"); e.printStackTrace(log); result = false; } try { oObj.getCellRangeByPosition(-1,0,-1,1); log.println("No Exception occurred while getting cellrange by position with invalid position"); result &= false; } catch (com.sun.star.lang.IndexOutOfBoundsException e) { log.println("Getting cellrange by position with a invalid position ... OK"); result &= true; } tRes.tested( "getCellRangeByPosition()", result ); } // end getCellRangeByPosition() /** * Forces environment recreation. */ protected void after() { disposeEnvironment(); } } // finish class _XCellRange