Browse Source

Re-order events in RefreshEndpoint

EnvironmentChangeEvent should come before the RefreshScopeRefreshedEvent
so that all the @ConfigurationProperties are fully bound when the refresh
happens.
pull/52/merge
Dave Syer 10 years ago
parent
commit
8c346506f4
  1. 2
      spring-cloud-context/src/main/java/org/springframework/cloud/endpoint/RefreshEndpoint.java
  2. 34
      spring-cloud-context/src/test/java/org/springframework/cloud/endpoint/RefreshEndpointTests.java

2
spring-cloud-context/src/main/java/org/springframework/cloud/endpoint/RefreshEndpoint.java

@ -73,8 +73,8 @@ public class RefreshEndpoint extends AbstractEndpoint<Collection<String>> { @@ -73,8 +73,8 @@ public class RefreshEndpoint extends AbstractEndpoint<Collection<String>> {
addConfigFilesToEnvironment();
Set<String> keys = changes(before,
extract(this.context.getEnvironment().getPropertySources())).keySet();
this.scope.refreshAll();
this.context.publishEvent(new EnvironmentChangeEvent(keys));
this.scope.refreshAll();
return keys.toArray(new String[keys.size()]);
}

34
spring-cloud-context/src/test/java/org/springframework/cloud/bootstrap/config/RefreshEndpointTests.java → spring-cloud-context/src/test/java/org/springframework/cloud/endpoint/RefreshEndpointTests.java

@ -14,19 +14,25 @@ @@ -14,19 +14,25 @@
* limitations under the License.
*/
package org.springframework.cloud.bootstrap.config;
package org.springframework.cloud.endpoint;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.junit.Test;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.context.environment.EnvironmentChangeEvent;
import org.springframework.cloud.context.scope.refresh.RefreshScope;
import org.springframework.cloud.endpoint.RefreshEndpoint;
import org.springframework.cloud.context.scope.refresh.RefreshScopeRefreshedEvent;
import org.springframework.context.ApplicationEvent;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.event.EventListener;
import org.springframework.util.ClassUtils;
import org.springframework.util.ReflectionUtils;
@ -36,6 +42,20 @@ import org.springframework.util.ReflectionUtils; @@ -36,6 +42,20 @@ import org.springframework.util.ReflectionUtils;
*/
public class RefreshEndpointTests {
@Test
public void eventsPublishedInOrder() throws Exception {
ConfigurableApplicationContext context = new SpringApplicationBuilder(Empty.class)
.web(false).showBanner(false).run();
RefreshScope scope = new RefreshScope();
scope.setApplicationContext(context);
RefreshEndpoint endpoint = new RefreshEndpoint(context, scope);
Empty empty = context.getBean(Empty.class);
endpoint.invoke();
int after = empty.events.size();
assertEquals("Shutdown hooks not cleaned on refresh", 2, after);
assertTrue(empty.events.get(0) instanceof EnvironmentChangeEvent);
}
@Test
public void shutdownHooksCleaned() {
ConfigurableApplicationContext context = new SpringApplicationBuilder(Empty.class)
@ -61,6 +81,14 @@ public class RefreshEndpointTests { @@ -61,6 +81,14 @@ public class RefreshEndpointTests {
@Configuration
protected static class Empty {
private List<ApplicationEvent> events = new ArrayList<ApplicationEvent>();
@EventListener(EnvironmentChangeEvent.class)
public void changed(EnvironmentChangeEvent event) {
this.events.add(event);
}
@EventListener(RefreshScopeRefreshedEvent.class)
public void refreshed(RefreshScopeRefreshedEvent event) {
this.events.add(event);
}
}
}
Loading…
Cancel
Save