/*
* Copyright 2016 Christoph Böhme
*
* 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 org.culturegraph.mf.metamorph.collectors;
import static org.mockito.Mockito.inOrder;
import org.culturegraph.mf.framework.StreamReceiver;
import org.culturegraph.mf.metamorph.InlineMorph;
import org.culturegraph.mf.metamorph.Metamorph;
import org.junit.Rule;
import org.junit.Test;
import org.mockito.InOrder;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnit;
import org.mockito.junit.MockitoRule;
/**
* Tests the basic functionality of Metamorph collectors.
*
* @author Markus Geipel (metamorph-test xml)
* @author Christoph Böhme (conversion to Java)
*/
public final class TestCollectorBasics {
// TODO: Can this be changed into a JUnit test for AbstractCollect?
@Rule
public final MockitoRule mockitoRule = MockitoJUnit.rule();
@Mock
private StreamReceiver receiver;
private Metamorph metamorph;
@Test
public void shouldSupportNestedCollectors() {
metamorph = InlineMorph.in(this)
.with("<rules>")
.with(" <combine name='d' value='${1}${c}'>")
.with(" <data source='d1' name='1' />")
.with(" <combine name='c' value='${2}${3}'>")
.with(" <data source='d2' name='2' />")
.with(" <data source='d3' name='3' />")
.with(" <postprocess>")
.with(" <trim />")
.with(" </postprocess>")
.with(" </combine>")
.with(" </combine>")
.with("</rules>")
.createConnectedTo(receiver);
metamorph.startRecord("1");
metamorph.literal("d1", "a");
metamorph.literal("d2", "b");
metamorph.literal("d3", "c ");
metamorph.endRecord();
final InOrder ordered = inOrder(receiver);
ordered.verify(receiver).startRecord("1");
ordered.verify(receiver).literal("d", "abc");
ordered.verify(receiver).endRecord();
ordered.verifyNoMoreInteractions(); }
@Test
public void shouldSupportNestedSameEntity() {
metamorph = InlineMorph.in(this)
.with("<rules>")
.with(" <combine name='result' value='${value}${ch}' sameEntity='true'>")
.with(" <data source='rel.value' name='value' />")
.with(" <choose name='ch' flushWith='rel'>")
.with(" <data source='rel.ch' />")
.with(" <data source='rel'>")
.with(" <constant value='M' />")
.with(" </data>")
.with(" </choose>")
.with(" </combine>")
.with("</rules>")
.createConnectedTo(receiver);
metamorph.startRecord("1");
metamorph.startEntity("rel");
metamorph.literal("ch", "b");
metamorph.literal("value", "a");
metamorph.endEntity();
metamorph.startEntity("rel");
metamorph.literal("value", "B");
metamorph.endEntity();
metamorph.startEntity("rel");
metamorph.literal("ch", "e");
metamorph.literal("value", "d");
metamorph.endEntity();
metamorph.startEntity("rel");
metamorph.literal("ch", "X");
metamorph.endEntity();
metamorph.endRecord();
final InOrder ordered = inOrder(receiver);
ordered.verify(receiver).startRecord("1");
ordered.verify(receiver).literal("result", "ab");
ordered.verify(receiver).literal("result", "BM");
ordered.verify(receiver).literal("result", "de");
ordered.verify(receiver).endRecord();
ordered.verifyNoMoreInteractions();
}
@Test
public void shouldAllowUsingAnArbitraryLiteralForFlush() {
metamorph = InlineMorph.in(this)
.with("<rules>")
.with(" <concat delimiter='' name='d' flushWith='f'>")
.with(" <data source='d' />")
.with(" </concat>")
.with("</rules>")
.createConnectedTo(receiver);
metamorph.startRecord("1");
metamorph.literal("d", "1");
metamorph.literal("d", "2");
metamorph.literal("f", "");
metamorph.literal("d", "3");
metamorph.literal("d", "4");
metamorph.literal("d", "5");
metamorph.literal("f", "");
metamorph.literal("d", "6");
metamorph.endRecord();
final InOrder ordered = inOrder(receiver);
ordered.verify(receiver).startRecord("1");
ordered.verify(receiver).literal("d", "12");
ordered.verify(receiver).literal("d", "345");
ordered.verify(receiver).endRecord();
ordered.verifyNoMoreInteractions();
}
@Test
public void shouldReceiveFlushingLiteralBeforeFlushEvent() {
metamorph = InlineMorph.in(this)
.with("<rules>")
.with(" <concat delimiter='' name='d' flushWith='f'>")
.with(" <data source='d' />")
.with(" <data source='f' />")
.with(" </concat>")
.with("</rules>")
.createConnectedTo(receiver);
metamorph.startRecord("1");
metamorph.literal("f", "1");
metamorph.literal("f", "2");
metamorph.literal("d", "a");
metamorph.literal("f", "3");
metamorph.endRecord();
final InOrder ordered = inOrder(receiver);
ordered.verify(receiver).startRecord("1");
ordered.verify(receiver).literal("d", "1");
ordered.verify(receiver).literal("d", "2");
ordered.verify(receiver).literal("d", "a3");
ordered.verify(receiver).endRecord();
ordered.verifyNoMoreInteractions();
}
}