Java Code Examples for reactor.core.publisher.Flux#create()
The following examples show how to use
reactor.core.publisher.Flux#create() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: LoadBalancedRSocketMonoTest.java From rsocket-java with Apache License 2.0 | 6 votes |
@Test(timeout = 10_000L) public void testRefreshesSocketsOnSelectBeforeReturningFailedAfterNewFactoriesDelivered() { TestingRSocket socket = new TestingRSocket(Function.identity()); CompletableFuture<RSocketSupplier> laterSupplier = new CompletableFuture<>(); Flux<List<RSocketSupplier>> factories = Flux.create( s -> { s.next(Collections.emptyList()); laterSupplier.handle( (RSocketSupplier result, Throwable t) -> { s.next(Collections.singletonList(result)); return null; }); }); LoadBalancedRSocketMono balancer = LoadBalancedRSocketMono.create(factories); Assert.assertEquals(0.0, balancer.availability(), 0); laterSupplier.complete(succeedingFactory(socket)); balancer.rSocketMono.block(); Assert.assertEquals(1.0, balancer.availability(), 0); }
Example 2
Source File: RetryHandlerBuilderTest.java From titus-control-plane with Apache License 2.0 | 6 votes |
private Flux<String> fluxOf(Object... items) { AtomicInteger pos = new AtomicInteger(); return Flux.create(sink -> { for (int i = pos.get(); i < items.length; i++) { pos.incrementAndGet(); Object item = items[i]; if (item instanceof Throwable) { sink.error((Throwable) item); return; } sink.next((String) item); } sink.complete(); }); }
Example 3
Source File: R023_CallbackToFlux.java From reactor-workshop with GNU General Public License v3.0 | 6 votes |
/** * TODO terminate the stream when <code>null</code> is received from callback. * Hint: <code>sink.complete()</code> */ @Test public void handleNullAsEndOfStream() throws Exception { //when final Flux<Email> emails = Flux .create(sink -> inbox.read("spam@example.com", e -> { if (e != null) { sink.next(e); } else { sink.complete(); } })); //then emails .as(StepVerifier::create) .expectNextCount(2) .verifyComplete(); }
Example 4
Source File: TcpController.java From jetlinks-community with Apache License 2.0 | 6 votes |
@GetMapping(value = "/server/{id}/_subscribe/{type}", produces = MediaType.TEXT_EVENT_STREAM_VALUE) public Flux<TcpClientMessage> serverSubscribe(@PathVariable String id, @PathVariable PayloadType type) { return Flux.create(sink -> { sink.onDispose(networkManager.<TcpServer>getNetwork(DefaultNetworkType.TCP_SERVER, id) .flatMapMany(TcpServer::handleConnection) .flatMap(client -> { String address = client.getRemoteAddress().toString(); sink.next(new TcpClientMessage(address, "已建立连接")); client.onDisconnect(() -> sink.next(new TcpClientMessage(address, "已断开连接"))); return client .subscribe() .map(msg -> new TcpClientMessage(address, type.read(msg.getPayload()))); }) .subscriberContext(sink.currentContext()) .subscribe(sink::next)); }); }
Example 5
Source File: Archaius2Ext.java From titus-control-plane with Apache License 2.0 | 5 votes |
/** * Observe property value changes. Emits current value on subscriptions. */ public static <T> Flux<T> watch(Property<T> property) { Flux<T> observer = Flux.create(emitter -> { Property.Subscription subscription = property.subscribe(emitter::next); emitter.onCancel(subscription::unsubscribe); }); return Flux.just(property.get()).concatWith(observer); }
Example 6
Source File: FluxConverter.java From smallrye-reactive-streams-operators with Apache License 2.0 | 5 votes |
@Override public <X> Flux fromCompletionStage(CompletionStage<X> cs) { return Flux.create(sink -> cs.whenComplete((X v, Throwable e) -> { if (e != null) { sink.error(e instanceof CompletionException ? e.getCause() : e); } else if (v != null) { sink.next(v); sink.complete(); } else { sink.complete(); } })); }
Example 7
Source File: MyApi.java From titus-control-plane with Apache License 2.0 | 5 votes |
@Override public Flux<String> fluxEcho(String message) { return Flux.create(emitter -> { emitter.next(buildReply(message)); emitter.complete(); }); }
Example 8
Source File: RedissonTimeSeriesReactive.java From redisson with Apache License 2.0 | 5 votes |
public Publisher<V> iterator() { return Flux.create(new SetReactiveIterator<V>() { @Override protected RFuture<ListScanResult<Object>> scanIterator(RedisClient client, long nextIterPos) { return ((RedissonTimeSeries) instance).scanIteratorAsync(instance.getName(), client, nextIterPos, null, 10); } }); }
Example 9
Source File: QuotaEventEmitter.java From titus-control-plane with Apache License 2.0 | 5 votes |
public Flux<EvictionEvent> events(boolean includeSnapshot) { return Flux.create(sink -> { Preconditions.checkState(scheduleReference != null && !scheduleReference.isClosed()); eventSubscriberSinks.add(new SinkHolder(sink, includeSnapshot)); sink.onDispose(() -> eventSubscriberSinks.remove(sink)); }); }
Example 10
Source File: R023_CallbackToFlux.java From reactor-workshop with GNU General Public License v3.0 | 5 votes |
/** * TODO use {@link Flux#as(Function)} operator with {@link #toList(Flux)} method */ @Test public void asOperator() throws Exception { //given final Flux<Email> foo = Flux.create(sink -> inbox.read("foo@example.com", sink::next)); //when final List<Email> emails = toList(foo); //then assertThat(emails).hasSize(3); }
Example 11
Source File: FluxSinkApplication.java From spring-5-examples with MIT License | 5 votes |
@Bean Flux<ServerSentEvent<Map>> processor(final List<FluxSink<ServerSentEvent<Map>>> subscribers) { return Flux.create( fluxSink -> subscribers.add( fluxSink.onCancel(() -> subscribers.remove(fluxSink)) .onDispose(() -> log.debug("disposing...")) .onRequest(i -> log.debug("{} subscribers on request", subscribers.size())))); }
Example 12
Source File: GrpcRetryTest.java From reactive-grpc with BSD 3-Clause "New" or "Revised" License | 5 votes |
private Flux<Integer> newThreeErrorFlux() { return Flux.create(new Consumer<FluxSink<Integer>>() { int count = 3; @Override public void accept(FluxSink<Integer> emitter) { if (count > 0) { emitter.error(new Throwable("Not yet!")); count--; } else { emitter.next(0); emitter.complete(); } } }, FluxSink.OverflowStrategy.BUFFER); }
Example 13
Source File: StateStoreRepository.java From football-events with MIT License | 5 votes |
public Flux<T> findAll() { return Flux.create(sink -> { var iterator = store().all(); while (iterator.hasNext()) { sink.next(iterator.next().value); } iterator.close(); sink.complete(); }); }
Example 14
Source File: GuideTests.java From reactor-core with Apache License 2.0 | 5 votes |
@Test public void producingCreate() { Flux<String> bridge = Flux.create(sink -> { myEventProcessor.register( // <4> new MyEventListener<String>() { // <1> public void onDataChunk(List<String> chunk) { for(String s : chunk) { sink.next(s); // <2> } } public void processComplete() { sink.complete(); // <3> } }); }); StepVerifier.withVirtualTime(() -> bridge) .expectSubscription() .expectNoEvent(Duration.ofSeconds(10)) .then(() -> myEventProcessor.dataChunk("foo", "bar", "baz")) .expectNext("foo", "bar", "baz") .expectNoEvent(Duration.ofSeconds(10)) .then(() -> myEventProcessor.processComplete()) .verifyComplete(); }
Example 15
Source File: SourceToFunctionsSupportTests.java From spring-cloud-stream with Apache License 2.0 | 5 votes |
@Bean public Supplier<Flux<String>> numberReactive() { return () -> Flux.create(emitter -> { for (int i = 0; i < 3; i++) { emitter.next(String.valueOf(i)); } }); }
Example 16
Source File: BlobCodecTest.java From r2dbc-mysql with Apache License 2.0 | 5 votes |
@Override public Flux<ByteBuffer> stream() { return Flux.create(sink -> { for (byte[] value : values) { if (sink.isCancelled()) { return; } ByteBuffer buffer = ByteBuffer.allocate(value.length); buffer.put(value).flip(); sink.next(buffer); } sink.complete(); }); }
Example 17
Source File: FluxToCompletionStageTest.java From smallrye-reactive-streams-operators with Apache License 2.0 | 5 votes |
@Override protected Optional<Flux> createInstanceEmittingAMultipleValuesAndFailure(String v1, String v2, RuntimeException e) { Flux<String> stream = Flux.create(emitter -> { emitter.next(v1); emitter.next(v2); emitter.error(e); }); return Optional.of(stream); }
Example 18
Source File: HttpRequestOperation.java From styx with Apache License 2.0 | 5 votes |
public Flux<LiveHttpResponse> execute(NettyConnection nettyConnection) { AtomicReference<RequestBodyChunkSubscriber> requestRequestBodyChunkSubscriber = new AtomicReference<>(); requestTime = System.currentTimeMillis(); executeCount.incrementAndGet(); Flux<LiveHttpResponse> responseFlux = Flux.create(sink -> { if (nettyConnection.isConnected()) { RequestBodyChunkSubscriber bodyChunkSubscriber = new RequestBodyChunkSubscriber(request, nettyConnection); requestRequestBodyChunkSubscriber.set(bodyChunkSubscriber); addProxyBridgeHandlers(nettyConnection, sink); new WriteRequestToOrigin(sink, nettyConnection, request, bodyChunkSubscriber) .write(); if (requestLoggingEnabled) { httpRequestMessageLogger.logRequest(request, nettyConnection.getOrigin()); } } else { sink.error(new TransportLostException(nettyConnection.channel(), nettyConnection.getOrigin())); } }); if (requestLoggingEnabled) { responseFlux = responseFlux .doOnNext(response -> { httpRequestMessageLogger.logResponse(request, response); }); } return responseFlux.map(response -> Requests.doFinally(response, cause -> { if (nettyConnection.isConnected()) { removeProxyBridgeHandlers(nettyConnection); if (requestIsOngoing(requestRequestBodyChunkSubscriber.get())) { LOGGER.warn("Origin responded too quickly to an ongoing request, or it was cancelled. Connection={}, Request={}.", new Object[]{nettyConnection.channel(), this.request}); nettyConnection.close(); requestRequestBodyChunkSubscriber.get().dispose(); } } })); }
Example 19
Source File: DataBufferUtils.java From spring-analysis-note with MIT License | 3 votes |
/** * Write the given stream of {@link DataBuffer DataBuffers} to the given * {@code WritableByteChannel}. Does <strong>not</strong> close the channel * when the flux is terminated, and does <strong>not</strong> * {@linkplain #release(DataBuffer) release} the data buffers in the source. * If releasing is required, then subscribe to the returned {@code Flux} * with a {@link #releaseConsumer()}. * <p>Note that the writing process does not start until the returned * {@code Flux} is subscribed to. * @param source the stream of data buffers to be written * @param channel the channel to write to * @return a Flux containing the same buffers as in {@code source}, that * starts the writing process when subscribed to, and that publishes any * writing errors and the completion signal */ public static Flux<DataBuffer> write(Publisher<DataBuffer> source, WritableByteChannel channel) { Assert.notNull(source, "'source' must not be null"); Assert.notNull(channel, "'channel' must not be null"); Flux<DataBuffer> flux = Flux.from(source); return Flux.create(sink -> { WritableByteChannelSubscriber subscriber = new WritableByteChannelSubscriber(sink, channel); sink.onDispose(subscriber); flux.subscribe(subscriber); }); }
Example 20
Source File: DataBufferUtils.java From spring-analysis-note with MIT License | 3 votes |
/** * Write the given stream of {@link DataBuffer DataBuffers} to the given * {@code AsynchronousFileChannel}. Does <strong>not</strong> close the channel * when the flux is terminated, and does <strong>not</strong> * {@linkplain #release(DataBuffer) release} the data buffers in the source. * If releasing is required, then subscribe to the returned {@code Flux} with a * {@link #releaseConsumer()}. * <p>Note that the writing process does not start until the returned * {@code Flux} is subscribed to. * @param source the stream of data buffers to be written * @param channel the channel to write to * @param position file position write write is to begin; must be non-negative * @return a flux containing the same buffers as in {@code source}, that * starts the writing process when subscribed to, and that publishes any * writing errors and the completion signal */ public static Flux<DataBuffer> write( Publisher<DataBuffer> source, AsynchronousFileChannel channel, long position) { Assert.notNull(source, "'source' must not be null"); Assert.notNull(channel, "'channel' must not be null"); Assert.isTrue(position >= 0, "'position' must be >= 0"); Flux<DataBuffer> flux = Flux.from(source); return Flux.create(sink -> { WriteCompletionHandler handler = new WriteCompletionHandler(sink, channel, position); sink.onDispose(handler); flux.subscribe(handler); }); }