blob: 538704388fb618af5d4f40ce7207bee0111a32d7 [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 org.apache.carbondata.core.scan.filter;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
import org.apache.carbondata.core.metadata.AbsoluteTableIdentifier;
import org.apache.carbondata.core.metadata.CarbonTableIdentifier;
import org.apache.carbondata.core.metadata.datatype.DataTypes;
import org.apache.carbondata.core.metadata.encoder.Encoding;
import org.apache.carbondata.core.metadata.schema.table.column.CarbonColumn;
import org.apache.carbondata.core.metadata.schema.table.column.ColumnSchema;
import org.apache.carbondata.core.scan.expression.ColumnExpression;
import org.apache.carbondata.core.scan.expression.Expression;
import org.apache.carbondata.core.scan.expression.LiteralExpression;
import org.apache.carbondata.core.scan.expression.conditional.InExpression;
import org.apache.carbondata.core.scan.filter.intf.ExpressionType;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
public class FilterExpressionProcessorTest {
private ColumnSchema columnSchema;
@Before public void setUp() throws Exception {
columnSchema = new ColumnSchema();
columnSchema.setColumnName("IMEI");
columnSchema.setColumnUniqueId(UUID.randomUUID().toString());
columnSchema.setDataType(DataTypes.STRING);
columnSchema.setDimensionColumn(true);
List<Encoding> encodingList = new ArrayList<>();
encodingList.add(Encoding.IMPLICIT);
columnSchema.setEncodingList(encodingList);
}
@Test public void testGetFilterResolverBasedOnExpressionType()
throws NoSuchMethodException, InvocationTargetException, IllegalAccessException {
CarbonColumn carbonColumn = new CarbonColumn(columnSchema, 0, 0);
ColumnExpression columnExpression = new ColumnExpression("IMEI", DataTypes.STRING);
columnExpression.setCarbonColumn(carbonColumn);
LiteralExpression literalExpression = new LiteralExpression("ImeiValue", DataTypes.STRING);
InExpression equalToExpression = new InExpression(columnExpression, literalExpression);
FilterExpressionProcessor filterExpressionProcessor = new FilterExpressionProcessor();
Method method = FilterExpressionProcessor.class
.getDeclaredMethod("getFilterResolverBasedOnExpressionType", ExpressionType.class,
boolean.class, Expression.class, AbsoluteTableIdentifier.class, Expression.class);
method.setAccessible(true);
Object result = method
.invoke(filterExpressionProcessor, ExpressionType.EQUALS, false, equalToExpression, null,
null);
Assert.assertTrue(result.getClass().getName()
.equals("org.apache.carbondata.core.scan.filter.resolver.ConditionalFilterResolverImpl"));
}
}