-
Notifications
You must be signed in to change notification settings - Fork 157
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[ARIES-2161] Update destroy method to be compatible with spring 5 and 6 #299
base: trunk
Are you sure you want to change the base?
Conversation
Hi @f2par0 |
b1f4597
to
a1c0cd5
Compare
blueprint/blueprint-spring/pom.xml
Outdated
@@ -119,13 +119,13 @@ | |||
<dependency> | |||
<groupId>org.springframework</groupId> | |||
<artifactId>spring-context</artifactId> | |||
<version>4.2.2.RELEASE</version> | |||
<version>6.1.15</version> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I checked that spring 6.x does not work with minimal java 8 that we should have in the repo
you can find the errors by running:
mvn -f blueprint/blueprint-spring clean package
or checking your branch with definition of blueprint build from #297
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes, spring 6 is for java 17, so if java 8 support is required, the latest version is 5.3.39.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
spring 5 is end of life, it does not really make sense to support spring 5. blueprint-spring should support spring 6 (therefore need to move to jdk17) is there a way to move one project without moving all blueprint projects ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are a lot of possible users who stay with Java 8 so it's better to keep all the artifacts compatible with Java 8 if possible. Especially that Spring is not often used in OSGi projects.
But personally I see the value in using the newest version of Spring.
Maybe the solution here may be creating the new artifact blueprint-spring6
. Existing blueprint-spring
could use newest spring 5.x version supporting Java 8. Perfectly the code should be reused between modules so the new module should only override necessary parts (if possible).
WDYT?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but people using spring cannot stay with Java 8, so blueprint-spring itself will not be use in java 8.
Anyway I realized looking at this PR than same code can work for spring 5 and current spring 6 as well with no differences yet, so no need to separate artifacts yet, and blueprint-spring can stay with java 8
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @f2par0
please rebase your branch and update the spring version also in blueprint-spring-extender
and blueprint-itests
to the highest 5.x
You may have a look to an old PR I opened for spring 5 which should work for spring 6 as well |
Problem found : the class
SpringApplicationContext
inherits fromorg.springframework.context.support.AbstractApplicationContext
, which had adestroy
method in version 4, but was deprecated then removed in the version 6 of spring framework.The name of the destroy method must be updated to match this new name