Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in / Register
Toggle navigation
S
spring-boot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
DEMO
spring-boot
Commits
26811b89
Commit
26811b89
authored
Mar 08, 2018
by
Madhura Bhave
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Ignore top-level ConfigurationProperty binding failures
Fixes gh-12357
parent
f47d60e7
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
171 additions
and
1 deletion
+171
-1
ConfigurationPropertiesBinder.java
...oot/context/properties/ConfigurationPropertiesBinder.java
+2
-1
IgnoreTopLevelConverterNotFoundBindHandler.java
...d/handler/IgnoreTopLevelConverterNotFoundBindHandler.java
+45
-0
ConfigurationPropertiesTests.java
...boot/context/properties/ConfigurationPropertiesTests.java
+5
-0
IgnoreTopLevelConverterNotFoundBindHandlerTests.java
...dler/IgnoreTopLevelConverterNotFoundBindHandlerTests.java
+119
-0
No files found.
spring-boot-project/spring-boot/src/main/java/org/springframework/boot/context/properties/ConfigurationPropertiesBinder.java
View file @
26811b89
...
...
@@ -26,6 +26,7 @@ import org.springframework.boot.context.properties.bind.Bindable;
import
org.springframework.boot.context.properties.bind.Binder
;
import
org.springframework.boot.context.properties.bind.PropertySourcesPlaceholdersResolver
;
import
org.springframework.boot.context.properties.bind.handler.IgnoreErrorsBindHandler
;
import
org.springframework.boot.context.properties.bind.handler.IgnoreTopLevelConverterNotFoundBindHandler
;
import
org.springframework.boot.context.properties.bind.handler.NoUnboundElementsBindHandler
;
import
org.springframework.boot.context.properties.bind.validation.ValidationBindHandler
;
import
org.springframework.boot.context.properties.source.ConfigurationPropertySource
;
...
...
@@ -103,7 +104,7 @@ class ConfigurationPropertiesBinder {
private
BindHandler
getBindHandler
(
ConfigurationProperties
annotation
,
List
<
Validator
>
validators
)
{
BindHandler
handler
=
BindHandler
.
DEFAULT
;
BindHandler
handler
=
new
IgnoreTopLevelConverterNotFoundBindHandler
()
;
if
(
annotation
.
ignoreInvalidFields
())
{
handler
=
new
IgnoreErrorsBindHandler
(
handler
);
}
...
...
spring-boot-project/spring-boot/src/main/java/org/springframework/boot/context/properties/bind/handler/IgnoreTopLevelConverterNotFoundBindHandler.java
0 → 100644
View file @
26811b89
/*
* Copyright 2012-2017 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
.
context
.
properties
.
bind
.
handler
;
import
org.springframework.boot.context.properties.bind.AbstractBindHandler
;
import
org.springframework.boot.context.properties.bind.BindContext
;
import
org.springframework.boot.context.properties.bind.BindHandler
;
import
org.springframework.boot.context.properties.bind.Bindable
;
import
org.springframework.boot.context.properties.source.ConfigurationPropertyName
;
import
org.springframework.core.convert.ConverterNotFoundException
;
/**
* {@link BindHandler} that can be used to ignore top-level {@link ConverterNotFoundException}s.
*
* @author Madhura Bhave
* @since 2.0.0
*/
public
class
IgnoreTopLevelConverterNotFoundBindHandler
extends
AbstractBindHandler
{
@Override
public
Object
onFailure
(
ConfigurationPropertyName
name
,
Bindable
<?>
target
,
BindContext
context
,
Exception
error
)
throws
Exception
{
if
(
context
.
getDepth
()
==
0
&&
error
instanceof
ConverterNotFoundException
)
{
return
null
;
}
throw
error
;
}
}
spring-boot-project/spring-boot/src/test/java/org/springframework/boot/context/properties/ConfigurationPropertiesTests.java
View file @
26811b89
...
...
@@ -745,6 +745,11 @@ public class ConfigurationPropertiesTests {
assertThat
(
bean
.
getFile
()).
isEqualTo
(
new
File
(
"."
));
}
@Test
public
void
loadWhenTopLevelConverterNotFoundExceptionShouldNotFail
()
{
load
(
PersonProperties
.
class
,
"test=boot"
);
}
private
AnnotationConfigApplicationContext
load
(
Class
<?>
configuration
,
String
...
inlinedProperties
)
{
return
load
(
new
Class
<?>[]
{
configuration
},
inlinedProperties
);
...
...
spring-boot-project/spring-boot/src/test/java/org/springframework/boot/context/properties/bind/handler/IgnoreTopLevelConverterNotFoundBindHandlerTests.java
0 → 100644
View file @
26811b89
/*
* Copyright 2012-2017 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
.
context
.
properties
.
bind
.
handler
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.Map
;
import
org.junit.After
;
import
org.junit.Before
;
import
org.junit.Rule
;
import
org.junit.Test
;
import
org.junit.rules.ExpectedException
;
import
org.springframework.boot.context.properties.bind.BindException
;
import
org.springframework.boot.context.properties.bind.Bindable
;
import
org.springframework.boot.context.properties.bind.Binder
;
import
org.springframework.boot.context.properties.source.ConfigurationPropertySource
;
import
org.springframework.boot.context.properties.source.MockConfigurationPropertySource
;
import
org.springframework.core.convert.ConverterNotFoundException
;
import
static
org
.
hamcrest
.
Matchers
.
instanceOf
;
/**
* Tests for {@link IgnoreTopLevelConverterNotFoundBindHandler}.
*
* @author Madhura Bhave
*/
public
class
IgnoreTopLevelConverterNotFoundBindHandlerTests
{
@Rule
public
ExpectedException
thrown
=
ExpectedException
.
none
();
private
List
<
ConfigurationPropertySource
>
sources
=
new
ArrayList
<>();
private
Binder
binder
;
@Before
public
void
setup
()
{
MockConfigurationPropertySource
source
=
new
MockConfigurationPropertySource
();
source
.
put
(
"example"
,
"bar"
);
this
.
sources
.
add
(
source
);
this
.
binder
=
new
Binder
(
this
.
sources
);
}
@After
public
void
tearDown
()
{
this
.
sources
.
clear
();
}
@Test
public
void
bindWhenHandlerNotPresentShouldFail
()
{
this
.
thrown
.
expectCause
(
instanceOf
(
ConverterNotFoundException
.
class
));
this
.
binder
.
bind
(
"example"
,
Bindable
.
of
(
Example
.
class
));
}
@Test
public
void
bindWhenTopLevelContextAndExceptionIgnorableShouldNotFail
()
{
this
.
binder
.
bind
(
"example"
,
Bindable
.
of
(
Example
.
class
),
new
IgnoreTopLevelConverterNotFoundBindHandler
());
}
@Test
public
void
bindWhenExceptionNotIgnorableShouldNotFail
()
{
MockConfigurationPropertySource
source
=
new
MockConfigurationPropertySource
();
source
.
put
(
"example.foo"
,
"1"
);
this
.
sources
.
add
(
source
);
this
.
thrown
.
expectCause
(
instanceOf
(
IllegalStateException
.
class
));
this
.
binder
.
bind
(
"example"
,
Bindable
.
of
(
Example
.
class
),
new
IgnoreTopLevelConverterNotFoundBindHandler
());
}
@Test
public
void
bindWhenExceptionInNestedContextShouldFail
()
{
MockConfigurationPropertySource
source
=
new
MockConfigurationPropertySource
();
source
.
put
(
"example.map"
,
"hello"
);
this
.
sources
.
add
(
source
);
this
.
thrown
.
expect
(
BindException
.
class
);
this
.
thrown
.
expectCause
(
instanceOf
(
ConverterNotFoundException
.
class
));
this
.
binder
.
bind
(
"example"
,
Bindable
.
of
(
Example
.
class
),
new
IgnoreTopLevelConverterNotFoundBindHandler
());
}
public
static
class
Example
{
private
int
foo
;
private
Map
<
String
,
String
>
map
;
public
int
getFoo
()
{
return
this
.
foo
;
}
public
void
setFoo
(
int
foo
)
{
throw
new
IllegalStateException
();
}
public
Map
<
String
,
String
>
getMap
()
{
return
this
.
map
;
}
public
void
setMap
(
Map
<
String
,
String
>
map
)
{
this
.
map
=
map
;
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment