Ensure that JolokiaMvcEndpoint destroys underlying controller
Closes gh-7606
This commit is contained in:
parent
b80ad2a212
commit
4ec95b8308
|
@ -26,6 +26,7 @@ import javax.servlet.http.HttpServletResponse;
|
||||||
import org.jolokia.http.AgentServlet;
|
import org.jolokia.http.AgentServlet;
|
||||||
|
|
||||||
import org.springframework.beans.BeansException;
|
import org.springframework.beans.BeansException;
|
||||||
|
import org.springframework.beans.factory.DisposableBean;
|
||||||
import org.springframework.beans.factory.InitializingBean;
|
import org.springframework.beans.factory.InitializingBean;
|
||||||
import org.springframework.boot.context.properties.ConfigurationProperties;
|
import org.springframework.boot.context.properties.ConfigurationProperties;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
|
@ -44,8 +45,9 @@ import org.springframework.web.util.UrlPathHelper;
|
||||||
*/
|
*/
|
||||||
@ConfigurationProperties(prefix = "endpoints.jolokia", ignoreUnknownFields = false)
|
@ConfigurationProperties(prefix = "endpoints.jolokia", ignoreUnknownFields = false)
|
||||||
@HypermediaDisabled
|
@HypermediaDisabled
|
||||||
public class JolokiaMvcEndpoint extends AbstractMvcEndpoint
|
public class JolokiaMvcEndpoint extends AbstractMvcEndpoint implements InitializingBean,
|
||||||
implements InitializingBean, ApplicationContextAware, ServletContextAware {
|
ApplicationContextAware, ServletContextAware, DisposableBean {
|
||||||
|
|
||||||
private final ServletWrappingController controller = new ServletWrappingController();
|
private final ServletWrappingController controller = new ServletWrappingController();
|
||||||
|
|
||||||
public JolokiaMvcEndpoint() {
|
public JolokiaMvcEndpoint() {
|
||||||
|
@ -74,6 +76,11 @@ public class JolokiaMvcEndpoint extends AbstractMvcEndpoint
|
||||||
this.controller.setApplicationContext(context);
|
this.controller.setApplicationContext(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void destroy() {
|
||||||
|
this.controller.destroy();
|
||||||
|
}
|
||||||
|
|
||||||
@RequestMapping("/**")
|
@RequestMapping("/**")
|
||||||
public ModelAndView handle(HttpServletRequest request, HttpServletResponse response)
|
public ModelAndView handle(HttpServletRequest request, HttpServletResponse response)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
|
|
|
@ -0,0 +1,111 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2013-2016 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.
|
||||||
|
* 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.springframework.boot.actuate.endpoint.mvc;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.actuate.autoconfigure.EndpointWebMvcAutoConfiguration;
|
||||||
|
import org.springframework.boot.actuate.autoconfigure.JolokiaAutoConfiguration;
|
||||||
|
import org.springframework.boot.actuate.autoconfigure.ManagementServerPropertiesAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.jackson.JacksonAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.web.HttpMessageConvertersAutoConfiguration;
|
||||||
|
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.boot.test.util.EnvironmentTestUtils;
|
||||||
|
import org.springframework.context.ConfigurableApplicationContext;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.context.annotation.Import;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
import org.springframework.test.web.servlet.MockMvc;
|
||||||
|
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
||||||
|
import org.springframework.web.context.WebApplicationContext;
|
||||||
|
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||||
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||||
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Integration tests for {@link JolokiaMvcEndpoint}
|
||||||
|
*
|
||||||
|
* @author Christian Dupuis
|
||||||
|
* @author Dave Syer
|
||||||
|
*/
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@SpringBootTest
|
||||||
|
public class JolokiaMvcEndpointIntegrationTests {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private MvcEndpoints endpoints;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private WebApplicationContext context;
|
||||||
|
|
||||||
|
private MockMvc mvc;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
this.mvc = MockMvcBuilders.webAppContextSetup(this.context).build();
|
||||||
|
EnvironmentTestUtils.addEnvironment((ConfigurableApplicationContext) this.context,
|
||||||
|
"foo:bar");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void endpointRegistered() throws Exception {
|
||||||
|
Set<? extends MvcEndpoint> values = this.endpoints.getEndpoints();
|
||||||
|
assertThat(values).hasAtLeastOneElementOfType(JolokiaMvcEndpoint.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void search() throws Exception {
|
||||||
|
this.mvc.perform(get("/jolokia/search/java.lang:*")).andExpect(status().isOk())
|
||||||
|
.andExpect(content().string(containsString("GarbageCollector")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void read() throws Exception {
|
||||||
|
this.mvc.perform(get("/jolokia/read/java.lang:type=Memory"))
|
||||||
|
.andExpect(status().isOk())
|
||||||
|
.andExpect(content().string(containsString("NonHeapMemoryUsage")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void list() throws Exception {
|
||||||
|
this.mvc.perform(get("/jolokia/list/java.lang/type=Memory/attr"))
|
||||||
|
.andExpect(status().isOk())
|
||||||
|
.andExpect(content().string(containsString("NonHeapMemoryUsage")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@EnableConfigurationProperties
|
||||||
|
@EnableWebMvc
|
||||||
|
@Import({ JacksonAutoConfiguration.class,
|
||||||
|
HttpMessageConvertersAutoConfiguration.class,
|
||||||
|
EndpointWebMvcAutoConfiguration.class, JolokiaAutoConfiguration.class,
|
||||||
|
ManagementServerPropertiesAutoConfiguration.class })
|
||||||
|
public static class Config {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2013-2016 the original author or authors.
|
* Copyright 2012-2016 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -16,98 +16,45 @@
|
||||||
|
|
||||||
package org.springframework.boot.actuate.endpoint.mvc;
|
package org.springframework.boot.actuate.endpoint.mvc;
|
||||||
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.DisposableBean;
|
||||||
import org.springframework.boot.actuate.autoconfigure.EndpointWebMvcAutoConfiguration;
|
import org.springframework.mock.web.MockServletContext;
|
||||||
import org.springframework.boot.actuate.autoconfigure.JolokiaAutoConfiguration;
|
import org.springframework.test.util.ReflectionTestUtils;
|
||||||
import org.springframework.boot.actuate.autoconfigure.ManagementServerPropertiesAutoConfiguration;
|
|
||||||
import org.springframework.boot.autoconfigure.jackson.JacksonAutoConfiguration;
|
|
||||||
import org.springframework.boot.autoconfigure.web.HttpMessageConvertersAutoConfiguration;
|
|
||||||
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
|
||||||
import org.springframework.boot.test.util.EnvironmentTestUtils;
|
|
||||||
import org.springframework.context.ConfigurableApplicationContext;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
import org.springframework.context.annotation.Import;
|
|
||||||
import org.springframework.test.annotation.DirtiesContext;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
|
||||||
import org.springframework.test.web.servlet.MockMvc;
|
|
||||||
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
|
||||||
import org.springframework.web.context.WebApplicationContext;
|
import org.springframework.web.context.WebApplicationContext;
|
||||||
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
|
import org.springframework.web.servlet.mvc.ServletWrappingController;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for {@link JolokiaMvcEndpoint}
|
* Tests for {@link JolokiaMvcEndpoint}.
|
||||||
*
|
*
|
||||||
* @author Christian Dupuis
|
* @author Andy Wilkinson
|
||||||
* @author Dave Syer
|
|
||||||
*/
|
*/
|
||||||
@RunWith(SpringRunner.class)
|
|
||||||
@DirtiesContext
|
|
||||||
@SpringBootTest
|
|
||||||
public class JolokiaMvcEndpointTests {
|
public class JolokiaMvcEndpointTests {
|
||||||
|
|
||||||
@Autowired
|
private final JolokiaMvcEndpoint endpoint = new JolokiaMvcEndpoint();
|
||||||
private MvcEndpoints endpoints;
|
|
||||||
|
|
||||||
@Autowired
|
private final ServletWrappingController controller = (ServletWrappingController) spy(
|
||||||
private WebApplicationContext context;
|
ReflectionTestUtils.getField(this.endpoint, "controller"));
|
||||||
|
|
||||||
private MockMvc mvc;
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void before() {
|
||||||
this.mvc = MockMvcBuilders.webAppContextSetup(this.context).build();
|
ReflectionTestUtils.setField(this.endpoint, "controller", this.controller);
|
||||||
EnvironmentTestUtils.addEnvironment((ConfigurableApplicationContext) this.context,
|
|
||||||
"foo:bar");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void endpointRegistered() throws Exception {
|
public void controllerIsDestroyed() throws Exception {
|
||||||
Set<? extends MvcEndpoint> values = this.endpoints.getEndpoints();
|
this.endpoint.setApplicationContext(mock(WebApplicationContext.class));
|
||||||
assertThat(values).hasAtLeastOneElementOfType(JolokiaMvcEndpoint.class);
|
this.endpoint.setServletContext(new MockServletContext());
|
||||||
}
|
this.endpoint.afterPropertiesSet();
|
||||||
|
this.endpoint.destroy();
|
||||||
@Test
|
assertThat(this.endpoint).isInstanceOf(DisposableBean.class);
|
||||||
public void search() throws Exception {
|
verify(this.controller).destroy();
|
||||||
this.mvc.perform(get("/jolokia/search/java.lang:*")).andExpect(status().isOk())
|
|
||||||
.andExpect(content().string(containsString("GarbageCollector")));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void read() throws Exception {
|
|
||||||
this.mvc.perform(get("/jolokia/read/java.lang:type=Memory"))
|
|
||||||
.andExpect(status().isOk())
|
|
||||||
.andExpect(content().string(containsString("NonHeapMemoryUsage")));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void list() throws Exception {
|
|
||||||
this.mvc.perform(get("/jolokia/list/java.lang/type=Memory/attr"))
|
|
||||||
.andExpect(status().isOk())
|
|
||||||
.andExpect(content().string(containsString("NonHeapMemoryUsage")));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Configuration
|
|
||||||
@EnableConfigurationProperties
|
|
||||||
@EnableWebMvc
|
|
||||||
@Import({ JacksonAutoConfiguration.class,
|
|
||||||
HttpMessageConvertersAutoConfiguration.class,
|
|
||||||
EndpointWebMvcAutoConfiguration.class, JolokiaAutoConfiguration.class,
|
|
||||||
ManagementServerPropertiesAutoConfiguration.class })
|
|
||||||
public static class Config {
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue