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.text; 25*b1cdbd2cSJim Jagielski 26*b1cdbd2cSJim Jagielski import lib.MultiMethodTest; 27*b1cdbd2cSJim Jagielski import lib.Status; 28*b1cdbd2cSJim Jagielski import lib.StatusException; 29*b1cdbd2cSJim Jagielski 30*b1cdbd2cSJim Jagielski import com.sun.star.text.XTextTable; 31*b1cdbd2cSJim Jagielski 32*b1cdbd2cSJim Jagielski /** 33*b1cdbd2cSJim Jagielski * Testing <code>com.sun.star.text.XTextTable</code> 34*b1cdbd2cSJim Jagielski * interface methods : 35*b1cdbd2cSJim Jagielski * <ul> 36*b1cdbd2cSJim Jagielski * <li><code> initialize()</code></li> 37*b1cdbd2cSJim Jagielski * <li><code> getRows()</code></li> 38*b1cdbd2cSJim Jagielski * <li><code> getColumns()</code></li> 39*b1cdbd2cSJim Jagielski * <li><code> getCellByName()</code></li> 40*b1cdbd2cSJim Jagielski * <li><code> getCellNames()</code></li> 41*b1cdbd2cSJim Jagielski * <li><code> createCursorByCellName()</code></li> 42*b1cdbd2cSJim Jagielski * </ul> <p> 43*b1cdbd2cSJim Jagielski * This test needs the following object relations : 44*b1cdbd2cSJim Jagielski * <ul> 45*b1cdbd2cSJim Jagielski * <li> <code>'NROW'</code> : the number of rows in table 46*b1cdbd2cSJim Jagielski * </li> 47*b1cdbd2cSJim Jagielski * <li> <code>'NCOL'</code> : the number of columns in table 48*b1cdbd2cSJim Jagielski * </li> 49*b1cdbd2cSJim Jagielski * 50*b1cdbd2cSJim Jagielski * Test is <b> NOT </b> multithread compilant. <p> 51*b1cdbd2cSJim Jagielski * @see com.sun.star.text.XTextTable 52*b1cdbd2cSJim Jagielski */ 53*b1cdbd2cSJim Jagielski public class _XTextTable extends MultiMethodTest { 54*b1cdbd2cSJim Jagielski 55*b1cdbd2cSJim Jagielski public XTextTable oObj = null; // oObj filled by MultiMethodTest 56*b1cdbd2cSJim Jagielski int nRow; 57*b1cdbd2cSJim Jagielski int nCol; 58*b1cdbd2cSJim Jagielski 59*b1cdbd2cSJim Jagielski String cellNamesList[] = null ; 60*b1cdbd2cSJim Jagielski before()61*b1cdbd2cSJim Jagielski protected void before() { 62*b1cdbd2cSJim Jagielski Integer num_row = (Integer)tEnv.getObjRelation("NROW"); 63*b1cdbd2cSJim Jagielski if (num_row == null) { 64*b1cdbd2cSJim Jagielski throw new StatusException 65*b1cdbd2cSJim Jagielski (Status.failed("Couldn't get relation 'NROW'")); 66*b1cdbd2cSJim Jagielski } 67*b1cdbd2cSJim Jagielski Integer num_col = (Integer)tEnv.getObjRelation("NCOL"); 68*b1cdbd2cSJim Jagielski if (num_col == null) { 69*b1cdbd2cSJim Jagielski throw new StatusException 70*b1cdbd2cSJim Jagielski (Status.failed("Couldn't get relation 'NCOL'")); 71*b1cdbd2cSJim Jagielski } 72*b1cdbd2cSJim Jagielski nRow = num_row.intValue(); 73*b1cdbd2cSJim Jagielski nCol = num_col.intValue(); 74*b1cdbd2cSJim Jagielski } 75*b1cdbd2cSJim Jagielski 76*b1cdbd2cSJim Jagielski /** 77*b1cdbd2cSJim Jagielski * The method is not called directly here, because it must 78*b1cdbd2cSJim Jagielski * be called before being inserted to the document. <p> 79*b1cdbd2cSJim Jagielski * 80*b1cdbd2cSJim Jagielski * Always has <b> OK </b> status. <p> 81*b1cdbd2cSJim Jagielski */ _initialize()82*b1cdbd2cSJim Jagielski public void _initialize() { 83*b1cdbd2cSJim Jagielski 84*b1cdbd2cSJim Jagielski // initialize() 85*b1cdbd2cSJim Jagielski log.println( "test for initialize()" ); 86*b1cdbd2cSJim Jagielski tRes.tested( "initialize()", true); 87*b1cdbd2cSJim Jagielski } 88*b1cdbd2cSJim Jagielski 89*b1cdbd2cSJim Jagielski /** 90*b1cdbd2cSJim Jagielski * Test calls the method passing as cell name the first 91*b1cdbd2cSJim Jagielski * element from names returned by <code>getCellNames</code> 92*b1cdbd2cSJim Jagielski * method. <p> 93*b1cdbd2cSJim Jagielski * 94*b1cdbd2cSJim Jagielski * Has <b> OK </b> status if the method returns not 95*b1cdbd2cSJim Jagielski * <code>null</code> value. 96*b1cdbd2cSJim Jagielski * 97*b1cdbd2cSJim Jagielski * The following method tests are to be completed successfully before : 98*b1cdbd2cSJim Jagielski * <ul> 99*b1cdbd2cSJim Jagielski * <li> <code> getCellNames() </code> : its result used by test. </li> 100*b1cdbd2cSJim Jagielski * </ul> 101*b1cdbd2cSJim Jagielski */ _createCursorByCellName()102*b1cdbd2cSJim Jagielski public void _createCursorByCellName(){ 103*b1cdbd2cSJim Jagielski requiredMethod("getCellNames()") ; 104*b1cdbd2cSJim Jagielski 105*b1cdbd2cSJim Jagielski // createCursorByCellName() 106*b1cdbd2cSJim Jagielski log.println( "test for createCursorByCellName()" ); 107*b1cdbd2cSJim Jagielski tRes.tested( "createCursorByCellName()", 108*b1cdbd2cSJim Jagielski oObj.createCursorByCellName( cellNamesList[0] ) != null ); 109*b1cdbd2cSJim Jagielski } 110*b1cdbd2cSJim Jagielski 111*b1cdbd2cSJim Jagielski /** 112*b1cdbd2cSJim Jagielski * Test calls the method passing as cell name the first 113*b1cdbd2cSJim Jagielski * element from names returned by <code>getCellNames</code> 114*b1cdbd2cSJim Jagielski * method. <p> 115*b1cdbd2cSJim Jagielski * 116*b1cdbd2cSJim Jagielski * Has <b> OK </b> status if the method returns not 117*b1cdbd2cSJim Jagielski * <code>null</code> value. 118*b1cdbd2cSJim Jagielski * 119*b1cdbd2cSJim Jagielski * The following method tests are to be completed successfully before : 120*b1cdbd2cSJim Jagielski * <ul> 121*b1cdbd2cSJim Jagielski * <li> <code> getCellNames() </code> : its result used by test. </li> 122*b1cdbd2cSJim Jagielski * </ul> 123*b1cdbd2cSJim Jagielski */ _getCellByName()124*b1cdbd2cSJim Jagielski public void _getCellByName(){ 125*b1cdbd2cSJim Jagielski requiredMethod("getCellNames()") ; 126*b1cdbd2cSJim Jagielski 127*b1cdbd2cSJim Jagielski // getCellByName() 128*b1cdbd2cSJim Jagielski log.println( "test for getCellByName()" ); 129*b1cdbd2cSJim Jagielski tRes.tested( "getCellByName()", 130*b1cdbd2cSJim Jagielski oObj.getCellByName( cellNamesList[0] ) != null ); 131*b1cdbd2cSJim Jagielski } 132*b1cdbd2cSJim Jagielski 133*b1cdbd2cSJim Jagielski /** 134*b1cdbd2cSJim Jagielski * Obtains cell names of the table. <p> 135*b1cdbd2cSJim Jagielski * 136*b1cdbd2cSJim Jagielski * Has <b>OK</b> status if number of elements in the returned 137*b1cdbd2cSJim Jagielski * array is equal to [row number] * [column number] 138*b1cdbd2cSJim Jagielski * and if the first name is 'A1'. 139*b1cdbd2cSJim Jagielski */ _getCellNames()140*b1cdbd2cSJim Jagielski public void _getCellNames(){ 141*b1cdbd2cSJim Jagielski // getCellNames() 142*b1cdbd2cSJim Jagielski log.println( "test for getCellNames()" ); 143*b1cdbd2cSJim Jagielski cellNamesList = oObj.getCellNames(); 144*b1cdbd2cSJim Jagielski 145*b1cdbd2cSJim Jagielski boolean result = cellNamesList.length == ( nRow * nCol ) ; 146*b1cdbd2cSJim Jagielski result &= cellNamesList[0].equals( "A1" ) ; 147*b1cdbd2cSJim Jagielski 148*b1cdbd2cSJim Jagielski tRes.tested( "getCellNames()", result ) ; 149*b1cdbd2cSJim Jagielski } 150*b1cdbd2cSJim Jagielski 151*b1cdbd2cSJim Jagielski /** 152*b1cdbd2cSJim Jagielski * Obtains columns of the table. <p> 153*b1cdbd2cSJim Jagielski * 154*b1cdbd2cSJim Jagielski * Has <b>OK</b> status if the number of element of returned 155*b1cdbd2cSJim Jagielski * collection is equal to real number of columns in the table. 156*b1cdbd2cSJim Jagielski */ _getColumns()157*b1cdbd2cSJim Jagielski public void _getColumns(){ 158*b1cdbd2cSJim Jagielski // getColumns() 159*b1cdbd2cSJim Jagielski log.println( "test for getColumns()" ); 160*b1cdbd2cSJim Jagielski tRes.tested( "getColumns()", nCol == oObj.getColumns().getCount() ); 161*b1cdbd2cSJim Jagielski } 162*b1cdbd2cSJim Jagielski 163*b1cdbd2cSJim Jagielski /** 164*b1cdbd2cSJim Jagielski * Obtains rows of the table. <p> 165*b1cdbd2cSJim Jagielski * 166*b1cdbd2cSJim Jagielski * Has <b>OK</b> status if the number of element of returned 167*b1cdbd2cSJim Jagielski * collection is equal to real number of rows in the table. 168*b1cdbd2cSJim Jagielski */ _getRows()169*b1cdbd2cSJim Jagielski public void _getRows(){ 170*b1cdbd2cSJim Jagielski // getRows() 171*b1cdbd2cSJim Jagielski log.println( "test for getRows()" ); 172*b1cdbd2cSJim Jagielski tRes.tested( "getRows()", nRow == oObj.getRows().getCount() ); 173*b1cdbd2cSJim Jagielski } 174*b1cdbd2cSJim Jagielski 175*b1cdbd2cSJim Jagielski } 176*b1cdbd2cSJim Jagielski 177*b1cdbd2cSJim Jagielski 178