Skip to content

Commit

Permalink
Polish "Add error rendering support with @WebFluxTest"
Browse files Browse the repository at this point in the history
Closes gh-16266
  • Loading branch information
snicoll committed Mar 29, 2019
1 parent 53e7484 commit 090f5f5
Showing 1 changed file with 14 additions and 6 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright 2012-2018 the original author or authors.
* Copyright 2012-2019 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand All @@ -18,7 +18,7 @@
import reactor.core.publisher.Mono;

import org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest;
import org.springframework.core.Ordered;
import org.springframework.boot.web.reactive.error.ErrorWebExceptionHandler;
import org.springframework.core.annotation.Order;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;
Expand All @@ -29,16 +29,24 @@
* Example {@link WebExceptionHandler} used with {@link WebFluxTest} tests.
*
* @author Madhura Bhave
* @author Ali Dehghani
*/
@Component
@Order(Ordered.HIGHEST_PRECEDENCE)
@Order(-2)
public class ExampleWebExceptionHandler implements WebExceptionHandler {

private final ErrorWebExceptionHandler fallback;

public ExampleWebExceptionHandler(ErrorWebExceptionHandler fallback) {
this.fallback = fallback;
}

@Override
public Mono<Void> handle(ServerWebExchange exchange, Throwable ex) {
exchange.getResponse().setStatusCode(HttpStatus.BAD_REQUEST);
return exchange.getResponse().setComplete();
if (ex instanceof RuntimeException && "foo".equals(ex.getMessage())) {
exchange.getResponse().setStatusCode(HttpStatus.BAD_REQUEST);
return exchange.getResponse().setComplete();
}
return this.fallback.handle(exchange, ex);
}

}

0 comments on commit 090f5f5

Please sign in to comment.