/*************************************************************************
*
* 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
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
package ifc.sheet;
import lib.MultiMethodTest;
import com.sun.star.sheet.TableFilterField;
import com.sun.star.sheet.XSheetFilterDescriptor;
import com.sun.star.sheet.XSheetFilterable;
import com.sun.star.sheet.XSheetFilterableEx;
import com.sun.star.uno.UnoRuntime;
/**
* Inteface test for XSheetFilterableEx
*
* methods:
*
* createFilterDescriptorByObject
*
*/
public class _XSheetFilterableEx extends MultiMethodTest {
public XSheetFilterableEx oObj = null;
/**
* queries a XSheetFilterable from the parent Object and then creates
* a XSheetFilterDescriptor with it.
* Returns OK if the Descriptor isn't null and checkFilterDescriptor returns true
*/
public void _createFilterDescriptorByObject() {
boolean res = true;
Object parent = tEnv.getTestObject();
XSheetFilterable aFilterable = (XSheetFilterable) UnoRuntime.queryInterface(
XSheetFilterable.class, parent);
XSheetFilterDescriptor desc = oObj.createFilterDescriptorByObject(
aFilterable);
if (desc != null) {
res &= checkFilterDescriptor(desc);
} else {
log.println("gained XSheetFilterDescriptor is null");
res &= false;
}
tRes.tested("createFilterDescriptorByObject()",res);
}
/**
* returns true if the Method getFilterFields() returns a non empty array
* and all Fields can be gained without exception
*/
public boolean checkFilterDescriptor(XSheetFilterDescriptor desc) {
TableFilterField[] fields = desc.getFilterFields();
boolean res = true;
if (fields.length == 0) {
log.println("The gained Descriptor is empty");
res &= false;
} else {
log.println("Found "+fields.length+" TableFields");
}
for (int k = 0; k < fields.length; k++) {
log.println("StringValue(" + k + "): " + fields[k].StringValue);
log.println("IsNumeric(" + k + "): " + fields[k].IsNumeric);
log.println("NumericValue(" + k + "): " + fields[k].NumericValue);
log.println("Field(" + k + "): " + fields[k].Field);
log.println("Connection(" + k + "): " + fields[k].Connection);
log.println("Operator(" + k + "): " + fields[k].Operator);
}
return res;
}
}