/*
* Copyright (C) 2015 Stratio (http://stratio.com)
*
* Licensed 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 com.stratio.morphlines.commons;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
import org.kitesdk.morphline.api.Command;
import org.kitesdk.morphline.api.MorphlineContext;
import org.kitesdk.morphline.api.Record;
import java.io.IOException;
import java.util.List;
import static org.fest.assertions.Assertions.assertThat;
@RunWith(JUnit4.class)
public class FieldFilterTest extends BaseTest {
@Before
public void setUp() {
}
private Record record(String...args) {
final Record record = new Record();
for (List<String> parts : Lists.partition(ImmutableList.copyOf(args), 2)) {
record.put(parts.get(0), parts.get(1));
}
return record;
}
@Test
public void onlyIncludeNoRegex() throws IOException {
final MorphlineContext context = new MorphlineContext.Builder().build();
Collector collectorParent = new Collector();
Collector collectorChild = new Collector();
final Command command = new FieldFilterBuilder().build(
parse("/fieldfilter/onlyIncludeNoRegex.conf").getConfigList("commands").get(0).getConfig("fieldFilter"),
collectorParent, collectorChild, context
);
Record record = record();
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record());
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value2"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field1", "value1",
"field2", "value2"
));
}
@Test
public void onlyExcludeNoRegex() throws IOException {
final MorphlineContext context = new MorphlineContext.Builder().build();
Collector collectorParent = new Collector();
Collector collectorChild = new Collector();
final Command command = new FieldFilterBuilder().build(
parse("/fieldfilter/onlyExcludeNoRegex.conf").getConfigList("commands").get(0).getConfig("fieldFilter"),
collectorParent, collectorChild, context
);
Record record = record();
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record());
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field3", "value3"
));
}
@Test
public void includeAndExcludeNoRegex() throws IOException {
final MorphlineContext context = new MorphlineContext.Builder().build();
Collector collectorParent = new Collector();
Collector collectorChild = new Collector();
final Command command = new FieldFilterBuilder().build(
parse("/fieldfilter/includeAndExcludeNoRegex.conf").getConfigList("commands").get(0).getConfig("fieldFilter"),
collectorParent, collectorChild, context
);
Record record = record();
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record());
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value2"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field1", "value1",
"field2", "value2"
));
}
@Test
public void onlyIncludeRegex() throws IOException {
final MorphlineContext context = new MorphlineContext.Builder().build();
Collector collectorParent = new Collector();
Collector collectorChild = new Collector();
final Command command = new FieldFilterBuilder().build(
parse("/fieldfilter/onlyIncludeRegex.conf").getConfigList("commands").get(0).getConfig("fieldFilter"),
collectorParent, collectorChild, context
);
Record record = record();
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record());
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field1", "value1",
"field2", "value2"
));
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3",
"fieldRegex1Blah", "value",
"fieldRegex2Blah", "value"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field1", "value1",
"field2", "value2",
"fieldRegex1Blah", "value",
"fieldRegex2Blah", "value"
));
}
@Test
public void onlyExcludeRegex() throws IOException {
final MorphlineContext context = new MorphlineContext.Builder().build();
Collector collectorParent = new Collector();
Collector collectorChild = new Collector();
final Command command = new FieldFilterBuilder().build(
parse("/fieldfilter/onlyExcludeRegex.conf").getConfigList("commands").get(0).getConfig("fieldFilter"),
collectorParent, collectorChild, context
);
Record record = record();
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record());
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field3", "value3"
));
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3",
"fieldRegex1Blah", "value",
"fieldRegex2Blah", "value"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field3", "value3"
));
}
@Test
public void includeAndExcludeRegex() throws IOException {
final MorphlineContext context = new MorphlineContext.Builder().build();
Collector collectorParent = new Collector();
Collector collectorChild = new Collector();
final Command command = new FieldFilterBuilder().build(
parse("/fieldfilter/includeAndExcludeRegex.conf").getConfigList("commands").get(0).getConfig("fieldFilter"),
collectorParent, collectorChild, context
);
Record record = record();
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record());
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field1", "value1",
"field2", "value2"
));
collectorChild.reset();
record = record(
"field1", "value1",
"field2", "value2",
"field3", "value3",
"fieldRegex1foo", "value",
"fieldRegex2bar", "value"
);
command.process(record);
assertThat(collectorChild.getFirstRecord()).isEqualTo(record(
"field1", "value1",
"field2", "value2",
"fieldRegex1foo", "value"
));
}
}