/* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ package ifc.table; import java.util.Random; import lib.MultiMethodTest; import com.sun.star.beans.XPropertySet; import com.sun.star.container.XNameAccess; import com.sun.star.lang.XMultiServiceFactory; import com.sun.star.table.XAutoFormattable; import com.sun.star.table.XCell; import com.sun.star.table.XCellRange; import com.sun.star.uno.UnoRuntime; import com.sun.star.uno.XInterface; /** * Testing com.sun.star.table.XAutoFormattable * interface methods : *

* The component tested must implement interface * com.sun.star.table.XCellRange.

* Test is NOT multithread compliant.

* @see com.sun.star.table.XAutoFormattable */ public class _XAutoFormattable extends MultiMethodTest { public XAutoFormattable oObj = null; /** * First 'Default' autoformat is set and a background of a cell * is obtained. Then any other autoformat is set and background * of a cell is obtained again.

* Has OK status if backgrounds with different autoformat * settings are differ.

*/ public void _autoFormat() { boolean bResult = true; XMultiServiceFactory oMSF = tParam.getMSF(); String name = "Default"; try { oObj.autoFormat(name); // applying default format // getting current background of the cell XCellRange cellRange = UnoRuntime.queryInterface( XCellRange.class, oObj); XCell oCell = cellRange.getCellByPosition(0, 0); XPropertySet PS = UnoRuntime.queryInterface( XPropertySet.class, oCell); Integer bkgrnd1; try { bkgrnd1 = (Integer) PS.getPropertyValue("CellBackColor"); } catch (com.sun.star.beans.UnknownPropertyException e) { bkgrnd1 = (Integer) PS.getPropertyValue("BackColor"); } // getting formats names. XInterface iFormats = (XInterface) oMSF.createInstance( "com.sun.star.sheet.TableAutoFormats"); XNameAccess formats = UnoRuntime.queryInterface( XNameAccess.class, iFormats); String[] names = formats.getElementNames(); // getting one random not default style name Random rnd = new Random(); if (names.length > 1) { while (name.equals("Default")) { name = names[rnd.nextInt(names.length)]; } } else { name = names[0]; } log.println("Applying style " + name); // applying style oObj.autoFormat(name); // getting new cell's background. Integer bkgrnd2; try { bkgrnd2 = (Integer) PS.getPropertyValue("CellBackColor"); } catch (com.sun.star.beans.UnknownPropertyException e) { bkgrnd2 = (Integer) PS.getPropertyValue("BackColor"); } bResult &= !bkgrnd1.equals(bkgrnd2); } catch (com.sun.star.uno.Exception e) { log.println("Exception occurred :"); e.printStackTrace(log); bResult = false; } tRes.tested("autoFormat()", bResult); } /** * Forces environment recreation. */ @Override protected void after() { disposeEnvironment(); } }