import java.util.Arrays;
import java.util.Collection;
-import java.util.concurrent.atomic.AtomicLong;
+import java.util.UUID;
+import java.util.logging.Handler;
import java.util.logging.Level;
+import java.util.logging.Logger;
import javax.xml.transform.dom.DOMSource;
}
private ExtendedRouterConfig routerConfig;
+ private XMLRouterConfiguration config;
private XMLRouter router;
private DOMSource source1;
private DOMSource source2;
@Before
public void setUp() {
- routerConfig = new SingleRouterConfig(new AtomicLong(1L));
+
+ Logger logger = Logger.getLogger(XMLRouter.class.getName());
+ setLogLevel(logger, Level.FINEST);
+
+ routerConfig = new SingleRouterConfig("routerconfig");
+ config = new XMLRouterConfigurationImpl(routerConfig);
EventListener logListener = new LoggingEventListener(Level.INFO);
listener = spy(logListener);
- router = new XMLRouter(new SystemClock(), routerConfig, listener);
+ router = new XMLRouter(new SystemClock(), config, listener);
source1 = mock(DOMSource.class);
source2 = mock(DOMSource.class);
source3 = mock(DOMSource.class);
}
+ private void setLogLevel(Logger aLogger, Level aLevel) {
+ aLogger.setLevel(aLevel);
+ for (Handler handler : aLogger.getHandlers()) {
+ handler.setLevel(Level.FINEST);
+ }
+ Logger parent = aLogger.getParent();
+ if (parent != null) {
+ setLogLevel(parent, aLevel);
+ }
+ }
+
@Test
public void testNoInputDocumentsRegistered() {
Destination destination = new MyDestination(true, Arrays.asList("any"));
@Test
public void testMisBehavingDocumentType() {
- DocumentType type = mock(DocumentType.class);
+ DocumentType type = mockDocument("docid");
doThrow(new RuntimeException("x")).when(type).isInstance(
any(DOMSource.class));
routerConfig.documentTypeConfig().add(type);
// no exception should occur.
}
+ private DocumentType mockDocument(String docid) {
+ DocumentType type = mock(DocumentType.class);
+ when(type.getId()).thenReturn(new Id<DocumentType>(docid));
+ return type;
+ }
+
@Test
public void testMisBehavingFilter() {
registerDocumentType("any");
- Filter filter = mock(Filter.class);
+ Filter filter = mockFilter("filterid");
doThrow(new RuntimeException("x")).when(filter).isAllowed(anyString(),
any(DOMSource.class));
routerConfig.filterConfig().add(filter);
// no exception should occur.
}
+ private Filter mockFilter(String filterId) {
+ Filter filter = mock(Filter.class);
+ when(filter.getId()).thenReturn(new Id<Filter>(filterId));
+ return filter;
+ }
+
@Test
public void testOneDestinationNoTransformationSuccess() {
destinationSpy = registerDestination(true, "any");
router.publish("any", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(destinationSpy).receive(same(source1));
// Unregister the destination.
}
private void registerDocumentType(String aType) {
- DocumentType type = mock(DocumentType.class);
+ DocumentType type = mockDocument(UUID.randomUUID().toString());
when(type.isInstance(any(DOMSource.class))).thenReturn(true);
when(type.getName()).thenReturn(aType);
- Id<DocumentType> typeId = routerConfig.documentTypeConfig().add(type);
+ routerConfig.documentTypeConfig().add(type);
}
private void registerDocumentType(String aType, DOMSource aSource) {
DocumentType type = mock(DocumentType.class);
when(type.isInstance(same(aSource))).thenReturn(true);
when(type.getName()).thenReturn(aType);
- Id<DocumentType> typeId = routerConfig.documentTypeConfig().add(type);
+ when(type.getId()).thenReturn(new Id<DocumentType>(aType));
+ routerConfig.documentTypeConfig().add(type);
}
private Destination registerDestination(boolean aResult, String... types) {
router.publish("any", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(destinationSpy2).receive(same(source1));
.registerDestination(destinationSpy2);
router.publish("any", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(destinationSpy, never()).receive(same(source1));
verify(destinationSpy2).receive(same(source1));
.registerDestination(destinationSpy2);
router.publish("any", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(destinationSpy, never()).receive(same(source1));
verify(destinationSpy2).receive(same(source1));
public void testOneTransformationOneDestination() {
registerDocumentType("any");
Transformation transformation = mock(Transformation.class);
- when(transformation.getName()).thenReturn("trans");
+ when(transformation.getId())
+ .thenReturn(new Id<Transformation>("trans"));
when(transformation.getFromType()).thenReturn("any");
when(transformation.getToType()).thenReturn("bla");
when(transformation.transform(same(source1))).thenReturn(source2);
routerConfig.transformationConfig().add(transformation);
+ config.setRouterConfig(routerConfig);
Destination destination = mock(Destination.class);
when(
when(destination.receive(any(DOMSource.class))).thenReturn(true);
router.publish("bla", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(transformation).transform(source1);
verify(destination).receive(same(source2));
verify(listener).notDelivered(any(EventInfo.class));
}
+ @Test
+ public void testOneTransformationOneDestinationFilterRejectsDestinationDocType() {
+ registerDocumentType("any");
+
+ Transformation transformation = mock(Transformation.class);
+ when(transformation.getId())
+ .thenReturn(new Id<Transformation>("trans"));
+ when(transformation.getFromType()).thenReturn("any");
+ when(transformation.getToType()).thenReturn("bla");
+ when(transformation.transform(same(source1))).thenReturn(source2);
+ routerConfig.transformationConfig().add(transformation);
+
+ Filter filter = mock(Filter.class);
+ when(filter.getId()).thenReturn(new Id<Filter>("f"));
+ when(filter.isAllowed(anyString(), same(source2))).thenReturn(false);
+ when(filter.isAllowed(anyString(), same(source1))).thenReturn(true);
+ routerConfig.filterConfig().add(filter);
+
+ config.setRouterConfig(routerConfig);
+
+ Destination destination = mock(Destination.class);
+ when(
+ destination.chooseFromTargetTypes((Collection<String>) anyObject()))
+ .thenReturn(Arrays.asList("bla"));
+
+ router.registerDestination(destination);
+
+ when(destination.receive(any(DOMSource.class))).thenReturn(true);
+ router.publish("bla", source1);
+ verify(listener).notDelivered(any(EventInfo.class));
+
+ verify(transformation).transform(source1);
+ verify(destination, never()).receive(any(DOMSource.class));
+ }
+
@Test
public void testMisbehavingTransformationOneDestination() {
registerDocumentType("any");
Transformation transformation = mock(Transformation.class);
- when(transformation.getName()).thenReturn("trans");
+ when(transformation.getId())
+ .thenReturn(new Id<Transformation>("trans"));
when(transformation.getFromType()).thenReturn("any");
when(transformation.getToType()).thenReturn("bla");
doThrow(new RuntimeException("x")).when(transformation).transform(
private Transformation createTransformation(String aFrom, String aTo,
DOMSource aSource, DOMSource aTarget) {
Transformation transformation = mock(Transformation.class);
- when(transformation.getName()).thenReturn("trans");
+ when(transformation.getId()).thenReturn(
+ new Id<Transformation>(UUID.randomUUID().toString()));
when(transformation.getFromType()).thenReturn(aFrom);
when(transformation.getToType()).thenReturn(aTo);
when(transformation.transform(same(aSource))).thenReturn(aTarget);
source1, null);
routerConfig.transformationConfig().add(transformation);
-
+ config.setRouterConfig(routerConfig);
Destination destination = mock(Destination.class);
when(
destination.chooseFromTargetTypes((Collection<String>) anyObject()))
source1, source2);
routerConfig.transformationConfig().add(transformation2);
+ config.setRouterConfig(routerConfig);
when(
destination.chooseFromTargetTypes((Collection<String>) anyObject()))
.thenReturn(Arrays.asList("bla", "bla2"));
reset(transformation);
- when(transformation.getName()).thenReturn("trans");
+ when(transformation.getId())
+ .thenReturn(new Id<Transformation>("trans"));
when(transformation.getFromType()).thenReturn("any");
when(transformation.getToType()).thenReturn("bla");
when(transformation.transform(same(source1))).thenReturn(null);
when(destination.receive(any(DOMSource.class))).thenReturn(true);
router.publish("bla", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(transformation).transform(source1);
verify(transformation2).transform(source1);
router.publish("source", source1);
verify(listener, times(2)).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(dest1).receive(same(source1));
verify(dest2).receive(same(source1));
Transformation transformation = createTransformation("any", "other",
source1, source2);
routerConfig.transformationConfig().add(transformation);
+ config.setRouterConfig(routerConfig);
router.publish("source", source1);
verify(listener, times(2)).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(dest).receive(same(source1));
verify(dest).receive(same(source2));
Transformation t2 = createTransformation("intermediate", "other",
source2, source3);
routerConfig.transformationConfig().add(t2);
+ config.setRouterConfig(routerConfig);
router.publish("source", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(true));
+ anyListOf(Transformation.class), anyString(), eq(true));
verify(dest).receive(same(source3));
}
+ @Test
+ public void testMultipleTransformationsFilterRejectsIntermediateDocument() {
+ Destination dest = registerDestination(true, "other");
+ registerDocumentType("any", source1);
+ registerDocumentType("other", source3);
+
+ Transformation t1 = createTransformation("any", "intermediate",
+ source1, source2);
+ routerConfig.transformationConfig().add(t1);
+ Transformation t2 = createTransformation("intermediate", "other",
+ source2, source3);
+ routerConfig.transformationConfig().add(t2);
+ config.setRouterConfig(routerConfig);
+
+ Filter filter = mock(Filter.class);
+ when(filter.getId()).thenReturn(new Id<Filter>("f"));
+ when(filter.isAllowed(anyString(), same(source1))).thenReturn(true);
+ when(filter.isAllowed(anyString(), same(source2))).thenReturn(false);
+ when(filter.isAllowed(anyString(), same(source3))).thenReturn(true);
+ routerConfig.filterConfig().add(filter);
+
+ router.publish("source", source1);
+ verify(listener).notDelivered(any(EventInfo.class));
+ verify(dest, never()).receive(any(DOMSource.class));
+ }
+
@Test
public void testDestinationGivesError() {
Destination destination = mock(Destination.class);
router.publish("source", source1);
verify(listener).delivered(any(EventInfo.class),
- anyListOf(Transformation.class), anyLong(), anyString(), eq(false));
+ anyListOf(Transformation.class), anyString(), eq(false));
}
}