From 6f53e362aec269c030ec0e5a28f8ae65da57ae68 Mon Sep 17 00:00:00 2001 From: Georgios Andrianakis Date: Thu, 4 Apr 2024 09:14:19 +0300 Subject: [PATCH] Use cache-control header to make sure health checks aren't cached Fixes: #39868 --- .../health/test/HealthCheckProducerDefaultScopeTest.java | 2 ++ .../smallrye/health/runtime/SmallRyeHealthHandlerBase.java | 4 +++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/HealthCheckProducerDefaultScopeTest.java b/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/HealthCheckProducerDefaultScopeTest.java index 4233aa75967f1..0b3921302320d 100644 --- a/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/HealthCheckProducerDefaultScopeTest.java +++ b/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/HealthCheckProducerDefaultScopeTest.java @@ -31,10 +31,12 @@ void testHealth() { try { RestAssured.defaultParser = Parser.JSON; when().get("/q/health/ready").then() + .header("cache-control", "no-store") .body("status", is("UP"), "checks.status", hasItems("UP", "UP"), "checks.name", hasItems("alpha1", "bravo1")); when().get("/q/health/ready").then() + .header("cache-control", "no-store") .body("status", is("UP"), "checks.status", hasItems("UP", "UP"), "checks.name", hasItems("alpha1", "bravo2")); diff --git a/extensions/smallrye-health/runtime/src/main/java/io/quarkus/smallrye/health/runtime/SmallRyeHealthHandlerBase.java b/extensions/smallrye-health/runtime/src/main/java/io/quarkus/smallrye/health/runtime/SmallRyeHealthHandlerBase.java index 30dd03d3ca973..cc0bb85cce758 100644 --- a/extensions/smallrye-health/runtime/src/main/java/io/quarkus/smallrye/health/runtime/SmallRyeHealthHandlerBase.java +++ b/extensions/smallrye-health/runtime/src/main/java/io/quarkus/smallrye/health/runtime/SmallRyeHealthHandlerBase.java @@ -59,7 +59,9 @@ private void doHandle(RoutingContext ctx, ManagedContext requestContext) { if (health.isDown()) { resp.setStatusCode(503); } - resp.headers().set(HttpHeaders.CONTENT_TYPE, "application/json; charset=UTF-8"); + resp.headers() + .set(HttpHeaders.CONTENT_TYPE, "application/json; charset=UTF-8") + .set(HttpHeaders.CACHE_CONTROL, "no-store"); Buffer buffer = Buffer.buffer(256); // this size seems to cover the basic health checks try (BufferOutputStream outputStream = new BufferOutputStream(buffer);) { reporter.reportHealth(outputStream, health);