Skip to content
This repository has been archived by the owner on Dec 13, 2023. It is now read-only.

Upgrade Conductor to Spring3 #3824

Closed
wants to merge 30 commits into from

Conversation

LuisLainez
Copy link
Contributor

Pull Request type

  • Bugfix
  • Feature
  • Refactoring (no functional changes, no api changes)
  • [X ] Build related changes (Please run ./gradlew generateLock saveLock to refresh dependencies)
  • WHOSUSING.md
  • Other (please describe):

NOTE: Please remember to run ./gradlew spotlessApply to fix any format violations.

Changes in this PR
Upgrading Conductor to Spring 3 - WARNING - Server doesn't start successfully.
The main changes are:

  1. Upgrade Spring version to 3.1.4
  2. Add org.elasticsearch.client is not in the bom - has to be self managed
  3. Groovy + Spock - Version 4.0.9 (changed from org.codehaus to org.apache )
  4. Add com.google.googlejavaformat as it was not in bom
  5. WorkflowDefConstraintTest -> Need to delete the ApacheValidator because bval-jsr does not allow the new jakarta stuff - and version 3x is not yet public.
  6. There is an issue with grpc libraries - they generate the ‘Generated’ tag in javax - and then it can’t compile. As per the thread here protobuf-maven-plugin supports jakarta instead of deprecated javax.annotation · Issue #1113 · grpc/grpc.io , we will need to also add the javax annotation - we should not use it inside the project though: implementation 'javax.annotation:javax.annotation-api:1.3.2'
  7. In HTTPTask , the method field used to be HTTP Method - which was an enum and serialized fine, it is no longer an enum and serializes bad - I am decoupling the internal model from the Spring Framework so it doesn’t break constantly.
  8. I had to add the dependency Maven Repository: org.apache.httpcomponents.client5 » httpclient5 » 5.2.1 because it’s needed in org.springframework.http.client
  9. Had to add the explicit jakarta annotations in grpc-client as it depends on grpc and that has the javax as well - just didnt compile.
  10. In DefaultRestTemplateProvider , the method setReadTimeout is now deprecated and no longer has an effect - so we had to do changes in there. We are no longer user a restTemplate in the constructor, but a builder, and we set up the timeout in there taking into account the input from the task. Alert: This will create more RestTemplates potentially in the thread, but it’s the only way we can set up the timeout PER request. An alternative solution is to create 1 default one and then a custom one per request.
  11. Use GRPC version 1.57.2 - Since that works, keeping it 1+ caused compatibility issues with protobuf.

Describe the new behavior from this PR, and why it's needed
Issue #
Spring 2 is reaching its end of life and will no longer be maintained.
Alternatives considered

Describe alternative implementation you have considered

api 'com.google.protobuf:protobuf-java:3.21.7'
api 'javax.annotation:javax.annotation-api:1.3.2'
api 'com.google.protobuf:protobuf-java:3.21.12'
api 'jakarta.annotation:jakarta.annotation-api:2.1.1'
api gradleApi()
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add jakarta annotation. We move from javax -> jakarta

@@ -1,7 +1,7 @@
{
"annotationProcessor": {
"org.springframework.boot:spring-boot-configuration-processor": {
"locked": "2.7.3"
"locked": "3.1.4"
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Upgrade Spring to 3.1.4

@LuisLainez LuisLainez changed the title Issue/upgrade to spring Upgrade Conductor to Spring3 Oct 26, 2023
@LuisLainez LuisLainez closed this Oct 26, 2023
@LuisLainez LuisLainez reopened this Oct 27, 2023
@LuisLainez LuisLainez closed this Oct 27, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant