Skip to content

Commit

Permalink
fix(webserver): create execution don't display error
Browse files Browse the repository at this point in the history
close #4673
  • Loading branch information
tchiotludo committed Aug 16, 2024
1 parent 492f5f4 commit fd19334
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@
import io.micronaut.scheduling.TaskExecutors;
import io.micronaut.scheduling.annotation.ExecuteOn;
import io.micronaut.validation.Validated;
import io.netty.util.IllegalReferenceCountException;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.media.Content;
Expand Down Expand Up @@ -590,13 +591,21 @@ public Publisher<Execution> create(
sink.success(item);
}
});
sink.onDispose(() -> receive.run());

sink.onDispose(receive::run);
}
} catch (IOException e) {
sink.error(new RuntimeException(e));
}
})
.doOnError(t -> Flux.from(inputs).subscribeOn(Schedulers.boundedElastic()).blockLast()); // need to consume the inputs in case of error;
.doOnError(t -> {
// need to consume the inputs in case of error, that can failed, but we ignored
try {
Flux.from(inputs).subscribeOn(Schedulers.boundedElastic()).blockLast();
} catch (IllegalReferenceCountException ignored) {

}
});
}

private List<Label> parseLabels(List<String> labels) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,7 @@ private Execution triggerExecution(String namespace, String flowId, MultipartBod
Execution.class
);
}

private MultipartBody createInputsFlowBody() {
// Trigger execution
File applicationFile = new File(Objects.requireNonNull(
Expand Down Expand Up @@ -187,6 +188,25 @@ void trigger() {
assertThat(notFound.getStatus(), is(HttpStatus.NOT_FOUND));
}


@Test
void invalidInputs() {
MultipartBody.Builder builder = MultipartBody.builder()
.addPart("validatedString", "B-failed");
inputs.forEach((s, o) -> builder.addPart(s, o instanceof String ? (String) o : null));

HttpClientResponseException e = assertThrows(
HttpClientResponseException.class,
() -> triggerExecution(TESTS_FLOW_NS, "inputs", builder.build(), false)
);

String response = e.getResponse().getBody(String.class).orElseThrow();

assertThat(response, containsString("Invalid entity"));
assertThat(response, containsString("Invalid input for `validatedString`"));
}


@Test
void triggerAndWait() {
Execution result = triggerInputsFlowExecution(true);
Expand Down

0 comments on commit fd19334

Please sign in to comment.