blob: 53e49709c242c40a931ea8267ca9b247d50d7e6f [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
package complex.sfx2.undo;
import org.openoffice.test.tools.SpreadsheetDocument;
import com.sun.star.table.XCellRange;
import com.sun.star.lang.XMultiServiceFactory;
import com.sun.star.table.XCell;
import com.sun.star.uno.UnoRuntime;
import org.openoffice.test.tools.DocumentType;
import static org.junit.Assert.*;
/**
* implements the {@link DocumentTest} interface on top of a spreadsheet document
* @author frank.schoenheit@oracle.com
*/
public class CalcDocumentTest extends DocumentTestBase
{
public CalcDocumentTest( final XMultiServiceFactory i_orb ) throws Exception
{
super( i_orb, DocumentType.CALC );
}
public String getDocumentDescription()
{
return "spreadsheet document";
}
public void initializeDocument() throws com.sun.star.uno.Exception
{
final XCell cellA1 = getCellA1();
cellA1.setValue( INIT_VALUE );
assertEquals( "initializing the cell value didn't work", cellA1.getValue(), INIT_VALUE, 0 );
XCellRange range = UnoRuntime.queryInterface( XCellRange.class,
((SpreadsheetDocument)m_document).getSheet(0) );
for ( int i=0; i<12; ++i )
{
XCell cell = range.getCellByPosition( 1, i );
cell.setFormula( "" );
}
}
public void doSingleModification() throws com.sun.star.uno.Exception
{
final XCell cellA1 = getCellA1();
assertEquals( "initial cell value not as expected", INIT_VALUE, cellA1.getValue(), 0 );
cellA1.setValue( MODIFIED_VALUE );
assertEquals( "modified cell value not as expected", MODIFIED_VALUE, cellA1.getValue(), 0 );
}
public void verifyInitialDocumentState() throws com.sun.star.uno.Exception
{
final XCell cellA1 = getCellA1();
assertEquals( "cell A1 doesn't have its initial value", INIT_VALUE, cellA1.getValue(), 0 );
XCellRange range = UnoRuntime.queryInterface( XCellRange.class,
((SpreadsheetDocument)m_document).getSheet(0) );
for ( int i=0; i<12; ++i )
{
final XCell cell = range.getCellByPosition( 1, i );
assertEquals( "Cell B" + (i+1) + " not having its initial value (an empty string)", "", cell.getFormula() );
}
}
public void verifySingleModificationDocumentState() throws com.sun.star.uno.Exception
{
final XCell cellA1 = getCellA1();
assertEquals( "cell A1 doesn't have the value which we gave it", MODIFIED_VALUE, cellA1.getValue(), 0 );
}
public int doMultipleModifications() throws com.sun.star.uno.Exception
{
XCellRange range = UnoRuntime.queryInterface( XCellRange.class,
((SpreadsheetDocument)m_document).getSheet(0) );
final String[] months = new String[] {
"January", "February", "March", "April", "May", "June", "July", "August",
"September", "October", "November", "December" };
for ( int i=0; i<12; ++i )
{
final XCell cell = range.getCellByPosition( 1, i );
cell.setFormula( months[i] );
}
return 12;
}
private XCell getCellA1() throws com.sun.star.uno.Exception
{
XCellRange range = UnoRuntime.queryInterface( XCellRange.class,
((SpreadsheetDocument)m_document).getSheet(0) );
return range.getCellByPosition( 0, 0 );
}
private static final double INIT_VALUE = 100.0;
private static final double MODIFIED_VALUE = 200.0;
}