2018-10-29 17:19:37 +08:00
|
|
|
/*
|
2022-02-04 12:36:44 +01:00
|
|
|
* Copyright (C) 2015-2022 Lightbend Inc. <https://www.lightbend.com>
|
2016-01-13 16:25:24 +01:00
|
|
|
*/
|
2018-03-13 23:45:55 +09:00
|
|
|
|
2017-03-16 09:30:00 +01:00
|
|
|
package jdocs.stream.javadsl.cookbook;
|
2016-01-13 16:25:24 +01:00
|
|
|
|
2022-11-12 10:21:24 +01:00
|
|
|
import org.apache.pekko.actor.ActorSystem;
|
|
|
|
|
import org.apache.pekko.japi.Pair;
|
|
|
|
|
import org.apache.pekko.stream.*;
|
|
|
|
|
import org.apache.pekko.stream.javadsl.*;
|
|
|
|
|
import org.apache.pekko.stream.testkit.TestPublisher;
|
|
|
|
|
import org.apache.pekko.stream.testkit.TestSubscriber;
|
|
|
|
|
import org.apache.pekko.stream.testkit.javadsl.TestSink;
|
|
|
|
|
import org.apache.pekko.stream.testkit.javadsl.TestSource;
|
|
|
|
|
import org.apache.pekko.testkit.javadsl.TestKit;
|
2016-01-13 16:25:24 +01:00
|
|
|
import org.junit.AfterClass;
|
|
|
|
|
import org.junit.BeforeClass;
|
|
|
|
|
import org.junit.Test;
|
|
|
|
|
import scala.concurrent.duration.FiniteDuration;
|
|
|
|
|
|
|
|
|
|
import java.util.Arrays;
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
|
|
|
|
|
public class RecipeManualTrigger extends RecipeTest {
|
|
|
|
|
static ActorSystem system;
|
|
|
|
|
|
|
|
|
|
@BeforeClass
|
|
|
|
|
public static void setup() {
|
2016-02-11 16:39:25 +01:00
|
|
|
system = ActorSystem.create("RecipeManualTrigger");
|
2016-01-13 16:25:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@AfterClass
|
|
|
|
|
public static void tearDown() {
|
2017-03-17 03:02:47 +08:00
|
|
|
TestKit.shutdownActorSystem(system);
|
2016-01-13 16:25:24 +01:00
|
|
|
system = null;
|
|
|
|
|
}
|
|
|
|
|
|
2019-01-12 04:00:53 +08:00
|
|
|
class Trigger {}
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
public final Trigger TRIGGER = new Trigger();
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void zipped() throws Exception {
|
2017-03-17 03:02:47 +08:00
|
|
|
new TestKit(system) {
|
2016-01-13 16:25:24 +01:00
|
|
|
{
|
2019-01-12 04:00:53 +08:00
|
|
|
final Source<Trigger, TestPublisher.Probe<Trigger>> triggerSource =
|
|
|
|
|
TestSource.probe(system);
|
2016-01-13 16:25:24 +01:00
|
|
|
final Sink<Message, TestSubscriber.Probe<Message>> messageSink = TestSink.probe(system);
|
|
|
|
|
|
2019-01-12 04:00:53 +08:00
|
|
|
// #manually-triggered-stream
|
2016-01-13 16:25:24 +01:00
|
|
|
final RunnableGraph<Pair<TestPublisher.Probe<Trigger>, TestSubscriber.Probe<Message>>> g =
|
2019-01-12 04:00:53 +08:00
|
|
|
RunnableGraph
|
|
|
|
|
.<Pair<TestPublisher.Probe<Trigger>, TestSubscriber.Probe<Message>>>fromGraph(
|
|
|
|
|
GraphDSL.create(
|
|
|
|
|
triggerSource,
|
|
|
|
|
messageSink,
|
|
|
|
|
(p, s) -> new Pair<>(p, s),
|
|
|
|
|
(builder, source, sink) -> {
|
|
|
|
|
SourceShape<Message> elements =
|
|
|
|
|
builder.add(
|
|
|
|
|
Source.from(Arrays.asList("1", "2", "3", "4"))
|
|
|
|
|
.map(t -> new Message(t)));
|
|
|
|
|
FlowShape<Pair<Message, Trigger>, Message> takeMessage =
|
|
|
|
|
builder.add(
|
|
|
|
|
Flow.<Pair<Message, Trigger>>create().map(p -> p.first()));
|
|
|
|
|
final FanInShape2<Message, Trigger, Pair<Message, Trigger>> zip =
|
|
|
|
|
builder.add(Zip.create());
|
|
|
|
|
builder.from(elements).toInlet(zip.in0());
|
|
|
|
|
builder.from(source).toInlet(zip.in1());
|
|
|
|
|
builder.from(zip.out()).via(takeMessage).to(sink);
|
|
|
|
|
return ClosedShape.getInstance();
|
|
|
|
|
}));
|
|
|
|
|
// #manually-triggered-stream
|
2016-01-13 16:25:24 +01:00
|
|
|
|
2019-08-23 18:19:27 +02:00
|
|
|
Pair<TestPublisher.Probe<Trigger>, TestSubscriber.Probe<Message>> pubSub = g.run(system);
|
2016-01-13 16:25:24 +01:00
|
|
|
TestPublisher.Probe<Trigger> pub = pubSub.first();
|
|
|
|
|
TestSubscriber.Probe<Message> sub = pubSub.second();
|
|
|
|
|
|
|
|
|
|
FiniteDuration timeout = FiniteDuration.create(100, TimeUnit.MILLISECONDS);
|
|
|
|
|
sub.expectSubscription().request(1000);
|
2018-07-25 09:38:33 +01:00
|
|
|
sub.expectNoMessage(timeout);
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
sub.expectNext(new Message("1"));
|
2018-07-25 09:38:33 +01:00
|
|
|
sub.expectNoMessage(timeout);
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
sub.expectNext(new Message("2"));
|
|
|
|
|
sub.expectNext(new Message("3"));
|
2018-07-25 09:38:33 +01:00
|
|
|
sub.expectNoMessage(timeout);
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
sub.expectNext(new Message("4"));
|
|
|
|
|
sub.expectComplete();
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void zipWith() throws Exception {
|
2017-03-17 03:02:47 +08:00
|
|
|
new TestKit(system) {
|
2016-01-13 16:25:24 +01:00
|
|
|
{
|
2019-01-12 04:00:53 +08:00
|
|
|
final Source<Trigger, TestPublisher.Probe<Trigger>> triggerSource =
|
|
|
|
|
TestSource.probe(system);
|
2016-01-13 16:25:24 +01:00
|
|
|
final Sink<Message, TestSubscriber.Probe<Message>> messageSink = TestSink.probe(system);
|
|
|
|
|
|
2019-01-12 04:00:53 +08:00
|
|
|
// #manually-triggered-stream-zipwith
|
2016-01-13 16:25:24 +01:00
|
|
|
final RunnableGraph<Pair<TestPublisher.Probe<Trigger>, TestSubscriber.Probe<Message>>> g =
|
2019-01-12 04:00:53 +08:00
|
|
|
RunnableGraph
|
|
|
|
|
.<Pair<TestPublisher.Probe<Trigger>, TestSubscriber.Probe<Message>>>fromGraph(
|
|
|
|
|
GraphDSL.create(
|
|
|
|
|
triggerSource,
|
|
|
|
|
messageSink,
|
|
|
|
|
(p, s) -> new Pair<>(p, s),
|
|
|
|
|
(builder, source, sink) -> {
|
|
|
|
|
final SourceShape<Message> elements =
|
|
|
|
|
builder.add(
|
|
|
|
|
Source.from(Arrays.asList("1", "2", "3", "4"))
|
|
|
|
|
.map(t -> new Message(t)));
|
|
|
|
|
final FanInShape2<Message, Trigger, Message> zipWith =
|
|
|
|
|
builder.add(ZipWith.create((msg, trigger) -> msg));
|
|
|
|
|
builder.from(elements).toInlet(zipWith.in0());
|
|
|
|
|
builder.from(source).toInlet(zipWith.in1());
|
|
|
|
|
builder.from(zipWith.out()).to(sink);
|
|
|
|
|
return ClosedShape.getInstance();
|
|
|
|
|
}));
|
|
|
|
|
// #manually-triggered-stream-zipwith
|
2016-01-13 16:25:24 +01:00
|
|
|
|
2019-08-23 18:19:27 +02:00
|
|
|
Pair<TestPublisher.Probe<Trigger>, TestSubscriber.Probe<Message>> pubSub = g.run(system);
|
2016-01-13 16:25:24 +01:00
|
|
|
TestPublisher.Probe<Trigger> pub = pubSub.first();
|
|
|
|
|
TestSubscriber.Probe<Message> sub = pubSub.second();
|
|
|
|
|
|
|
|
|
|
FiniteDuration timeout = FiniteDuration.create(100, TimeUnit.MILLISECONDS);
|
|
|
|
|
sub.expectSubscription().request(1000);
|
2018-07-25 09:38:33 +01:00
|
|
|
sub.expectNoMessage(timeout);
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
sub.expectNext(new Message("1"));
|
2018-07-25 09:38:33 +01:00
|
|
|
sub.expectNoMessage(timeout);
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
sub.expectNext(new Message("2"));
|
|
|
|
|
sub.expectNext(new Message("3"));
|
2018-07-25 09:38:33 +01:00
|
|
|
sub.expectNoMessage(timeout);
|
2016-01-13 16:25:24 +01:00
|
|
|
|
|
|
|
|
pub.sendNext(TRIGGER);
|
|
|
|
|
sub.expectNext(new Message("4"));
|
|
|
|
|
sub.expectComplete();
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
}
|