Add useAlwaysMessageFormat configuration key
Allow to configure the `useAlwaysMessageFormat` attribute of `MessageSource` via configuration. Closes gh-5483
This commit is contained in:
parent
7db9280bf3
commit
4912b989a5
|
@ -80,6 +80,12 @@ public class MessageSourceAutoConfiguration {
|
||||||
*/
|
*/
|
||||||
private boolean fallbackToSystemLocale = true;
|
private boolean fallbackToSystemLocale = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set whether to always apply the MessageFormat rules, parsing even
|
||||||
|
* messages without arguments.
|
||||||
|
*/
|
||||||
|
private boolean alwaysUseMessageFormat = false;
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public MessageSource messageSource() {
|
public MessageSource messageSource() {
|
||||||
ResourceBundleMessageSource messageSource = new ResourceBundleMessageSource();
|
ResourceBundleMessageSource messageSource = new ResourceBundleMessageSource();
|
||||||
|
@ -92,6 +98,7 @@ public class MessageSourceAutoConfiguration {
|
||||||
}
|
}
|
||||||
messageSource.setFallbackToSystemLocale(this.fallbackToSystemLocale);
|
messageSource.setFallbackToSystemLocale(this.fallbackToSystemLocale);
|
||||||
messageSource.setCacheSeconds(this.cacheSeconds);
|
messageSource.setCacheSeconds(this.cacheSeconds);
|
||||||
|
messageSource.setAlwaysUseMessageFormat(this.alwaysUseMessageFormat);
|
||||||
return messageSource;
|
return messageSource;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,6 +134,14 @@ public class MessageSourceAutoConfiguration {
|
||||||
this.fallbackToSystemLocale = fallbackToSystemLocale;
|
this.fallbackToSystemLocale = fallbackToSystemLocale;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isAlwaysUseMessageFormat() {
|
||||||
|
return this.alwaysUseMessageFormat;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAlwaysUseMessageFormat(boolean alwaysUseMessageFormat) {
|
||||||
|
this.alwaysUseMessageFormat = alwaysUseMessageFormat;
|
||||||
|
}
|
||||||
|
|
||||||
protected static class ResourceBundleCondition extends SpringBootCondition {
|
protected static class ResourceBundleCondition extends SpringBootCondition {
|
||||||
|
|
||||||
private static ConcurrentReferenceHashMap<String, ConditionOutcome> cache = new ConcurrentReferenceHashMap<String, ConditionOutcome>();
|
private static ConcurrentReferenceHashMap<String, ConditionOutcome> cache = new ConcurrentReferenceHashMap<String, ConditionOutcome>();
|
||||||
|
|
|
@ -116,6 +116,21 @@ public class MessageSourceAutoConfigurationTests {
|
||||||
.isFallbackToSystemLocale()).isFalse();
|
.isFallbackToSystemLocale()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFormatMessageDefault() throws Exception {
|
||||||
|
load("spring.messages.basename:test/messages");
|
||||||
|
assertThat(this.context.getBean(MessageSourceAutoConfiguration.class)
|
||||||
|
.isAlwaysUseMessageFormat()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFormatMessageOn() throws Exception {
|
||||||
|
load("spring.messages.basename:test/messages",
|
||||||
|
"spring.messages.always-use-message-format:true");
|
||||||
|
assertThat(this.context.getBean(MessageSourceAutoConfiguration.class)
|
||||||
|
.isAlwaysUseMessageFormat()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void existingMessageSourceIsPreferred() {
|
public void existingMessageSourceIsPreferred() {
|
||||||
this.context = new AnnotationConfigApplicationContext();
|
this.context = new AnnotationConfigApplicationContext();
|
||||||
|
|
|
@ -113,6 +113,7 @@ content into your application; rather pick only the properties that you need.
|
||||||
spring.messages.cache-seconds=-1 # Loaded resource bundle files cache expiration, in seconds. When set to -1, bundles are cached forever.
|
spring.messages.cache-seconds=-1 # Loaded resource bundle files cache expiration, in seconds. When set to -1, bundles are cached forever.
|
||||||
spring.messages.encoding=UTF-8 # Message bundles encoding.
|
spring.messages.encoding=UTF-8 # Message bundles encoding.
|
||||||
spring.messages.fallback-to-system-locale=true # Set whether to fall back to the system Locale if no files for a specific Locale have been found.
|
spring.messages.fallback-to-system-locale=true # Set whether to fall back to the system Locale if no files for a specific Locale have been found.
|
||||||
|
spring.messages.always-use-message-format=false # Set whether to always apply the MessageFormat rules, parsing even messages without arguments.
|
||||||
|
|
||||||
# OUTPUT
|
# OUTPUT
|
||||||
spring.output.ansi.enabled=detect # Configure the ANSI output (can be "detect", "always", "never").
|
spring.output.ansi.enabled=detect # Configure the ANSI output (can be "detect", "always", "never").
|
||||||
|
|
Loading…
Reference in New Issue