This is an automated email from the ASF dual-hosted git repository.

remm pushed a commit to branch 11.0.x
in repository https://gitbox.apache.org/repos/asf/tomcat.git


The following commit(s) were added to refs/heads/11.0.x by this push:
     new 54160f7de8 Add test case for health check valve
54160f7de8 is described below

commit 54160f7de8c04c87d556858dd37cafe94bcf9bf6
Author: remm <r...@apache.org>
AuthorDate: Wed Sep 18 16:44:50 2024 +0200

    Add test case for health check valve
---
 .../catalina/valves/TestHealthCheckValve.java      | 116 +++++++++++++++++++++
 1 file changed, 116 insertions(+)

diff --git a/test/org/apache/catalina/valves/TestHealthCheckValve.java 
b/test/org/apache/catalina/valves/TestHealthCheckValve.java
new file mode 100644
index 0000000000..5424805bb5
--- /dev/null
+++ b/test/org/apache/catalina/valves/TestHealthCheckValve.java
@@ -0,0 +1,116 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.catalina.valves;
+
+import jakarta.servlet.ServletRequest;
+import jakarta.servlet.ServletResponse;
+import jakarta.servlet.http.HttpServlet;
+import jakarta.servlet.http.HttpServletResponse;
+
+import org.junit.Assert;
+import org.junit.Test;
+
+import org.apache.catalina.Container;
+import org.apache.catalina.Context;
+import org.apache.catalina.startup.Tomcat;
+import org.apache.catalina.startup.TomcatBaseTest;
+import org.apache.tomcat.util.buf.ByteChunk;
+
+public class TestHealthCheckValve extends TomcatBaseTest {
+
+    @Test
+    public void testServerHealthCheck() throws Exception {
+        Tomcat tomcat = getTomcatInstance();
+        // No file system docBase required
+        Context ctx = getProgrammaticRootContext();
+
+        HealthCheckValve healthCheckValve = new HealthCheckValve();
+        ctx.getParent().getPipeline().addValve(healthCheckValve);
+
+        tomcat.start();
+
+        ByteChunk result = new ByteChunk();
+        int rc = getUrl("http://localhost:"; + getPort() + "/foo", result, 
null);
+        Assert.assertEquals(HttpServletResponse.SC_NOT_FOUND, rc);
+
+        result.recycle();
+
+        rc = getUrl("http://localhost:"; + getPort() + 
healthCheckValve.getPath(), result, null);
+        Assert.assertEquals(HttpServletResponse.SC_OK, rc);
+        Assert.assertTrue(result.toString().contains("UP"));
+
+        result.recycle();
+        ctx.stop();
+
+        rc = getUrl("http://localhost:"; + getPort() + 
healthCheckValve.getPath(), result, null);
+        Assert.assertEquals(HttpServletResponse.SC_SERVICE_UNAVAILABLE, rc);
+        Assert.assertTrue(result.toString().contains("DOWN"));
+
+        healthCheckValve.setCheckContainersAvailable(false);
+        result.recycle();
+
+        rc = getUrl("http://localhost:"; + getPort() + 
healthCheckValve.getPath(), result, null);
+        Assert.assertEquals(HttpServletResponse.SC_OK, rc);
+        Assert.assertTrue(result.toString().contains("UP"));
+    }
+
+    @Test
+    public void testContextHealthCheck() throws Exception {
+        Tomcat tomcat = getTomcatInstance();
+        // No file system docBase required
+        Context ctx = getProgrammaticRootContext();
+
+        HealthCheckValve healthCheckValve = new HealthCheckValve();
+        ctx.getPipeline().addValve(healthCheckValve);
+
+        tomcat.start();
+
+        ByteChunk result = new ByteChunk();
+        int rc = getUrl("http://localhost:"; + getPort() + 
healthCheckValve.getPath(), result, null);
+
+        Assert.assertEquals(HttpServletResponse.SC_OK, rc);
+        Assert.assertTrue(result.toString().contains("UP"));
+
+        result.recycle();
+        ctx.stop();
+        healthCheckValve.setPath("/customhealthpath");
+
+        rc = getUrl("http://localhost:"; + getPort() + 
healthCheckValve.getPath(), result, null);
+        Assert.assertEquals(HttpServletResponse.SC_NOT_FOUND, rc);
+
+        result.recycle();
+        Tomcat.addServlet(ctx, "dummy", new DummyServlet());
+        Container wrapper = ctx.findChild("dummy");
+        ctx.start();
+        wrapper.stop();
+
+        rc = getUrl("http://localhost:"; + getPort() + 
healthCheckValve.getPath(), result, null);
+        Assert.assertEquals(HttpServletResponse.SC_SERVICE_UNAVAILABLE, rc);
+        Assert.assertTrue(result.toString().contains("DOWN"));
+    }
+
+    private static final class DummyServlet extends HttpServlet {
+
+        private static final long serialVersionUID = 1L;
+
+        @Override
+        public void service(ServletRequest request, ServletResponse response) {
+        }
+    }
+
+
+}


---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@tomcat.apache.org
For additional commands, e-mail: dev-h...@tomcat.apache.org

Reply via email to