Skip to content
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

If both ksp and kapt plugins are available, both also create bean definitions #801

Open
braeluca opened this issue Aug 10, 2023 · 10 comments
Labels
lang: kotlin Issues or features specific to Kotlin

Comments

@braeluca
Copy link

Expected Behavior

If both ksp and kapt plugins are available, only one should be used.

Actual Behaviour

If both ksp and kapt plugins are available, both also create bean definitions, which is inefficient. It also leads to and exception when building the jar:

Execution failed for task ':runnerJar'.
Entry org/example/$ExampleController$Definition$Reference.class is a duplicate but no duplicate handling strategy has been set. Please refer to https://docs.gradle.org/8.2/dsl/org.gradle.api.tasks.Copy.html#org.gradle.api.tasks.Copy:duplicatesStrategy for details.

However this can be resolved by specifying a duplicate strategy, but it is still inefficient. Sometimes kapt is also needed for other annotation processors.

Steps To Reproduce

  1. Create application with micronaut launch: mn create-app --build=gradle_kotlin --jdk=17 --lang=kotlin --test=junit com.example.demo
  2. Create any Bean or Controller
  3. Add kapt plugin to build.gradle.kts
  4. Run the assemble task

Environment Information

  • Operating System: macos 13.4.1 arm
  • JDK 17.0.6

Example Application

https://github.com/braeluca/micronaut-kapt-ksp-demo

Version

4.0.3

@sdelamo
Copy link
Contributor

sdelamo commented Sep 21, 2023

We don't support both KAPT and KSP at the same time.

@sdelamo sdelamo added the lang: kotlin Issues or features specific to Kotlin label Sep 21, 2023
@sdelamo
Copy link
Contributor

sdelamo commented Sep 21, 2023

why do you want to use KAPT and KSP simultaneously?

@braeluca
Copy link
Author

Some other annotation processor does not support ksp and probably never will and therefore i need to apply also the kapt plugin to use these.

@graemerocher
Copy link
Contributor

graemerocher commented Sep 21, 2023

If KSP is present then the inject-java module shouldn't be added to the kapt scope

@graemerocher
Copy link
Contributor

check needs to be added here

configureKotlinCompilerPlugin(project, KAPT_CONFIGURATIONS, "kapt", PluginsHelper.ANNOTATION_PROCESSOR_MODULES);

@melix
Copy link
Collaborator

melix commented Sep 26, 2023

The issue is that we cannot know when the kapt or ksp plugins are applied. So even if we add a check, it can fail. There's more going on than just the annotation processor being added too.

@braeluca
Copy link
Author

But correct me if i am wrong: To apply the dependencies for kapt or ksp scope, it must know, that kapt or ksp are added, right?

An alternative could be to disable kapt in the micronaut plugin via a config.

@melix
Copy link
Collaborator

melix commented Sep 26, 2023

Yes, we can do something when the KSP plugin is applied, or when the kapt plugin is applied. That's what we do. The thing is that we do it "twice" when both are applied. Disabling via configuration could be used too, but it's not that easy either because the flag could be set after the configuration was applied...

@forresthopkinsa
Copy link

Using kapt and ksp at the same time, I get a really non-obvious error: when I run the embedded server locally, it works correctly, but when I push a container to ECS with jib I get the error

More than 1 route matched the incoming request. The following routes matched /: GET - /, GET - /

Interestingly, even if I run the jib container locally, it works fine. Only get this error when running in ECS. Running a pretty minimal hello-world application.

Does Micronaut truly not support using both ksp and kapt at the same time? This would honestly be a significant issue, e.g. for using DynamoDB Object Mapper which currently only (source: micronaut-projects/micronaut-aws#1664) has third party support in Micronaut: com.agorapulse:micronaut-amazon-awssdk-dynamodb, which uses kapt

Even if that is the case, I feel like the behavior I'm seeing is especially cryptic and was extremely hard to troubleshoot. I have not found any other documentation anywhere that suggests that Micronaut does not support kapt and ksp simultaneously. If this is indeed the official policy, I would be happy to contribute docs updates.

@graemerocher
Copy link
Contributor

it is not supported to use both at the same time no, feel free to contribute docs to clarify this

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
lang: kotlin Issues or features specific to Kotlin
Projects
No open projects
Status: No status
Development

No branches or pull requests

5 participants