Skip to content

Commit

Permalink
Polishing.
Browse files Browse the repository at this point in the history
Reuse connection-closed exception factory method.

[#492]

Signed-off-by: Mark Paluch <mpaluch@vmware.com>
  • Loading branch information
mp911de committed Feb 16, 2022
1 parent 1e692fc commit 6c98f43
Showing 1 changed file with 15 additions and 4 deletions.
19 changes: 15 additions & 4 deletions src/main/java/io/r2dbc/postgresql/client/ReactorNettyClient.java
Original file line number Diff line number Diff line change
Expand Up @@ -214,14 +214,22 @@ public Flux<BackendMessage> exchange(Predicate<BackendMessage> takeUntil, Publis
Assert.requireNonNull(takeUntil, "takeUntil must not be null");
Assert.requireNonNull(requests, "requests must not be null");

return this.messageSubscriber.addConversation(takeUntil, requests, this.requests::next, this::isConnected);
if (!isConnected()) {
return Flux.error(this.messageSubscriber.createClientClosedException());
}

return this.messageSubscriber.addConversation(takeUntil, requests, this::doSendRequest, this::isConnected);
}

@Override
public void send(FrontendMessage message) {
Assert.requireNonNull(message, "requests must not be null");

this.requests.next(Mono.just(message));
doSendRequest(Mono.just(message));
}

private void doSendRequest(Publisher<FrontendMessage> it) {
this.requests.next(it);
}

private Mono<Void> resumeError(Throwable throwable) {
Expand Down Expand Up @@ -695,7 +703,7 @@ public Flux<BackendMessage> addConversation(Predicate<BackendMessage> takeUntil,
sink.onRequest(value -> onRequest(conversation, value));

if (!isConnected.get()) {
sink.error(new PostgresConnectionClosedException("Cannot exchange messages because the connection is closed"));
sink.error(createClientClosedException());
return;
}

Expand All @@ -708,12 +716,15 @@ public Flux<BackendMessage> addConversation(Predicate<BackendMessage> takeUntil,
sender.accept(requestMessages);
} else {
sink.error(new RequestQueueException("Cannot exchange messages because the request queue limit is exceeded"));

}
}
});
}

PostgresConnectionClosedException createClientClosedException() {
return new PostgresConnectionClosedException("Cannot exchange messages because the connection is closed");
}

/**
* {@link Subscription#request(long)} callback. Request more for a {@link Conversation}. Potentially, demands also more upstream elements.
*
Expand Down

0 comments on commit 6c98f43

Please sign in to comment.