Skip to content

Commit

Permalink
MP Health test development
Browse files Browse the repository at this point in the history
	refactoring
	negative scenario for MIME types
	multiple deployment / deployment with subdeployments scenario
	new health version test
	JavaDoc
  • Loading branch information
istraka committed Dec 13, 2019
1 parent 8b72604 commit 40c3ca4
Show file tree
Hide file tree
Showing 11 changed files with 553 additions and 52 deletions.
5 changes: 5 additions & 0 deletions microprofile-health/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -39,5 +39,10 @@
<artifactId>wildfly-arquillian-container-managed</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<artifactId>tooling-server-configuration</artifactId>
<groupId>org.jboss.eap.qe</groupId>
<version>${project.version}</version>
</dependency>
</dependencies>
</project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package org.jboss.eap.qe.microprofile.health;

import org.eclipse.microprofile.health.HealthCheck;
import org.eclipse.microprofile.health.HealthCheckResponse;
import org.eclipse.microprofile.health.Liveness;
import org.eclipse.microprofile.health.Readiness;

@Liveness
@Readiness
public class SimplifiedHealthCheck implements HealthCheck {
@Override
public HealthCheckResponse call() {
return HealthCheckResponse.up("simplified");
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.as.arquillian.api.ContainerResource;
import org.jboss.as.arquillian.container.ManagementClient;
import org.jboss.eap.qe.microprofile.tooling.server.configuration.ConfigurationException;
import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.EmptyAsset;
Expand All @@ -22,39 +23,41 @@

@RunAsClient
@RunWith(Arquillian.class)
public class MicroProfileHealthDeprecatedTest {
public class HealthDeprecatedTest {

@ContainerResource
ManagementClient managementClient;

@Deployment(testable = false)
public static Archive<?> deployment() {
WebArchive war = ShrinkWrap.create(WebArchive.class, "MicroProfileHealthDeprecatedTest.war")
return ShrinkWrap.create(WebArchive.class, HealthDeprecatedTest.class.getSimpleName() + ".war")
.addClasses(DeprecatedHealthCheck.class)
.addAsWebInfResource(EmptyAsset.INSTANCE, "beans.xml");
return war;
}

/**
* @tpTestDetails backward compatibility scenario - test for deprecated however still supported annotation {@code @Health}.
* @tpPassCrit Overall and the health check status is up.
* @tpSince EAP 7.4.0.CD19
*/
@Test
public void testDeprecatedHealthCheck() {
final String healthURL = "http://" + managementClient.getMgmtAddress() + ":" + managementClient.getMgmtPort()
+ "/health";
public void testDeprecatedHealthAnnotation() throws ConfigurationException {

get(healthURL).then()
get(HealthUrlProvider.healthEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("UP"),
"checks.status", containsInAnyOrder("UP"),
"checks.name", containsInAnyOrder("deprecated-health"));

get(healthURL + "/live").then()
get(HealthUrlProvider.liveEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("UP"),
"checks.status", is(empty()),
"checks.name", is(empty()));

get(healthURL + "/ready").then()
get(HealthUrlProvider.readyEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("UP"),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,7 @@
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.container.test.api.RunAsClient;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.as.arquillian.api.ContainerResource;
import org.jboss.as.arquillian.container.ManagementClient;
import org.jboss.eap.qe.microprofile.tooling.server.configuration.ConfigurationException;
import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.EmptyAsset;
Expand All @@ -21,32 +20,30 @@

@RunAsClient
@RunWith(Arquillian.class)
public class MicroProfileHealthNullTest {

@ContainerResource
ManagementClient managementClient;
public class HealthNullTest {

@Deployment(testable = false)
public static Archive<?> deployment() {
WebArchive war = ShrinkWrap.create(WebArchive.class, "MicroProfileHealthNullTest.war")
return ShrinkWrap.create(WebArchive.class, HealthNullTest.class.getSimpleName() + ".war")
.addClasses(NullLivenessHealthCheck.class)
.addAsWebInfResource(EmptyAsset.INSTANCE, "beans.xml");
return war;
}

/**
* @tpTestDetails Negative scenario - health check returns null.
* @tpPassCrit Overall and the health check status is down.
* @tpSince EAP 7.4.0.CD19
*/
@Test
public void testDeprecatedHealthCheck() {
final String healthURL = "http://" + managementClient.getMgmtAddress() + ":" + managementClient.getMgmtPort()
+ "/health";

get(healthURL).then()
public void testNullHealthCheck() throws ConfigurationException {
get(HealthUrlProvider.healthEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("DOWN"),
"checks.status", contains("DOWN"),
"checks.name", contains(NullLivenessHealthCheck.class.getCanonicalName()));

get(healthURL + "/live").then()
get(HealthUrlProvider.liveEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("DOWN"));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,59 +11,55 @@
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.container.test.api.RunAsClient;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.as.arquillian.api.ContainerResource;
import org.jboss.as.arquillian.container.ManagementClient;
import org.jboss.eap.qe.microprofile.tooling.server.configuration.ConfigurationException;
import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.EmptyAsset;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;

import io.restassured.http.ContentType;

@RunAsClient
@RunWith(Arquillian.class)
public class MicroProfileHealth21Test {

@ContainerResource
ManagementClient managementClient;

String healthURL;

@Before
public void composeHealthEndpointURL() {
healthURL = "http://" + managementClient.getMgmtAddress() + ":" + managementClient.getMgmtPort() + "/health";
}
public class HealthTest {

@Deployment(testable = false)
public static Archive<?> deployment() {
WebArchive war = ShrinkWrap.create(WebArchive.class, "MicroProfileHealth21Test.war")
.addClasses(DeprecatedHealthCheck.class, BothHealthCheck.class, LivenessHealthCheck.class,
ReadinessHealthCheck.class)
return ShrinkWrap.create(WebArchive.class, HealthTest.class.getSimpleName() + ".war")
.addClasses(BothHealthCheck.class, LivenessHealthCheck.class, ReadinessHealthCheck.class)
.addAsWebInfResource(EmptyAsset.INSTANCE, "beans.xml");
return war;
}

/**
* @tpTestDetails Customer scenario where health check contains customer data.
* @tpPassCrit Overall and the health check status is up and checks contains expected data.
* @tpSince EAP 7.4.0.CD19
*/
@Test
public void testHealthEndpoint() {
get(healthURL).then()
public void testHealthEndpoint() throws ConfigurationException {
get(HealthUrlProvider.healthEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("UP"),
"checks", hasSize(5), // BothHealthCheck contains both annotations: @Liveness and @Readiness
"checks", hasSize(4), // BothHealthCheck contains both annotations: @Liveness and @Readiness
"checks.status", hasItems("UP"),
"checks.status", not(hasItems("DOWN")),
"checks.name", containsInAnyOrder("deprecated-health", "both", "live", "ready", "both"),
"checks.data", hasSize(5),
"checks.name", containsInAnyOrder("both", "live", "ready", "both"),
"checks.data", hasSize(4),
"checks.data[0].key", is("value"),
"checks.data[0..4].key", hasItems("value"));
"checks.data[0..3].key", hasItems("value"));
}

/**
* @tpTestDetails Customer scenario where liveness check contains customer data.
* @tpPassCrit Overall and the liveness check status is up and checks contains expected data.
* @tpSince EAP 7.4.0.CD19
*/
@Test
public void testLivenessEndpoint() {
get(healthURL + "/live").then()
public void testLivenessEndpoint() throws ConfigurationException {
get(HealthUrlProvider.liveEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("UP"),
Expand All @@ -74,9 +70,14 @@ public void testLivenessEndpoint() {
"checks.data[0..1].key", hasItems("value"));
}

/**
* @tpTestDetails Customer scenario where readiness check contains customer data.
* @tpPassCrit Overall and the readiness check status is up and checks contains expected data.
* @tpSince EAP 7.4.0.CD19
*/
@Test
public void testReadinessEndpoint() {
get(healthURL + "/ready").then()
public void testReadinessEndpoint() throws ConfigurationException {
get(HealthUrlProvider.readyEndpoint()).then()
.contentType(ContentType.JSON)
.header("Content-Type", containsString("application/json"))
.body("status", is("UP"),
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package org.jboss.eap.qe.microprofile.health;

import org.jboss.eap.qe.microprofile.tooling.server.configuration.ConfigurationException;
import org.jboss.eap.qe.microprofile.tooling.server.configuration.arquillian.ArquillianContainerProperties;
import org.jboss.eap.qe.microprofile.tooling.server.configuration.arquillian.ArquillianDescriptorWrapper;

public class HealthUrlProvider {
public static String healthEndpoint() throws ConfigurationException {
ArquillianContainerProperties arqProps = new ArquillianContainerProperties(
ArquillianDescriptorWrapper.getArquillianDescriptor());
return "http://" + arqProps.getDefaultManagementAddress() + ":" + arqProps.getDefaultManagementPort() + "/health";
}

public static String liveEndpoint() throws ConfigurationException {
ArquillianContainerProperties arqProps = new ArquillianContainerProperties(
ArquillianDescriptorWrapper.getArquillianDescriptor());
return "http://" + arqProps.getDefaultManagementAddress() + ":" + arqProps.getDefaultManagementPort()
+ "/health/live";
}

public static String readyEndpoint() throws ConfigurationException {
ArquillianContainerProperties arqProps = new ArquillianContainerProperties(
ArquillianDescriptorWrapper.getArquillianDescriptor());
return "http://" + arqProps.getDefaultManagementAddress() + ":" + arqProps.getDefaultManagementPort()
+ "/health/ready";
}
}
Loading

0 comments on commit 40c3ca4

Please sign in to comment.