Browse Source
The import selector does not take into account @Conditional* annotations on the imported configurations. fixes gh-g againpull/15/head
Spencer Gibb
10 years ago
5 changed files with 79 additions and 50 deletions
@ -1,46 +0,0 @@
@@ -1,46 +0,0 @@
|
||||
/* |
||||
* Copyright 2013-2015 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.cloud.client.discovery; |
||||
|
||||
import lombok.extern.apachecommons.CommonsLog; |
||||
|
||||
import org.springframework.context.annotation.DeferredImportSelector; |
||||
import org.springframework.core.annotation.AnnotationAttributes; |
||||
import org.springframework.core.type.AnnotationMetadata; |
||||
|
||||
/** |
||||
* Import Selector that only returns a NoopDiscoveryClientConfiguration if the |
||||
* @EnableDiscoveryClient annotation has NOT been used. |
||||
* @author Spencer Gibb |
||||
*/ |
||||
@CommonsLog |
||||
public class NoopDiscoveryClientImportSelector implements |
||||
DeferredImportSelector { |
||||
|
||||
@Override |
||||
public String[] selectImports(AnnotationMetadata metadata) { |
||||
AnnotationAttributes attributes = AnnotationAttributes.fromMap(metadata |
||||
.getAnnotationAttributes(EnableDiscoveryClient.class.getName(), true)); |
||||
|
||||
if (attributes == null) { |
||||
// @EnableDiscoveryClient has not been used, so configure the noop client
|
||||
return new String[] { NoopDiscoveryClientConfiguration.class.getName() }; |
||||
} |
||||
|
||||
return new String[]{}; |
||||
} |
||||
} |
@ -1,4 +1,4 @@
@@ -1,4 +1,4 @@
|
||||
# Bootstrap Configuration |
||||
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ |
||||
org.springframework.cloud.client.CommonsClientAutoConfiguration,\ |
||||
org.springframework.cloud.client.discovery.NoopDiscoveryClientImportSelector |
||||
org.springframework.cloud.client.discovery.NoopDiscoveryClientAutoConfiguration |
||||
|
@ -0,0 +1,73 @@
@@ -0,0 +1,73 @@
|
||||
package org.springframework.cloud.client.discovery; |
||||
|
||||
import static org.junit.Assert.assertFalse; |
||||
import static org.junit.Assert.assertTrue; |
||||
|
||||
import org.junit.Test; |
||||
import org.junit.runner.RunWith; |
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
import org.springframework.boot.SpringApplication; |
||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration; |
||||
import org.springframework.boot.test.SpringApplicationConfiguration; |
||||
import org.springframework.cloud.client.ServiceInstance; |
||||
import org.springframework.context.annotation.Bean; |
||||
import org.springframework.context.annotation.Configuration; |
||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; |
||||
|
||||
import java.util.List; |
||||
|
||||
/** |
||||
* Tests if @EnableDiscoveryClient is NOT used, then NoopDiscoveryClient is created. |
||||
* @author Spencer Gibb |
||||
*/ |
||||
@RunWith(SpringJUnit4ClassRunner.class) |
||||
@SpringApplicationConfiguration(classes = NoopDiscoveryClientConfigurationAdditionalTests.App.class) |
||||
public class NoopDiscoveryClientConfigurationAdditionalTests { |
||||
|
||||
@Autowired |
||||
DiscoveryClient discoveryClient; |
||||
|
||||
@Test |
||||
public void testDiscoveryClientIsNotNoop() { |
||||
assertFalse("discoveryClient is wrong instance type", discoveryClient instanceof NoopDiscoveryClient); |
||||
} |
||||
|
||||
@EnableAutoConfiguration |
||||
@Configuration |
||||
public static class App { |
||||
|
||||
@Bean |
||||
public DiscoveryClient discoveryClient() { |
||||
return new DiscoveryClient() { |
||||
@Override |
||||
public String description() { |
||||
return null; |
||||
} |
||||
|
||||
@Override |
||||
public ServiceInstance getLocalServiceInstance() { |
||||
return null; |
||||
} |
||||
|
||||
@Override |
||||
public List<ServiceInstance> getInstances(String serviceId) { |
||||
return null; |
||||
} |
||||
|
||||
@Override |
||||
public List<ServiceInstance> getAllInstances() { |
||||
return null; |
||||
} |
||||
|
||||
@Override |
||||
public List<String> getServices() { |
||||
return null; |
||||
} |
||||
}; |
||||
} |
||||
|
||||
public static void main(String[] args) { |
||||
SpringApplication.run(App.class, args); |
||||
} |
||||
} |
||||
} |
Loading…
Reference in new issue