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
8c159050
Commit
8c159050
authored
Dec 15, 2015
by
Phillip Webb
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3847 from akonczak/master
* pr/3847: Auto-configure Elasticsearch converter and context
parents
fce75eba
786f0258
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
55 additions
and
2 deletions
+55
-2
ElasticsearchDataAutoConfiguration.java
...ata/elasticsearch/ElasticsearchDataAutoConfiguration.java
+24
-2
ElasticsearchDataAutoConfigurationTests.java
...lasticsearch/ElasticsearchDataAutoConfigurationTests.java
+31
-0
No files found.
spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/elasticsearch/ElasticsearchDataAutoConfiguration.java
View file @
8c159050
...
...
@@ -25,6 +25,9 @@ import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.data.elasticsearch.core.ElasticsearchTemplate
;
import
org.springframework.data.elasticsearch.core.convert.ElasticsearchConverter
;
import
org.springframework.data.elasticsearch.core.convert.MappingElasticsearchConverter
;
import
org.springframework.data.elasticsearch.core.mapping.SimpleElasticsearchMappingContext
;
import
org.springframework.data.elasticsearch.repository.config.EnableElasticsearchRepositories
;
/**
...
...
@@ -46,8 +49,27 @@ public class ElasticsearchDataAutoConfiguration {
@Bean
@ConditionalOnMissingBean
public
ElasticsearchTemplate
elasticsearchTemplate
(
Client
client
)
{
return
new
ElasticsearchTemplate
(
client
);
public
ElasticsearchTemplate
elasticsearchTemplate
(
Client
client
,
ElasticsearchConverter
converter
)
{
try
{
return
new
ElasticsearchTemplate
(
client
,
converter
);
}
catch
(
Exception
ex
)
{
throw
new
IllegalStateException
(
ex
);
}
}
@Bean
@ConditionalOnMissingBean
public
ElasticsearchConverter
elasticsearchConverter
(
SimpleElasticsearchMappingContext
mappingContext
)
{
return
new
MappingElasticsearchConverter
(
mappingContext
);
}
@Bean
@ConditionalOnMissingBean
public
SimpleElasticsearchMappingContext
mappingContext
()
{
return
new
SimpleElasticsearchMappingContext
();
}
}
spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/elasticsearch/ElasticsearchDataAutoConfigurationTests.java
View file @
8c159050
...
...
@@ -23,6 +23,8 @@ import org.springframework.boot.autoconfigure.PropertyPlaceholderAutoConfigurati
import
org.springframework.boot.test.EnvironmentTestUtils
;
import
org.springframework.context.annotation.AnnotationConfigApplicationContext
;
import
org.springframework.data.elasticsearch.core.ElasticsearchTemplate
;
import
org.springframework.data.elasticsearch.core.convert.ElasticsearchConverter
;
import
org.springframework.data.elasticsearch.core.mapping.SimpleElasticsearchMappingContext
;
import
static
org
.
junit
.
Assert
.
assertEquals
;
...
...
@@ -30,6 +32,7 @@ import static org.junit.Assert.assertEquals;
* Tests for {@link ElasticsearchDataAutoConfiguration}.
*
* @author Phillip Webb
* @author Artur Konczak
*/
public
class
ElasticsearchDataAutoConfigurationTests
{
...
...
@@ -56,4 +59,32 @@ public class ElasticsearchDataAutoConfigurationTests {
this
.
context
.
getBeanNamesForType
(
ElasticsearchTemplate
.
class
).
length
);
}
@Test
public
void
mappingContextExists
()
{
this
.
context
=
new
AnnotationConfigApplicationContext
();
EnvironmentTestUtils
.
addEnvironment
(
this
.
context
,
"spring.data.elasticsearch.properties.path.data:target/data"
,
"spring.data.elasticsearch.properties.path.logs:target/logs"
);
this
.
context
.
register
(
PropertyPlaceholderAutoConfiguration
.
class
,
ElasticsearchAutoConfiguration
.
class
,
ElasticsearchDataAutoConfiguration
.
class
);
this
.
context
.
refresh
();
assertEquals
(
1
,
this
.
context
.
getBeanNamesForType
(
SimpleElasticsearchMappingContext
.
class
).
length
);
}
@Test
public
void
converterExists
()
{
this
.
context
=
new
AnnotationConfigApplicationContext
();
EnvironmentTestUtils
.
addEnvironment
(
this
.
context
,
"spring.data.elasticsearch.properties.path.data:target/data"
,
"spring.data.elasticsearch.properties.path.logs:target/logs"
);
this
.
context
.
register
(
PropertyPlaceholderAutoConfiguration
.
class
,
ElasticsearchAutoConfiguration
.
class
,
ElasticsearchDataAutoConfiguration
.
class
);
this
.
context
.
refresh
();
assertEquals
(
1
,
this
.
context
.
getBeanNamesForType
(
ElasticsearchConverter
.
class
).
length
);
}
}
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