/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 2005-2008, Open Source Geospatial Foundation (OSGeo)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License.
*
* This library 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 for more details.
*/
package org.geotools.filter.visitor;
import java.util.Arrays;
import org.opengis.filter.Filter;
import org.opengis.filter.PropertyIsEqualTo;
import org.opengis.filter.expression.Expression;
import org.geotools.filter.FilterCapabilities;
import org.geotools.filter.function.FilterFunction_geometryType;
import org.geotools.filter.function.math.FilterFunction_abs;
/**
* Test case where only specific functions are supported.
*
* @author Jesse
*
*
* @source $URL$
*/
public class PostPreProcessFilterSplitterVisitorFunctionTest extends AbstractPostPreProcessFilterSplittingVisitorTests {
PostPreProcessFilterSplittingVisitor visitor;
public void testSupportAll() throws Exception {
PropertyIsEqualTo filter1 = createFunctionFilter();
FilterFunction_abs filterFunction_abs = new FilterFunction_abs();
filterFunction_abs.setParameters(Arrays.asList(new Expression[]{ff.property("name")}));
PropertyIsEqualTo filter2 = ff.equals(ff.property("name"), filterFunction_abs);
Filter filter=ff.and(filter1,filter2);
visitor = newVisitor(new FilterCapabilities());
filter.accept(visitor, null);
assertEquals(Filter.INCLUDE, visitor.getFilterPre());
assertEquals(filter, visitor.getFilterPost());
FilterCapabilities filterCapabilitiesMask = new FilterCapabilities();
filterCapabilitiesMask.addType(FilterFunction_geometryType.class);
filterCapabilitiesMask.addType(FilterFunction_abs.class);
filterCapabilitiesMask.addAll(FilterCapabilities.SIMPLE_COMPARISONS_OPENGIS);
filterCapabilitiesMask.addAll(FilterCapabilities.LOGICAL_OPENGIS);
visitor=newVisitor(filterCapabilitiesMask);
filter.accept(visitor, null);
assertEquals(Filter.INCLUDE, visitor.getFilterPost());
assertEquals(filter, visitor.getFilterPre());
}
public void testSupportOnlySome() throws Exception {
PropertyIsEqualTo filter1 = createFunctionFilter();
FilterFunction_abs filterFunction_abs = new FilterFunction_abs();
filterFunction_abs.setParameters(Arrays.asList(new Expression[]{ff.property("name")}));
PropertyIsEqualTo filter2 = ff.equals(ff.property("name"), filterFunction_abs);
Filter filter=ff.and(filter1,filter2);
FilterCapabilities filterCapabilitiesMask = new FilterCapabilities();
filterCapabilitiesMask.addType(FilterFunction_geometryType.class);
filterCapabilitiesMask.addAll(FilterCapabilities.SIMPLE_COMPARISONS_OPENGIS);
filterCapabilitiesMask.addAll(FilterCapabilities.LOGICAL_OPENGIS);
visitor=newVisitor(filterCapabilitiesMask);
filter.accept(visitor, null);
assertEquals(filter1, visitor.getFilterPre());
assertEquals(filter2, visitor.getFilterPost());
}
}