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
50000518
Commit
50000518
authored
Dec 22, 2020
by
Stephane Nicoll
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '2.4.x'
Closes gh-24589
parents
72a22f80
33dda3ad
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
162 additions
and
1 deletion
+162
-1
Neo4jDataAutoConfiguration.java
.../autoconfigure/data/neo4j/Neo4jDataAutoConfiguration.java
+4
-1
Neo4jDataAutoConfigurationTests.java
...configure/data/neo4j/Neo4jDataAutoConfigurationTests.java
+23
-0
Neo4jReactiveDataAutoConfigurationTests.java
...e/data/neo4j/Neo4jReactiveDataAutoConfigurationTests.java
+23
-0
TestNode.java
...ramework/boot/autoconfigure/data/neo4j/scan/TestNode.java
+30
-0
TestNonAnnotated.java
.../boot/autoconfigure/data/neo4j/scan/TestNonAnnotated.java
+28
-0
TestPersistent.java
...rk/boot/autoconfigure/data/neo4j/scan/TestPersistent.java
+30
-0
TestRelationshipProperties.java
...configure/data/neo4j/scan/TestRelationshipProperties.java
+24
-0
No files found.
spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jDataAutoConfiguration.java
View file @
50000518
...
...
@@ -35,6 +35,7 @@ import org.springframework.boot.context.properties.EnableConfigurationProperties
import
org.springframework.context.ApplicationContext
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.data.annotation.Persistent
;
import
org.springframework.data.neo4j.core.DatabaseSelectionProvider
;
import
org.springframework.data.neo4j.core.Neo4jClient
;
import
org.springframework.data.neo4j.core.Neo4jOperations
;
...
...
@@ -42,6 +43,7 @@ import org.springframework.data.neo4j.core.Neo4jTemplate;
import
org.springframework.data.neo4j.core.convert.Neo4jConversions
;
import
org.springframework.data.neo4j.core.mapping.Neo4jMappingContext
;
import
org.springframework.data.neo4j.core.schema.Node
;
import
org.springframework.data.neo4j.core.schema.RelationshipProperties
;
import
org.springframework.data.neo4j.core.transaction.Neo4jTransactionManager
;
import
org.springframework.data.neo4j.repository.config.Neo4jRepositoryConfigurationExtension
;
import
org.springframework.transaction.PlatformTransactionManager
;
...
...
@@ -76,7 +78,8 @@ public class Neo4jDataAutoConfiguration {
@ConditionalOnMissingBean
public
Neo4jMappingContext
neo4jMappingContext
(
ApplicationContext
applicationContext
,
Neo4jConversions
neo4jConversions
)
throws
ClassNotFoundException
{
Set
<
Class
<?>>
initialEntityClasses
=
new
EntityScanner
(
applicationContext
).
scan
(
Node
.
class
);
Set
<
Class
<?>>
initialEntityClasses
=
new
EntityScanner
(
applicationContext
).
scan
(
Node
.
class
,
Persistent
.
class
,
RelationshipProperties
.
class
);
Neo4jMappingContext
context
=
new
Neo4jMappingContext
(
neo4jConversions
);
context
.
setInitialEntitySet
(
initialEntityClasses
);
return
context
;
...
...
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jDataAutoConfigurationTests.java
View file @
50000518
...
...
@@ -19,6 +19,11 @@ package org.springframework.boot.autoconfigure.data.neo4j;
import
org.junit.jupiter.api.Test
;
import
org.springframework.boot.autoconfigure.AutoConfigurations
;
import
org.springframework.boot.autoconfigure.TestAutoConfigurationPackage
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestNode
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestNonAnnotated
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestPersistent
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestRelationshipProperties
;
import
org.springframework.boot.autoconfigure.neo4j.Neo4jAutoConfiguration
;
import
org.springframework.boot.test.context.runner.ApplicationContextRunner
;
import
org.springframework.context.annotation.Bean
;
...
...
@@ -29,6 +34,7 @@ import org.springframework.data.neo4j.core.Neo4jClient;
import
org.springframework.data.neo4j.core.Neo4jOperations
;
import
org.springframework.data.neo4j.core.Neo4jTemplate
;
import
org.springframework.data.neo4j.core.convert.Neo4jConversions
;
import
org.springframework.data.neo4j.core.mapping.Neo4jMappingContext
;
import
org.springframework.data.neo4j.core.transaction.Neo4jTransactionManager
;
import
org.springframework.transaction.PlatformTransactionManager
;
import
org.springframework.transaction.ReactiveTransactionManager
;
...
...
@@ -137,6 +143,17 @@ class Neo4jDataAutoConfigurationTests {
.
hasBean
(
"myCustomTransactionManager"
));
}
@Test
void
shouldFilterInitialEntityScanWithKnownAnnotations
()
{
this
.
contextRunner
.
withUserConfiguration
(
EntityScanConfig
.
class
).
run
((
context
)
->
{
Neo4jMappingContext
mappingContext
=
context
.
getBean
(
Neo4jMappingContext
.
class
);
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestNode
.
class
)).
isTrue
();
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestPersistent
.
class
)).
isTrue
();
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestRelationshipProperties
.
class
)).
isTrue
();
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestNonAnnotated
.
class
)).
isFalse
();
});
}
@Configuration
(
proxyBeanMethods
=
false
)
static
class
CustomDatabaseSelectionProviderConfiguration
{
...
...
@@ -147,4 +164,10 @@ class Neo4jDataAutoConfigurationTests {
}
@Configuration
(
proxyBeanMethods
=
false
)
@TestAutoConfigurationPackage
(
TestPersistent
.
class
)
static
class
EntityScanConfig
{
}
}
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jReactiveDataAutoConfigurationTests.java
View file @
50000518
...
...
@@ -21,6 +21,11 @@ import reactor.core.publisher.Mono;
import
reactor.test.StepVerifier
;
import
org.springframework.boot.autoconfigure.AutoConfigurations
;
import
org.springframework.boot.autoconfigure.TestAutoConfigurationPackage
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestNode
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestNonAnnotated
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestPersistent
;
import
org.springframework.boot.autoconfigure.data.neo4j.scan.TestRelationshipProperties
;
import
org.springframework.boot.autoconfigure.neo4j.Neo4jAutoConfiguration
;
import
org.springframework.boot.test.context.runner.ApplicationContextRunner
;
import
org.springframework.context.annotation.Bean
;
...
...
@@ -30,6 +35,7 @@ import org.springframework.data.neo4j.core.ReactiveDatabaseSelectionProvider;
import
org.springframework.data.neo4j.core.ReactiveNeo4jClient
;
import
org.springframework.data.neo4j.core.ReactiveNeo4jOperations
;
import
org.springframework.data.neo4j.core.ReactiveNeo4jTemplate
;
import
org.springframework.data.neo4j.core.mapping.Neo4jMappingContext
;
import
org.springframework.transaction.ReactiveTransactionManager
;
import
org.springframework.transaction.TransactionManager
;
...
...
@@ -121,6 +127,17 @@ class Neo4jReactiveDataAutoConfigurationTests {
.
hasSingleBean
(
TransactionManager
.
class
));
}
@Test
void
shouldFilterInitialEntityScanWithKnownAnnotations
()
{
this
.
contextRunner
.
withUserConfiguration
(
EntityScanConfig
.
class
).
run
((
context
)
->
{
Neo4jMappingContext
mappingContext
=
context
.
getBean
(
Neo4jMappingContext
.
class
);
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestNode
.
class
)).
isTrue
();
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestPersistent
.
class
)).
isTrue
();
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestRelationshipProperties
.
class
)).
isTrue
();
assertThat
(
mappingContext
.
hasPersistentEntityFor
(
TestNonAnnotated
.
class
)).
isFalse
();
});
}
@Configuration
(
proxyBeanMethods
=
false
)
static
class
CustomReactiveDatabaseSelectionProviderConfiguration
{
...
...
@@ -131,4 +148,10 @@ class Neo4jReactiveDataAutoConfigurationTests {
}
@Configuration
(
proxyBeanMethods
=
false
)
@TestAutoConfigurationPackage
(
TestPersistent
.
class
)
static
class
EntityScanConfig
{
}
}
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/neo4j/scan/TestNode.java
0 → 100644
View file @
50000518
/*
* Copyright 2012-2020 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
*
* https://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
.
autoconfigure
.
data
.
neo4j
.
scan
;
import
org.springframework.data.neo4j.core.schema.GeneratedValue
;
import
org.springframework.data.neo4j.core.schema.Id
;
import
org.springframework.data.neo4j.core.schema.Node
;
@Node
public
class
TestNode
{
@Id
@GeneratedValue
private
Long
id
;
}
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/neo4j/scan/TestNonAnnotated.java
0 → 100644
View file @
50000518
/*
* Copyright 2012-2020 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
*
* https://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
.
autoconfigure
.
data
.
neo4j
.
scan
;
import
org.springframework.data.neo4j.core.schema.GeneratedValue
;
import
org.springframework.data.neo4j.core.schema.Id
;
public
class
TestNonAnnotated
{
@Id
@GeneratedValue
private
Long
id
;
}
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/neo4j/scan/TestPersistent.java
0 → 100644
View file @
50000518
/*
* Copyright 2012-2020 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
*
* https://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
.
autoconfigure
.
data
.
neo4j
.
scan
;
import
org.springframework.data.annotation.Persistent
;
import
org.springframework.data.neo4j.core.schema.GeneratedValue
;
import
org.springframework.data.neo4j.core.schema.Id
;
@Persistent
public
class
TestPersistent
{
@Id
@GeneratedValue
private
Long
id
;
}
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/neo4j/scan/TestRelationshipProperties.java
0 → 100644
View file @
50000518
/*
* Copyright 2012-2020 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
*
* https://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
.
autoconfigure
.
data
.
neo4j
.
scan
;
import
org.springframework.data.neo4j.core.schema.RelationshipProperties
;
@RelationshipProperties
public
class
TestRelationshipProperties
{
}
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