diff --git a/bom/application/pom.xml b/bom/application/pom.xml
index b6a8988dc065e..fca96a69a41cd 100644
--- a/bom/application/pom.xml
+++ b/bom/application/pom.xml
@@ -41,7 +41,7 @@
1.0
1.13.2
2.13.0
- 3.3.0
+ 3.3.1
3.0.5
2.3.1
1.9.0
diff --git a/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthConfig.java b/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthConfig.java
index 08a1066afeea5..f1c88cdea58c7 100644
--- a/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthConfig.java
+++ b/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthConfig.java
@@ -1,5 +1,6 @@
package io.quarkus.smallrye.health.deployment;
+import java.util.Optional;
import java.util.OptionalInt;
import io.quarkus.runtime.annotations.ConfigDocSection;
@@ -63,6 +64,12 @@ public class SmallRyeHealthConfig {
@ConfigItem
OptionalInt maxGroupRegistriesCount;
+ /**
+ * The name of the default health group used when no other health group is defined on the health check.
+ */
+ @ConfigItem
+ Optional defaultHealthGroup;
+
/**
* SmallRye Health UI configuration
*/
diff --git a/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthProcessor.java b/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthProcessor.java
index 13b3b9bb9272b..76c5effc51549 100644
--- a/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthProcessor.java
+++ b/extensions/smallrye-health/deployment/src/main/java/io/quarkus/smallrye/health/deployment/SmallRyeHealthProcessor.java
@@ -278,6 +278,10 @@ public void processSmallRyeHealthConfigValues(SmallRyeHealthConfig healthConfig,
String.valueOf(healthConfig.maxGroupRegistriesCount.getAsInt())));
}
config.produce(new RunTimeConfigurationDefaultBuildItem("io.smallrye.health.delayChecksInitializations", "true"));
+ if (healthConfig.defaultHealthGroup.isPresent()) {
+ config.produce(new RunTimeConfigurationDefaultBuildItem("io.smallrye.health.defaultHealthGroup",
+ healthConfig.defaultHealthGroup.get()));
+ }
}
@BuildStep(onlyIf = OpenAPIIncluded.class)
diff --git a/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/DefaultHealthGroupTest.java b/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/DefaultHealthGroupTest.java
new file mode 100644
index 0000000000000..a750c84e234b4
--- /dev/null
+++ b/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/DefaultHealthGroupTest.java
@@ -0,0 +1,51 @@
+package io.quarkus.smallrye.health.test;
+
+import static org.hamcrest.Matchers.contains;
+import static org.hamcrest.Matchers.hasItems;
+import static org.hamcrest.Matchers.is;
+
+import org.jboss.shrinkwrap.api.asset.EmptyAsset;
+import org.junit.jupiter.api.Test;
+import org.junit.jupiter.api.extension.RegisterExtension;
+
+import io.quarkus.smallrye.health.test.ui.HealthGroupCheck;
+import io.quarkus.test.QuarkusUnitTest;
+import io.restassured.RestAssured;
+import io.restassured.parsing.Parser;
+
+public class DefaultHealthGroupTest {
+
+ @RegisterExtension
+ static final QuarkusUnitTest config = new QuarkusUnitTest()
+ .withApplicationRoot((jar) -> jar
+ .addClasses(BasicHealthCheck.class, HealthGroupCheck.class)
+ .addAsManifestResource(EmptyAsset.INSTANCE, "beans.xml"))
+ .overrideConfigKey("quarkus.smallrye-health.default-health-group", "my-default-health-group");
+
+ @Test
+ public void testDefaultHealthGroup() {
+ try {
+ RestAssured.defaultParser = Parser.JSON;
+ RestAssured.when().get("/q/health/group/my-default-health-group").then()
+ .body("status", is("UP"),
+ "checks.size()", is(1),
+ "checks.status", contains("UP"),
+ "checks.name", contains("basic"));
+
+ RestAssured.when().get("/q/health/group/test-group").then()
+ .body("status", is("UP"),
+ "checks.size()", is(1),
+ "checks.status", contains("UP"),
+ "checks.name", contains(HealthGroupCheck.class.getName()));
+
+ RestAssured.when().get("/q/health/group").then()
+ .body("status", is("UP"),
+ "checks.size()", is(2),
+ "checks.status", hasItems("UP", "UP"),
+ "checks.name", hasItems("basic", HealthGroupCheck.class.getName()));
+ } finally {
+ RestAssured.reset();
+ }
+ }
+
+}
diff --git a/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/ui/HealthGroupCheck.java b/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/ui/HealthGroupCheck.java
new file mode 100644
index 0000000000000..3308675645192
--- /dev/null
+++ b/extensions/smallrye-health/deployment/src/test/java/io/quarkus/smallrye/health/test/ui/HealthGroupCheck.java
@@ -0,0 +1,14 @@
+package io.quarkus.smallrye.health.test.ui;
+
+import org.eclipse.microprofile.health.HealthCheck;
+import org.eclipse.microprofile.health.HealthCheckResponse;
+
+import io.smallrye.health.api.HealthGroup;
+
+@HealthGroup("test-group")
+public class HealthGroupCheck implements HealthCheck {
+ @Override
+ public HealthCheckResponse call() {
+ return HealthCheckResponse.up(HealthGroupCheck.class.getName());
+ }
+}
diff --git a/jakarta/rewrite.yml b/jakarta/rewrite.yml
index c5a79f69067c3..7b4f564497be7 100644
--- a/jakarta/rewrite.yml
+++ b/jakarta/rewrite.yml
@@ -576,7 +576,7 @@ recipeList:
newValue: '2.0.0'
- org.openrewrite.maven.ChangePropertyValue:
key: smallrye-health.version
- newValue: '4.0.0'
+ newValue: '4.0.1'
- org.openrewrite.maven.ChangePropertyValue:
key: microprofile-jwt.version
newValue: '2.0'