Align lazy and future operators #26446
This commit is contained in:
parent
4a72985e48
commit
74adecb4e7
59 changed files with 2091 additions and 384 deletions
|
|
@ -0,0 +1,67 @@
|
|||
/*
|
||||
* Copyright (C) 2019 Lightbend Inc. <https://www.lightbend.com>
|
||||
*/
|
||||
|
||||
package akka.stream.javadsl;
|
||||
|
||||
import akka.NotUsed;
|
||||
import akka.stream.StreamTest;
|
||||
import akka.testkit.AkkaJUnitActorSystemResource;
|
||||
import akka.testkit.AkkaSpec;
|
||||
import org.junit.ClassRule;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.CompletableFuture;
|
||||
import java.util.concurrent.CompletionStage;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
|
||||
public class LazyAndFutureFlowTest extends StreamTest {
|
||||
|
||||
@ClassRule
|
||||
public static AkkaJUnitActorSystemResource actorSystemResource =
|
||||
new AkkaJUnitActorSystemResource("LazyAndFutureFlowTest", AkkaSpec.testConf());
|
||||
|
||||
public LazyAndFutureFlowTest() {
|
||||
super(actorSystemResource);
|
||||
}
|
||||
|
||||
// note these are minimal happy path tests to cover API, more thorough tests are on the Scala side
|
||||
|
||||
@Test
|
||||
public void completionStageFlow() throws Exception {
|
||||
CompletionStage<List<String>> result =
|
||||
Source.single("one")
|
||||
.via(
|
||||
Flow.completionStageFlow(
|
||||
CompletableFuture.completedFuture(Flow.fromFunction(str -> str))))
|
||||
.runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), result.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void lazyFlow() throws Exception {
|
||||
CompletionStage<List<String>> result =
|
||||
Source.single("one")
|
||||
.via(Flow.lazyFlow(() -> Flow.fromFunction(str -> str)))
|
||||
.runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), result.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void lazyCompletionStageFlow() throws Exception {
|
||||
CompletionStage<List<String>> result =
|
||||
Source.single("one")
|
||||
.via(
|
||||
Flow.lazyCompletionStageFlow(
|
||||
() -> CompletableFuture.completedFuture(Flow.fromFunction(str -> str))))
|
||||
.runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), result.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,106 @@
|
|||
/*
|
||||
* Copyright (C) 2009-2019 Lightbend Inc. <https://www.lightbend.com>
|
||||
*/
|
||||
|
||||
package akka.stream.javadsl;
|
||||
|
||||
import akka.Done;
|
||||
import akka.NotUsed;
|
||||
import akka.japi.Pair;
|
||||
import akka.stream.StreamTest;
|
||||
import akka.testkit.AkkaJUnitActorSystemResource;
|
||||
import akka.testkit.AkkaSpec;
|
||||
import org.junit.ClassRule;
|
||||
import org.junit.Test;
|
||||
import scala.concurrent.Future;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.CompletableFuture;
|
||||
import java.util.concurrent.CompletionStage;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
|
||||
public class LazyAndFutureSourcesTest extends StreamTest {
|
||||
|
||||
@ClassRule
|
||||
public static AkkaJUnitActorSystemResource actorSystemResource =
|
||||
new AkkaJUnitActorSystemResource("LazyAndFutureSourcesTest", AkkaSpec.testConf());
|
||||
|
||||
public LazyAndFutureSourcesTest() {
|
||||
super(actorSystemResource);
|
||||
}
|
||||
|
||||
// note these are minimal happy path tests to cover API, more thorough tests are on the Scala side
|
||||
|
||||
@Test
|
||||
public void future() throws Exception {
|
||||
CompletionStage<List<String>> result =
|
||||
Source.future(Future.successful("one")).runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), result.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void completionStage() throws Exception {
|
||||
CompletionStage<String> one = CompletableFuture.completedFuture("one");
|
||||
CompletionStage<List<String>> result = Source.completionStage(one).runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), result.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void completionStageSource() throws Exception {
|
||||
Pair<CompletionStage<NotUsed>, CompletionStage<List<String>>> result =
|
||||
Source.completionStageSource(CompletableFuture.completedFuture(Source.single("one")))
|
||||
.toMat(Sink.seq(), Keep.both())
|
||||
.run(system);
|
||||
|
||||
CompletionStage<NotUsed> nestedMatVal = result.first();
|
||||
CompletionStage<List<String>> list = result.second();
|
||||
assertEquals(Arrays.asList("one"), list.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
assertEquals(true, nestedMatVal.toCompletableFuture().isDone());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void lazySingle() throws Exception {
|
||||
CompletionStage<List<String>> list = Source.lazySingle(() -> "one").runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), list.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void lazyCompletionStage() throws Exception {
|
||||
CompletionStage<List<String>> list =
|
||||
Source.lazyCompletionStage(() -> CompletableFuture.completedFuture("one"))
|
||||
.runWith(Sink.seq(), system);
|
||||
|
||||
assertEquals(Arrays.asList("one"), list.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void lazySource() throws Exception {
|
||||
Pair<CompletionStage<NotUsed>, CompletionStage<List<String>>> result =
|
||||
Source.lazySource(() -> Source.single("one")).toMat(Sink.seq(), Keep.both()).run(system);
|
||||
|
||||
CompletionStage<NotUsed> nestedMatVal = result.first();
|
||||
CompletionStage<List<String>> list = result.second();
|
||||
assertEquals(Arrays.asList("one"), list.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
assertEquals(true, nestedMatVal.toCompletableFuture().isDone());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void lazyCompletionStageSource() throws Exception {
|
||||
Pair<CompletionStage<NotUsed>, CompletionStage<List<String>>> result =
|
||||
Source.lazyCompletionStageSource(
|
||||
() -> CompletableFuture.completedFuture(Source.single("one")))
|
||||
.toMat(Sink.seq(), Keep.both())
|
||||
.run(system);
|
||||
|
||||
CompletionStage<NotUsed> nestedMatVal = result.first();
|
||||
CompletionStage<List<String>> list = result.second();
|
||||
assertEquals(Arrays.asList("one"), list.toCompletableFuture().get(3, TimeUnit.SECONDS));
|
||||
assertEquals(true, nestedMatVal.toCompletableFuture().isDone());
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue