Merge remote-tracking branch 'base-version/main' into dev
This commit is contained in:
@@ -112,8 +112,17 @@ public class HttpStepHandler implements ApiStepHandler {
|
|||||||
Map<String, String> headerMap = resolveHeaders(stepDefinition, payload);
|
Map<String, String> headerMap = resolveHeaders(stepDefinition, payload);
|
||||||
Duration timeout = resolveTimeout(stepDefinition);
|
Duration timeout = resolveTimeout(stepDefinition);
|
||||||
WebClient client = webClientBuilder.build();
|
WebClient client = webClientBuilder.build();
|
||||||
WebClient.RequestHeadersSpec<?> requestSpec = buildRequest(client, callSpec, requestPayload, headerMap, supportsBody);
|
final HttpRequestPayload resolvedPayload = requestPayload;
|
||||||
Mono<Object> responseMono = requestSpec.retrieve().bodyToMono(Object.class);
|
boolean finalSupportsBody = supportsBody;
|
||||||
|
Mono<Object> responseMono = Mono.defer(() -> {
|
||||||
|
// 每次订阅(含重试)都会重新构建请求,避免缓存第一次结果
|
||||||
|
HttpRequestPayload payloadForAttempt = resolvedPayload == null
|
||||||
|
? HttpRequestPayload.of(null, Collections.emptyMap())
|
||||||
|
: resolvedPayload;
|
||||||
|
return buildRequest(client, callSpec, payloadForAttempt, headerMap, finalSupportsBody)
|
||||||
|
.retrieve()
|
||||||
|
.bodyToMono(Object.class);
|
||||||
|
});
|
||||||
responseMono = applyResilientRetry(responseMono, stepDefinition);
|
responseMono = applyResilientRetry(responseMono, stepDefinition);
|
||||||
Object response = timeout == null ? responseMono.block() : responseMono.block(timeout);
|
Object response = timeout == null ? responseMono.block() : responseMono.block(timeout);
|
||||||
payload.addStepResult(ApiStepResult.builder()
|
payload.addStepResult(ApiStepResult.builder()
|
||||||
|
|||||||
Reference in New Issue
Block a user