commit
ff1e5076dc
|
@ -16,9 +16,6 @@
|
||||||
|
|
||||||
package org.springframework.boot.actuate.autoconfigure.web.server;
|
package org.springframework.boot.actuate.autoconfigure.web.server;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
|
||||||
import org.apache.commons.logging.LogFactory;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.SmartInitializingSingleton;
|
import org.springframework.beans.factory.SmartInitializingSingleton;
|
||||||
import org.springframework.boot.actuate.autoconfigure.endpoint.web.WebEndpointProperties;
|
import org.springframework.boot.actuate.autoconfigure.endpoint.web.WebEndpointProperties;
|
||||||
import org.springframework.boot.actuate.autoconfigure.web.ManagementContextFactory;
|
import org.springframework.boot.actuate.autoconfigure.web.ManagementContextFactory;
|
||||||
|
@ -29,7 +26,7 @@ import org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoCon
|
||||||
import org.springframework.boot.context.event.ApplicationFailedEvent;
|
import org.springframework.boot.context.event.ApplicationFailedEvent;
|
||||||
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
||||||
import org.springframework.boot.web.context.ConfigurableWebServerApplicationContext;
|
import org.springframework.boot.web.context.ConfigurableWebServerApplicationContext;
|
||||||
import org.springframework.boot.web.context.WebServerApplicationContext;
|
import org.springframework.boot.web.context.WebServerInitializedEvent;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
import org.springframework.context.ApplicationEvent;
|
import org.springframework.context.ApplicationEvent;
|
||||||
import org.springframework.context.ApplicationListener;
|
import org.springframework.context.ApplicationListener;
|
||||||
|
@ -59,9 +56,6 @@ import org.springframework.util.Assert;
|
||||||
ManagementServerProperties.class })
|
ManagementServerProperties.class })
|
||||||
public class ManagementContextAutoConfiguration {
|
public class ManagementContextAutoConfiguration {
|
||||||
|
|
||||||
private static final Log logger = LogFactory
|
|
||||||
.getLog(ManagementContextAutoConfiguration.class);
|
|
||||||
|
|
||||||
@Configuration(proxyBeanMethods = false)
|
@Configuration(proxyBeanMethods = false)
|
||||||
@ConditionalOnManagementPort(ManagementPortType.SAME)
|
@ConditionalOnManagementPort(ManagementPortType.SAME)
|
||||||
static class SameManagementContextConfiguration
|
static class SameManagementContextConfiguration
|
||||||
|
@ -122,7 +116,7 @@ public class ManagementContextAutoConfiguration {
|
||||||
@Configuration(proxyBeanMethods = false)
|
@Configuration(proxyBeanMethods = false)
|
||||||
@ConditionalOnManagementPort(ManagementPortType.DIFFERENT)
|
@ConditionalOnManagementPort(ManagementPortType.DIFFERENT)
|
||||||
static class DifferentManagementContextConfiguration
|
static class DifferentManagementContextConfiguration
|
||||||
implements SmartInitializingSingleton {
|
implements ApplicationListener<WebServerInitializedEvent> {
|
||||||
|
|
||||||
private final ApplicationContext applicationContext;
|
private final ApplicationContext applicationContext;
|
||||||
|
|
||||||
|
@ -135,10 +129,8 @@ public class ManagementContextAutoConfiguration {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void afterSingletonsInstantiated() {
|
public void onApplicationEvent(WebServerInitializedEvent event) {
|
||||||
if (this.applicationContext instanceof WebServerApplicationContext
|
if (event.getApplicationContext().equals(this.applicationContext)) {
|
||||||
&& ((WebServerApplicationContext) this.applicationContext)
|
|
||||||
.getWebServer() != null) {
|
|
||||||
ConfigurableWebServerApplicationContext managementContext = this.managementContextFactory
|
ConfigurableWebServerApplicationContext managementContext = this.managementContextFactory
|
||||||
.createManagementContext(this.applicationContext,
|
.createManagementContext(this.applicationContext,
|
||||||
EnableChildManagementContextConfiguration.class,
|
EnableChildManagementContextConfiguration.class,
|
||||||
|
@ -150,11 +142,6 @@ public class ManagementContextAutoConfiguration {
|
||||||
managementContext);
|
managementContext);
|
||||||
managementContext.refresh();
|
managementContext.refresh();
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
logger.warn("Could not start embedded management container on "
|
|
||||||
+ "different port (management endpoints are still available "
|
|
||||||
+ "through JMX)");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setClassLoaderIfPossible(ConfigurableApplicationContext child) {
|
private void setClassLoaderIfPossible(ConfigurableApplicationContext child) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2018 the original author or authors.
|
* Copyright 2012-2019 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.
|
||||||
|
@ -15,6 +15,9 @@
|
||||||
*/
|
*/
|
||||||
package org.springframework.boot.actuate.autoconfigure.web.server;
|
package org.springframework.boot.actuate.autoconfigure.web.server;
|
||||||
|
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -33,28 +36,13 @@ import static org.assertj.core.api.Assertions.assertThat;
|
||||||
* Tests for {@link ManagementContextAutoConfiguration}.
|
* Tests for {@link ManagementContextAutoConfiguration}.
|
||||||
*
|
*
|
||||||
* @author Madhura Bhave
|
* @author Madhura Bhave
|
||||||
|
* @author Andy Wilkinson
|
||||||
*/
|
*/
|
||||||
public class ManagementContextAutoConfigurationTests {
|
public class ManagementContextAutoConfigurationTests {
|
||||||
|
|
||||||
private WebApplicationContextRunner contextRunner = new WebApplicationContextRunner()
|
|
||||||
.withConfiguration(
|
|
||||||
AutoConfigurations.of(ManagementContextAutoConfiguration.class,
|
|
||||||
ServletManagementContextAutoConfiguration.class));
|
|
||||||
|
|
||||||
@Rule
|
@Rule
|
||||||
public OutputCapture output = new OutputCapture();
|
public OutputCapture output = new OutputCapture();
|
||||||
|
|
||||||
@Test
|
|
||||||
public void managementServerPortShouldBeIgnoredForNonEmbeddedServer() {
|
|
||||||
this.contextRunner.withPropertyValues("management.server.port=8081")
|
|
||||||
.run((context) -> {
|
|
||||||
assertThat(context.getStartupFailure()).isNull();
|
|
||||||
assertThat(this.output.toString())
|
|
||||||
.contains("Could not start embedded management container on "
|
|
||||||
+ "different port (management endpoints are still available through JMX)");
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void childManagementContextShouldStartForEmbeddedServer() {
|
public void childManagementContextShouldStartForEmbeddedServer() {
|
||||||
WebApplicationContextRunner contextRunner = new WebApplicationContextRunner(
|
WebApplicationContextRunner contextRunner = new WebApplicationContextRunner(
|
||||||
|
@ -65,10 +53,19 @@ public class ManagementContextAutoConfigurationTests {
|
||||||
ServletManagementContextAutoConfiguration.class,
|
ServletManagementContextAutoConfiguration.class,
|
||||||
WebEndpointAutoConfiguration.class,
|
WebEndpointAutoConfiguration.class,
|
||||||
EndpointAutoConfiguration.class));
|
EndpointAutoConfiguration.class));
|
||||||
contextRunner.withPropertyValues("management.server.port=8081")
|
contextRunner.withPropertyValues("server.port=0", "management.server.port=0").run(
|
||||||
.run((context) -> assertThat(this.output.toString()).doesNotContain(
|
(context) -> assertThat(tomcatStartedOccurencesIn(this.output.toString()))
|
||||||
"Could not start embedded management container on "
|
.isEqualTo(2));
|
||||||
+ "different port (management endpoints are still available through JMX)"));
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private int tomcatStartedOccurencesIn(String output) {
|
||||||
|
int matches = 0;
|
||||||
|
Matcher matcher = Pattern.compile("Tomcat started on port").matcher(output);
|
||||||
|
while (matcher.find()) {
|
||||||
|
matches++;
|
||||||
|
}
|
||||||
|
return matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue