Commit 3c91781b authored by Stephane Nicoll's avatar Stephane Nicoll

Add additional exclude property

The default value of `spring.devtools.restart.exclude` is quite long and
any override requires to copy/paste it to add additional exclusions. To
avoid that, a new `spring.devtools.restart.additional-exclude` property
has been added.

Both properties are now used to compute the full list of exclusions that
is used by PatternClassPathRestartStrategy.

Closes gh-3774
parent 23693c3f
...@@ -22,6 +22,7 @@ import java.util.List; ...@@ -22,6 +22,7 @@ import java.util.List;
import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.NestedConfigurationProperty; import org.springframework.boot.context.properties.NestedConfigurationProperty;
import org.springframework.util.StringUtils;
/** /**
* Configuration properties for developer tools. * Configuration properties for developer tools.
...@@ -71,10 +72,15 @@ public class DevToolsProperties { ...@@ -71,10 +72,15 @@ public class DevToolsProperties {
private boolean enabled = true; private boolean enabled = true;
/** /**
* Patterns that should be excluding for triggering a full restart. * Patterns that should be excluded from triggering a full restart.
*/ */
private String exclude = DEFAULT_RESTART_EXCLUDES; private String exclude = DEFAULT_RESTART_EXCLUDES;
/**
* Additional patterns that should be excluded from triggering a full restart.
*/
private String additionalExclude;
/** /**
* Amount of time (in milliseconds) to wait between polling for classpath changes. * Amount of time (in milliseconds) to wait between polling for classpath changes.
*/ */
...@@ -105,6 +111,17 @@ public class DevToolsProperties { ...@@ -105,6 +111,17 @@ public class DevToolsProperties {
this.enabled = enabled; this.enabled = enabled;
} }
public String[] getAllExclude() {
List<String> allExclude = new ArrayList<String>();
if (StringUtils.hasText(this.exclude)) {
allExclude.addAll(StringUtils.commaDelimitedListToSet(this.exclude));
}
if (StringUtils.hasText(this.additionalExclude)) {
allExclude.addAll(StringUtils.commaDelimitedListToSet(this.additionalExclude));
}
return allExclude.toArray(new String[allExclude.size()]);
}
public String getExclude() { public String getExclude() {
return this.exclude; return this.exclude;
} }
...@@ -113,6 +130,14 @@ public class DevToolsProperties { ...@@ -113,6 +130,14 @@ public class DevToolsProperties {
this.exclude = exclude; this.exclude = exclude;
} }
public String getAdditionalExclude() {
return this.additionalExclude;
}
public void setAdditionalExclude(String additionalExclude) {
this.additionalExclude = additionalExclude;
}
public long getPollInterval() { public long getPollInterval() {
return this.pollInterval; return this.pollInterval;
} }
......
...@@ -123,7 +123,7 @@ public class LocalDevToolsAutoConfiguration { ...@@ -123,7 +123,7 @@ public class LocalDevToolsAutoConfiguration {
@ConditionalOnMissingBean @ConditionalOnMissingBean
public ClassPathRestartStrategy classPathRestartStrategy() { public ClassPathRestartStrategy classPathRestartStrategy() {
return new PatternClassPathRestartStrategy(this.properties.getRestart() return new PatternClassPathRestartStrategy(this.properties.getRestart()
.getExclude()); .getAllExclude());
} }
@Bean @Bean
......
...@@ -33,9 +33,12 @@ public class PatternClassPathRestartStrategy implements ClassPathRestartStrategy ...@@ -33,9 +33,12 @@ public class PatternClassPathRestartStrategy implements ClassPathRestartStrategy
private final String[] excludePatterns; private final String[] excludePatterns;
public PatternClassPathRestartStrategy(String[] excludePatterns) {
this.excludePatterns = excludePatterns;
}
public PatternClassPathRestartStrategy(String excludePatterns) { public PatternClassPathRestartStrategy(String excludePatterns) {
this.excludePatterns = StringUtils this(StringUtils.commaDelimitedListToStringArray(excludePatterns));
.commaDelimitedListToStringArray(excludePatterns);
} }
@Override @Override
......
...@@ -214,7 +214,7 @@ public class RemoteClientConfiguration { ...@@ -214,7 +214,7 @@ public class RemoteClientConfiguration {
@Bean @Bean
public ClassPathRestartStrategy classPathRestartStrategy() { public ClassPathRestartStrategy classPathRestartStrategy() {
return new PatternClassPathRestartStrategy(this.properties.getRestart() return new PatternClassPathRestartStrategy(this.properties.getRestart()
.getExclude()); .getAllExclude());
} }
@Bean @Bean
......
/*
* Copyright 2012-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.boot.devtools.autoconfigure;
import org.junit.Test;
import static org.hamcrest.Matchers.arrayContaining;
import static org.junit.Assert.assertThat;
/**
* Tests for {@link DevToolsProperties}.
*
* @author Stephane Nicoll
*/
public class DevToolsPropertiesTests {
private final DevToolsProperties devToolsProperties = new DevToolsProperties();
@Test
public void additionalExcludeKeepsDefaults() {
DevToolsProperties.Restart restart = this.devToolsProperties.getRestart();
restart.setAdditionalExclude("foo/**,bar/**");
assertThat(restart.getAllExclude(), arrayContaining("META-INF/maven/**",
"META-INF/resources/**", "resources/**", "static/**", "public/**",
"templates/**", "foo/**", "bar/**"));
}
@Test
public void additionalExcludeNoDefault() {
DevToolsProperties.Restart restart = this.devToolsProperties.getRestart();
restart.setExclude("");
restart.setAdditionalExclude("foo/**,bar/**");
assertThat(restart.getAllExclude(), arrayContaining("foo/**", "bar/**"));
}
@Test
public void additionalExcludeCustomDefault() {
DevToolsProperties.Restart restart = this.devToolsProperties.getRestart();
restart.setExclude("biz/**");
restart.setAdditionalExclude("foo/**,bar/**");
assertThat(restart.getAllExclude(), arrayContaining("biz/**", "foo/**", "bar/**"));
}
}
...@@ -627,7 +627,8 @@ content into your application; rather pick only the properties that you need. ...@@ -627,7 +627,8 @@ content into your application; rather pick only the properties that you need.
# DEVTOOLS ({sc-spring-boot-devtools}/autoconfigure/DevToolsProperties.{sc-ext}[DevToolsProperties]) # DEVTOOLS ({sc-spring-boot-devtools}/autoconfigure/DevToolsProperties.{sc-ext}[DevToolsProperties])
spring.devtools.restart.additional-paths= # additional paths to watch for changes spring.devtools.restart.additional-paths= # additional paths to watch for changes
spring.devtools.restart.enabled=true # enable automatic restart spring.devtools.restart.enabled=true # enable automatic restart
spring.devtools.restart.exclude= # patterns that should be excluding for triggering a full restart spring.devtools.restart.exclude= # patterns that should be excluded from triggering a full restart
spring.devtools.restart.additional-exclude= # additional patterns that should be excluded from triggering a full restart
spring.devtools.restart.poll-interval= # amount of time (in milliseconds) to wait between polling for classpath changes spring.devtools.restart.poll-interval= # amount of time (in milliseconds) to wait between polling for classpath changes
spring.devtools.restart.quiet-period= # amount of quiet time (in milliseconds) required without any classpath changes before a restart is triggered spring.devtools.restart.quiet-period= # amount of quiet time (in milliseconds) required without any classpath changes before a restart is triggered
spring.devtools.restart.trigger-file= # name of a specific file that when changed will trigger the restart spring.devtools.restart.trigger-file= # name of a specific file that when changed will trigger the restart
......
...@@ -910,6 +910,8 @@ you can use the `spring.devtools.restart.exclude` property. For example, to excl ...@@ -910,6 +910,8 @@ you can use the `spring.devtools.restart.exclude` property. For example, to excl
spring.devtools.restart.exclude=static/**,public/** spring.devtools.restart.exclude=static/**,public/**
---- ----
TIP: if you want to keep those defaults and _add_ additional exclusions, use the
`spring.devtools.restart.exclude.additional-exclude` property instead.
[[using-boot-devtools-restart-additional-paths]] [[using-boot-devtools-restart-additional-paths]]
......
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