Java Code Examples for reactor.core.publisher.Flux#just()
The following examples show how to use
reactor.core.publisher.Flux#just() .
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: DefaultServerRequestTests.java From java-technology-stack with MIT License | 6 votes |
@Test public void bodyToMonoParameterizedTypeReference() { DefaultDataBufferFactory factory = new DefaultDataBufferFactory(); DefaultDataBuffer dataBuffer = factory.wrap(ByteBuffer.wrap("foo".getBytes(StandardCharsets.UTF_8))); Flux<DataBuffer> body = Flux.just(dataBuffer); HttpHeaders httpHeaders = new HttpHeaders(); httpHeaders.setContentType(MediaType.TEXT_PLAIN); MockServerHttpRequest mockRequest = MockServerHttpRequest .method(HttpMethod.GET, "http://example.com?foo=bar") .headers(httpHeaders) .body(body); DefaultServerRequest request = new DefaultServerRequest(MockServerWebExchange.from(mockRequest), messageReaders); ParameterizedTypeReference<String> typeReference = new ParameterizedTypeReference<String>() {}; Mono<String> resultMono = request.bodyToMono(typeReference); assertEquals("foo", resultMono.block()); }
Example 2
Source File: DefaultServerRequestTests.java From java-technology-stack with MIT License | 6 votes |
@Test public void bodyUnacceptable() { DefaultDataBufferFactory factory = new DefaultDataBufferFactory(); DefaultDataBuffer dataBuffer = factory.wrap(ByteBuffer.wrap("foo".getBytes(StandardCharsets.UTF_8))); Flux<DataBuffer> body = Flux.just(dataBuffer); HttpHeaders httpHeaders = new HttpHeaders(); httpHeaders.setContentType(MediaType.TEXT_PLAIN); MockServerHttpRequest mockRequest = MockServerHttpRequest .method(HttpMethod.GET, "http://example.com?foo=bar") .headers(httpHeaders) .body(body); DefaultServerRequest request = new DefaultServerRequest(MockServerWebExchange.from(mockRequest), Collections.emptyList()); Flux<String> resultFlux = request.bodyToFlux(String.class); StepVerifier.create(resultFlux) .expectError(UnsupportedMediaTypeStatusException.class) .verify(); }
Example 3
Source File: Jackson2JsonEncoderTests.java From spring-analysis-note with MIT License | 6 votes |
@Test public void encodeNonStream() { Flux<Pojo> input = Flux.just( new Pojo("foo", "bar"), new Pojo("foofoo", "barbar"), new Pojo("foofoofoo", "barbarbar") ); testEncode(input, Pojo.class, step -> step .consumeNextWith(expectString("[" + "{\"foo\":\"foo\",\"bar\":\"bar\"}," + "{\"foo\":\"foofoo\",\"bar\":\"barbar\"}," + "{\"foo\":\"foofoofoo\",\"bar\":\"barbarbar\"}]") .andThen(DataBufferUtils::release)) .verifyComplete()); }
Example 4
Source File: BodyExtractorsTests.java From spring-analysis-note with MIT License | 6 votes |
@Test public void toFlux() { BodyExtractor<Flux<String>, ReactiveHttpInputMessage> extractor = BodyExtractors.toFlux(String.class); DefaultDataBufferFactory factory = new DefaultDataBufferFactory(); DefaultDataBuffer dataBuffer = factory.wrap(ByteBuffer.wrap("foo".getBytes(StandardCharsets.UTF_8))); Flux<DataBuffer> body = Flux.just(dataBuffer); MockServerHttpRequest request = MockServerHttpRequest.post("/").body(body); Flux<String> result = extractor.extract(request, this.context); StepVerifier.create(result) .expectNext("foo") .expectComplete() .verify(); }
Example 5
Source File: WebSocketSampleApplicationTest.java From vertx-spring-boot with Apache License 2.0 | 6 votes |
@Test public void testWebSocket() { Flux<String> originalMessages = Flux.just("first", "second"); List<String> responseMessages = new CopyOnWriteArrayList<>(); disposable = client.execute(serviceUri, session -> { // Convert strings to WebSocket messages and send them Mono<Void> outputMono = session.send(originalMessages.map(session::textMessage)); Mono<Void> inputMono = session.receive() // Receive a messages stream .map(WebSocketMessage::getPayloadAsText) // Extract a payload from each message .doOnNext(responseMessages::add) // Store the payload to a collection .then(); return outputMono.then(inputMono); // Start receiving messages after sending. }).subscribe(); // Subscribe to the socket. Original messages will be sent and then we'll start receiving responses. await() .atMost(2, SECONDS) .until(() -> responseMessages, contains("FIRST", "SECOND")); }
Example 6
Source File: BodyExtractorsTests.java From spring-analysis-note with MIT License | 6 votes |
@Test public void toFormData() { DefaultDataBufferFactory factory = new DefaultDataBufferFactory(); String text = "name+1=value+1&name+2=value+2%2B1&name+2=value+2%2B2&name+3"; DefaultDataBuffer dataBuffer = factory.wrap(ByteBuffer.wrap(text.getBytes(StandardCharsets.UTF_8))); Flux<DataBuffer> body = Flux.just(dataBuffer); MockServerHttpRequest request = MockServerHttpRequest.post("/") .contentType(MediaType.APPLICATION_FORM_URLENCODED) .body(body); Mono<MultiValueMap<String, String>> result = BodyExtractors.toFormData().extract(request, this.context); StepVerifier.create(result) .consumeNextWith(form -> { assertEquals("Invalid result", 3, form.size()); assertEquals("Invalid result", "value 1", form.getFirst("name 1")); List<String> values = form.get("name 2"); assertEquals("Invalid result", 2, values.size()); assertEquals("Invalid result", "value 2+1", values.get(0)); assertEquals("Invalid result", "value 2+2", values.get(1)); assertNull("Invalid result", form.getFirst("name 3")); }) .expectComplete() .verify(); }
Example 7
Source File: StepVerifierTests.java From reactor-core with Apache License 2.0 | 5 votes |
@Test public void cancelInvalid() { Flux<String> flux = Flux.just("bar", "baz"); assertThatExceptionOfType(AssertionError.class) .isThrownBy(() -> StepVerifier.create(flux) .expectNext("foo") .thenCancel() .verify()) .withMessage("expectation \"expectNext(foo)\" failed (expected value: foo; actual value: bar)"); }
Example 8
Source File: MicrometerDuplexConnectionTest.java From rsocket-java with Apache License 2.0 | 5 votes |
@DisplayName("receive gathers metrics") @Test void receive() { Flux<ByteBuf> frames = Flux.just( createTestCancelFrame(), createTestErrorFrame(), createTestKeepaliveFrame(), createTestLeaseFrame(), createTestMetadataPushFrame(), createTestPayloadFrame(), createTestRequestChannelFrame(), createTestRequestFireAndForgetFrame(), createTestRequestNFrame(), createTestRequestResponseFrame(), createTestRequestStreamFrame(), createTestSetupFrame()); when(delegate.receive()).thenReturn(frames); new MicrometerDuplexConnection( CLIENT, delegate, meterRegistry, Tag.of("test-key", "test-value")) .receive() .as(StepVerifier::create) .expectNextCount(12) .verifyComplete(); assertThat(findCounter(CLIENT, CANCEL).count()).isEqualTo(1); assertThat(findCounter(CLIENT, COMPLETE).count()).isEqualTo(1); assertThat(findCounter(CLIENT, ERROR).count()).isEqualTo(1); assertThat(findCounter(CLIENT, KEEPALIVE).count()).isEqualTo(1); assertThat(findCounter(CLIENT, LEASE).count()).isEqualTo(1); assertThat(findCounter(CLIENT, METADATA_PUSH).count()).isEqualTo(1); assertThat(findCounter(CLIENT, REQUEST_CHANNEL).count()).isEqualTo(1); assertThat(findCounter(CLIENT, REQUEST_FNF).count()).isEqualTo(1); assertThat(findCounter(CLIENT, REQUEST_N).count()).isEqualTo(1); assertThat(findCounter(CLIENT, REQUEST_RESPONSE).count()).isEqualTo(1); assertThat(findCounter(CLIENT, REQUEST_STREAM).count()).isEqualTo(1); assertThat(findCounter(CLIENT, SETUP).count()).isEqualTo(1); }
Example 9
Source File: RestServiceController.java From Spring-5.0-Cookbook with MIT License | 5 votes |
@GetMapping(path = "/fluxAddEmp") public Flux<String> addMonoEmp(){ Employee newEmp = new Employee(); newEmp.setEmpid(56758); newEmp.setAge(43); newEmp.setBirthday(new Date(88, 10,10)); newEmp.setDeptid(362); newEmp.setEmail("aloha@gmail.com"); newEmp.setFirstname("John"); newEmp.setLastname("Lowell"); employeeServiceImpl.saveEmployeeRec(newEmp); Flux<String> status = Flux.just("OK"); return status; }
Example 10
Source File: Jackson2SmileEncoderTests.java From spring-analysis-note with MIT License | 5 votes |
@Test public void encodeAsStream() throws Exception { Pojo pojo1 = new Pojo("foo", "bar"); Pojo pojo2 = new Pojo("foofoo", "barbar"); Pojo pojo3 = new Pojo("foofoofoo", "barbarbar"); Flux<Pojo> input = Flux.just(pojo1, pojo2, pojo3); ResolvableType type = ResolvableType.forClass(Pojo.class); testEncodeAll(input, type, step -> step .consumeNextWith(expect(pojo1, Pojo.class)) .consumeNextWith(expect(pojo2, Pojo.class)) .consumeNextWith(expect(pojo3, Pojo.class)) .verifyComplete(), STREAM_SMILE_MIME_TYPE, null); }
Example 11
Source File: ServerHttpResponseTests.java From java-technology-stack with MIT License | 5 votes |
@Test // SPR-14952 public void writeAndFlushWithFluxOfDefaultDataBuffer() throws Exception { TestServerHttpResponse response = new TestServerHttpResponse(); Flux<Flux<DefaultDataBuffer>> flux = Flux.just(Flux.just(wrap("foo"))); response.writeAndFlushWith(flux).block(); assertTrue(response.statusCodeWritten); assertTrue(response.headersWritten); assertTrue(response.cookiesWritten); assertEquals(1, response.body.size()); assertEquals("foo", new String(response.body.get(0).asByteBuffer().array(), StandardCharsets.UTF_8)); }
Example 12
Source File: MonoTests.java From reactor-core with Apache License 2.0 | 5 votes |
@Test public void monoFromDirectCallableFluxCallsAssemblyHook() { final Flux<Integer> source = Flux.just(1); //set the hook AFTER the original operators have been invoked (since they trigger assembly themselves) AtomicInteger wrappedCount = new AtomicInteger(); Hooks.onEachOperator(p -> { wrappedCount.incrementAndGet(); return p; }); Mono.fromDirect(source); Assertions.assertThat(wrappedCount).hasValue(1); }
Example 13
Source File: R011_LetsMeetFlux.java From reactor-workshop with GNU General Public License v3.0 | 5 votes |
@Test public void helloFlux() throws Exception { //given final Flux<String> reactor = Flux.just("Reactor"); //when final List<String> value = reactor.collectList().block(); //then assertThat(value).containsExactly("Reactor"); }
Example 14
Source File: StepVerifierTests.java From reactor-core with Apache License 2.0 | 5 votes |
@Test public void verifyRecordMatchesError2() { Flux<String> flux = Flux.just("foo", "bar", "foobar"); assertThatExceptionOfType(AssertionError.class) .isThrownBy(() -> StepVerifier.create(flux) .expectNext("foo", "bar", "foobar") .expectRecordedMatches(c -> c.size() == 3) .expectComplete() .verify()) .withMessage("expectation \"expectRecordedMatches\" failed (expected record collector; actual record is [null])"); }
Example 15
Source File: SourceToFunctionsSupportTests.java From spring-cloud-stream with Apache License 2.0 | 5 votes |
@PollableBean(splittable = true) public Supplier<Flux<Message<?>>> messageStreamSupplier() { return () -> { Message<String> m1 = new GenericMessage<>(String.valueOf(counter.incrementAndGet())); Message<String> m2 = new GenericMessage<>(String.valueOf(counter.incrementAndGet())); Message<String> m3 = new GenericMessage<>(String.valueOf(counter.incrementAndGet())); return Flux.just(m1, m2, m3); }; }
Example 16
Source File: ReactiveTestServiceImpl.java From alibaba-rsocket-broker with Apache License 2.0 | 4 votes |
@Override public Flux<String> findNames() { return Flux.just("first", "second"); }
Example 17
Source File: FreeCapacityFetcherProto.java From linstor-server with GNU General Public License v3.0 | 4 votes |
private Flux<Tuple2<StorPool.Key, Tuple2<SpaceInfo, List<ApiCallRc>>>> parseFreeSpacesInTransaction( Tuple2<NodeName, ByteArrayInputStream> freeSpaceAnswer ) { List<Tuple2<Key, Tuple2<SpaceInfo, List<ApiCallRc>>>> ret = new ArrayList<>(); try { NodeName nodeName = freeSpaceAnswer.getT1(); ByteArrayInputStream freeSpaceMsgDataIn = freeSpaceAnswer.getT2(); MsgIntFreeSpace freeSpaces = MsgIntFreeSpace.parseDelimitedFrom(freeSpaceMsgDataIn); for (StorPoolFreeSpace freeSpaceInfo : freeSpaces.getFreeSpacesList()) { List<ApiCallRc> apiCallRcs = new ArrayList<>(); if (freeSpaceInfo.getErrorsCount() > 0) { ApiCallRcImpl apiCallRc = new ApiCallRcImpl(); for (ApiCallResponse msgApiCallResponse : freeSpaceInfo.getErrorsList()) { apiCallRc.addEntry( ProtoDeserializationUtils.parseApiCallRc( msgApiCallResponse, "Node: '" + nodeName + "', storage pool: '" + freeSpaceInfo.getStorPoolName() + "' - " ) ); } apiCallRcs.add(apiCallRc); } StorPoolName storPoolName = new StorPoolName(freeSpaceInfo.getStorPoolName()); long freeCapacity = freeSpaceInfo.getFreeCapacity(); long totalCapacity = freeSpaceInfo.getTotalCapacity(); ret.add( Tuples.of( new StorPool.Key(nodeName, storPoolName), Tuples.of( new SpaceInfo(totalCapacity, freeCapacity), apiCallRcs ) ) ); // also update storage pool's freespacemanager StorPool storPool = nodeRepository.get(apiCtx, nodeName).getStorPool(apiCtx, storPoolName); storPool.getFreeSpaceTracker().setCapacityInfo(apiCtx, freeCapacity, totalCapacity); ctrlTransactionHelper.commit(); } } catch (IOException | InvalidNameException | AccessDeniedException exc) { throw new ImplementationError(exc); } return Flux.just(ret.toArray(new Tuple2[0])); }
Example 18
Source File: OpenWhiskActionHandler.java From spring-cloud-function with Apache License 2.0 | 4 votes |
private Flux<?> extract(Object input) { if (input instanceof Collection) { return Flux.fromIterable((Iterable<?>) input); } return Flux.just(input); }
Example 19
Source File: CtrlRscDfnDeleteApiCallHandler.java From linstor-server with GNU General Public License v3.0 | 4 votes |
private Flux<ApiCallRc> deleteResourceDefinitionInTransaction(String rscNameStr) { requireRscDfnMapChangeAccess(); ResourceDefinition rscDfn = ctrlApiDataLoader.loadRscDfn(rscNameStr, false); if (rscDfn == null) { throw new ApiRcException(ApiCallRcImpl.simpleEntry( ApiConsts.WARN_NOT_FOUND, getRscDfnDescription(rscNameStr) + " not found." )); } if (hasSnapshotsPrivileged(rscDfn)) { throw new ApiRcException(ApiCallRcImpl.simpleEntry( ApiConsts.FAIL_EXISTS_SNAPSHOT_DFN, "Cannot delete " + getRscDfnDescriptionInline(rscNameStr) + " because it has snapshots." )); } Optional<Resource> rscInUse = null; rscInUse = anyResourceInUsePrivileged(rscDfn); if (rscInUse.isPresent()) { NodeName nodeName = rscInUse.get().getNode().getName(); throw new ApiRcException(ApiCallRcImpl .entryBuilder( ApiConsts.FAIL_IN_USE, String.format("Resource '%s' on node '%s' is still in use.", rscNameStr, nodeName.displayValue) ) .setCause("Resource is mounted/in use.") .setCorrection(String.format("Un-mount resource '%s' on the node '%s'.", rscNameStr, nodeName.displayValue)) .build() ); } Flux<ApiCallRc> flux; ResourceName rscName = rscDfn.getName(); UUID rscDfnUuid = rscDfn.getUuid(); String descriptionFirstLetterCaps = firstLetterCaps(getRscDfnDescriptionInline(rscNameStr)); if (rscDfn.getResourceCount() > 0) { markDeleted(rscDfn); ctrlTransactionHelper.commit(); ApiCallRc responses = ApiCallRcImpl.singletonApiCallRc( ApiCallRcImpl.entryBuilder(ApiConsts.DELETED, descriptionFirstLetterCaps + " marked for deletion.") .setDetails(descriptionFirstLetterCaps + " UUID is: " + rscDfnUuid).build() ); flux = Flux .just(responses) // first delete diskless resources, because DRBD raises an error if all peers with disks are // removed from a diskless resource .concatWith(deleteDiskless(rscName)); } else { flux = Flux.just(commitDeleteRscDfnData(rscDfn)); } return flux; }
Example 20
Source File: HttpGetIntegrationTests.java From spring-cloud-function with Apache License 2.0 | 4 votes |
@Bean public Supplier<Flux<Foo>> foos() { return () -> Flux.just(new Foo("foo"), new Foo("bar")); }