Commit 46e319ee by Johannes Edmeier

Merge branch '1.3.x'

parents 778ca87c e1eeb038
...@@ -7,7 +7,6 @@ ...@@ -7,7 +7,6 @@
<version>1.4.0-SNAPSHOT</version> <version>1.4.0-SNAPSHOT</version>
<relativePath>..</relativePath> <relativePath>..</relativePath>
</parent> </parent>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-docs</artifactId> <artifactId>spring-boot-admin-docs</artifactId>
<packaging>pom</packaging> <packaging>pom</packaging>
<name>Spring Boot Admin Docs</name> <name>Spring Boot Admin Docs</name>
......
...@@ -8,7 +8,6 @@ ...@@ -8,7 +8,6 @@
<version>1.4.0-SNAPSHOT</version> <version>1.4.0-SNAPSHOT</version>
<relativePath>..</relativePath> <relativePath>..</relativePath>
</parent> </parent>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-samples</artifactId> <artifactId>spring-boot-admin-samples</artifactId>
<packaging>pom</packaging> <packaging>pom</packaging>
<name>Spring Boot Admin Samples</name> <name>Spring Boot Admin Samples</name>
......
<?xml version="1.0"?> <?xml version="1.0"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-sample-war</artifactId> <artifactId>spring-boot-admin-sample-war</artifactId>
<version>1.4.0-SNAPSHOT</version>
<packaging>war</packaging> <packaging>war</packaging>
<parent> <parent>
<groupId>de.codecentric</groupId> <groupId>de.codecentric</groupId>
......
...@@ -17,18 +17,18 @@ package de.codecentric.boot.admin.config; ...@@ -17,18 +17,18 @@ package de.codecentric.boot.admin.config;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.AutoConfigureAfter; import org.springframework.boot.autoconfigure.AutoConfigureAfter;
import org.springframework.boot.autoconfigure.AutoConfigureBefore; import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.autoconfigure.condition.ConditionalOnSingleCandidate; import org.springframework.boot.autoconfigure.condition.ConditionalOnSingleCandidate;
import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.cloud.client.discovery.DiscoveryClient; import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.cloud.client.discovery.noop.NoopDiscoveryClientAutoConfiguration; import org.springframework.cloud.client.discovery.noop.NoopDiscoveryClientAutoConfiguration;
import org.springframework.cloud.netflix.eureka.EurekaDiscoveryClient.EurekaServiceInstance;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import com.netflix.discovery.EurekaClient;
import de.codecentric.boot.admin.discovery.ApplicationDiscoveryListener; import de.codecentric.boot.admin.discovery.ApplicationDiscoveryListener;
import de.codecentric.boot.admin.discovery.DefaultServiceInstanceConverter; import de.codecentric.boot.admin.discovery.DefaultServiceInstanceConverter;
import de.codecentric.boot.admin.discovery.EurekaServiceInstanceConverter; import de.codecentric.boot.admin.discovery.EurekaServiceInstanceConverter;
...@@ -58,23 +58,19 @@ public class DiscoveryClientConfiguration { ...@@ -58,23 +58,19 @@ public class DiscoveryClientConfiguration {
} }
@Configuration @Configuration
@ConditionalOnClass({ EurekaServiceInstance.class }) @ConditionalOnBean(EurekaClient.class)
@AutoConfigureBefore(DefaultConverterConfiguration.class)
public static class EurekaConverterConfiguration { public static class EurekaConverterConfiguration {
@Bean @Bean
@ConditionalOnMissingBean @ConditionalOnMissingBean({ ServiceInstanceConverter.class })
public EurekaServiceInstanceConverter serviceInstanceConverter() { public EurekaServiceInstanceConverter serviceInstanceConverter() {
return new EurekaServiceInstanceConverter(); return new EurekaServiceInstanceConverter();
} }
} }
@Configuration @Bean
@ConditionalOnMissingBean({ ServiceInstanceConverter.class })
@ConfigurationProperties(prefix = "spring.boot.admin.discovery.converter") @ConfigurationProperties(prefix = "spring.boot.admin.discovery.converter")
public static class DefaultConverterConfiguration { public DefaultServiceInstanceConverter serviceInstanceConverter() {
@Bean return new DefaultServiceInstanceConverter();
@ConditionalOnMissingBean
public DefaultServiceInstanceConverter serviceInstanceConverter() {
return new DefaultServiceInstanceConverter();
}
} }
} }
package de.codecentric.boot.admin.config;
import static org.hamcrest.CoreMatchers.instanceOf;
import static org.hamcrest.CoreMatchers.is;
import static org.junit.Assert.assertThat;
import org.junit.After;
import org.junit.Test;
import org.springframework.boot.autoconfigure.PropertyPlaceholderAutoConfiguration;
import org.springframework.boot.autoconfigure.web.ServerPropertiesAutoConfiguration;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.noop.NoopDiscoveryClientAutoConfiguration;
import org.springframework.cloud.commons.util.UtilAutoConfiguration;
import org.springframework.cloud.netflix.eureka.EurekaClientAutoConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
import de.codecentric.boot.admin.discovery.DefaultServiceInstanceConverter;
import de.codecentric.boot.admin.discovery.EurekaServiceInstanceConverter;
import de.codecentric.boot.admin.discovery.ServiceInstanceConverter;
import de.codecentric.boot.admin.model.Application;
public class DiscoveryClientConfigurationTest {
private AnnotationConfigWebApplicationContext context;
@After
public void close() {
if (this.context != null) {
this.context.close();
}
}
@Test
public void defaultServiceInstanceConverter() {
load(NoopDiscoveryClientAutoConfiguration.class);
assertThat(context.getBean(ServiceInstanceConverter.class),
is(instanceOf(DefaultServiceInstanceConverter.class)));
}
@Test
public void eurekaServiceInstanceConverter() {
load(UtilAutoConfiguration.class, EurekaClientAutoConfiguration.class);
assertThat(context.getBean(ServiceInstanceConverter.class),
is(instanceOf(EurekaServiceInstanceConverter.class)));
}
@Test
public void customServiceInstanceConverter() {
load(NoopDiscoveryClientAutoConfiguration.class,
TestCustomServiceInstanceConverterConfig.class);
assertThat(context.getBean(ServiceInstanceConverter.class),
is(instanceOf(CustomServiceInstanceConverter.class)));
}
@Configuration
static class TestCustomServiceInstanceConverterConfig {
@Bean
public CustomServiceInstanceConverter converter() {
return new CustomServiceInstanceConverter();
}
}
static class CustomServiceInstanceConverter implements ServiceInstanceConverter {
@Override
public Application convert(ServiceInstance instance) {
return null;
}
}
private void load(Class<?>... configs) {
AnnotationConfigWebApplicationContext applicationContext = new AnnotationConfigWebApplicationContext();
for (Class<?> config : configs) {
applicationContext.register(config);
}
applicationContext.register(PropertyPlaceholderAutoConfiguration.class);
applicationContext.register(ServerPropertiesAutoConfiguration.class);
applicationContext.register(AdminServerWebConfiguration.class);
applicationContext.register(DiscoveryClientConfiguration.class);
applicationContext.refresh();
this.context = applicationContext;
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment