/** * 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.camel.component.reactor.engine; import org.apache.camel.Exchange; import org.apache.camel.builder.RouteBuilder; import org.apache.camel.component.mock.MockEndpoint; import org.apache.camel.component.reactive.streams.ReactiveStreamsConstants; import org.junit.Assert; import org.junit.Test; import org.reactivestreams.Subscriber; import reactor.core.publisher.Flux; public class ReactorStreamsServiceEventTypeTest extends ReactorStreamsServiceTestSupport { @Test public void testOnCompleteHeaderForwarded() throws Exception { context.addRoutes(new RouteBuilder() { @Override public void configure() throws Exception { from("reactive-streams:numbers?forwardOnComplete=true") .to("mock:endpoint"); } }); Subscriber<Integer> numbers = crs.streamSubscriber("numbers", Integer.class); context.start(); Flux.<Integer>empty().subscribe(numbers); MockEndpoint endpoint = getMockEndpoint("mock:endpoint"); endpoint.expectedMessageCount(1); endpoint.expectedHeaderReceived(ReactiveStreamsConstants.REACTIVE_STREAMS_EVENT_TYPE, "onComplete"); endpoint.expectedBodiesReceived(new Object[]{null}); endpoint.assertIsSatisfied(); } @Test public void testOnCompleteHeaderNotForwarded() throws Exception { context.addRoutes(new RouteBuilder() { @Override public void configure() throws Exception { from("reactive-streams:numbers") .to("mock:endpoint"); } }); Subscriber<Integer> numbers = crs.streamSubscriber("numbers", Integer.class); context.start(); Flux.<Integer>empty().subscribe(numbers); MockEndpoint endpoint = getMockEndpoint("mock:endpoint"); endpoint.expectedMessageCount(0); endpoint.assertIsSatisfied(200); } @Test public void testOnNextHeaderForwarded() throws Exception { context.addRoutes(new RouteBuilder() { @Override public void configure() throws Exception { from("reactive-streams:numbers") .to("mock:endpoint"); } }); Subscriber<Integer> numbers = crs.streamSubscriber("numbers", Integer.class); context.start(); Flux.just(1).subscribe(numbers); MockEndpoint endpoint = getMockEndpoint("mock:endpoint"); endpoint.expectedHeaderReceived(ReactiveStreamsConstants.REACTIVE_STREAMS_EVENT_TYPE, "onNext"); endpoint.expectedMessageCount(1); endpoint.assertIsSatisfied(); Exchange ex = endpoint.getExchanges().get(0); Assert.assertEquals(1, ex.getIn().getBody()); } @Test public void testOnErrorHeaderForwarded() throws Exception { context.addRoutes(new RouteBuilder() { @Override public void configure() throws Exception { from("reactive-streams:numbers?forwardOnError=true") .to("mock:endpoint"); } }); Subscriber<Integer> numbers = crs.streamSubscriber("numbers", Integer.class); context.start(); RuntimeException ex = new RuntimeException("1"); Flux.just(1) .map(n -> { if (n == 1) { throw ex; } return n; }) .subscribe(numbers); MockEndpoint endpoint = getMockEndpoint("mock:endpoint"); endpoint.expectedMessageCount(1); endpoint.expectedHeaderReceived(ReactiveStreamsConstants.REACTIVE_STREAMS_EVENT_TYPE, "onError"); endpoint.assertIsSatisfied(); Exchange exch = endpoint.getExchanges().get(0); Assert.assertEquals(ex, exch.getIn().getBody()); } @Test public void testOnErrorHeaderNotForwarded() throws Exception { context.addRoutes(new RouteBuilder() { @Override public void configure() throws Exception { from("reactive-streams:numbers") .to("mock:endpoint"); } }); Subscriber<Integer> numbers = crs.streamSubscriber("numbers", Integer.class); context.start(); RuntimeException ex = new RuntimeException("1"); Flux.just(1) .map(n -> { if (n == 1) { throw ex; } return n; }) .subscribe(numbers); MockEndpoint endpoint = getMockEndpoint("mock:endpoint"); endpoint.expectedMessageCount(0); endpoint.assertIsSatisfied(200); } }