-
Notifications
You must be signed in to change notification settings - Fork 77
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
ConcurrentModificationException
while running dryRun
with mvnd
#780
Comments
Hi @motlin! In your project are you running multiple modules/plugins in parallel? There's no threading in the OpenRewrite Maven build plugin, but it looks like the Maven project's resources are getting modified out from under the plugin itself based on the stacktrace. |
Hi @shanman190, yes I'm running The rewrite plugin is explicitly marked thread-safe: https://github.com/search?q=repo%3Aopenrewrite%2Frewrite-maven-plugin%20threadSafe&type=code |
Oh wow, that's quite unfortunate; I must admit I hadn't tried |
ConcurrentModificationException
while running dryRun
with mvnd
In clicking through the stack trace I'm a bit puzzled why our use of rewrite-maven-plugin/src/main/java/org/openrewrite/maven/MavenMojoProjectParser.java Lines 404 to 407 in a482eff
I don't think there's very much we could do differently, seeing how the CCME is triggered on this line in Apache Maven: Does the same work for you if you use |
The
Still not sure if that's something we'd have much control over. 🤔 |
I would think the phases would happen in a serial fashion within each module independently as that particular module works toward the specified goal. To me this feels like a plugin that is modifying the current module's configuration within a separate thread or an entirely separate plugin in some other module running at the same time is crossing the module boundary. But I don't know for sure. From the Maven docs, they state that the entirety of Maven proper is all thread safe, but they can make no guarantees on plugins and their specific behavior. |
Because of the nature of this as a concurrency problem, I don't run into it frequently and haven't reproduced it with It's always possible to make a maven plugin thread-safe but it would be difficult to do it reliably without understanding the problem better. For example, we could add |
I think the problem here is OpenRewrite + something else. I'm not sure what the something else part of the equation is though. From an OpenRewrite standpoint, we are reading the dependencies -- as noted by Tim -- while something else is modifying the module's dependencies. Given Maven proper is all thread safe, my only remaining idea is some other plugin of either the current module or a plugin somewhere else in the Maven build is the one that is violating the thread safety here. |
Not sure if it helps, but same error happens with Gradle run as well. This can be reproduced on repo - https://github.com/iamrakesh/vfs-s3/tree/add-gradle-nature Using below Gradle command
Using below Maven command
|
@iamrakesh, so the the issue that you're seeing there is similar, but not actually related to the issue being described here. While your issue is also a
This error should be reported against the https://github.com/aws/aws-sdk-java-v2 repository where those OpenRewrite recipes are being maintained. |
Thank you for checking it (y), I see one has already been created for it - aws/aws-sdk-java-v2#5666 |
I just saw this exception while running through The command I ran: ./mvnw install org.openrewrite.maven:rewrite-maven-plugin:dryRun --activate-profiles rewrite-maven-plugin,rewrite-maven-plugin-dryRun -DskipTests The full build logs: https://github.com/liftwizard/klass/actions/runs/12589911149/job/35090556599?pr=272 The error: 23:01:35:159 [ERROR] Failed to execute goal org.openrewrite.maven:rewrite-maven-plugin:5.46.3:dryRun (default-cli) on project stackoverflow-dropwizard-application: Execution default-cli of goal org.openrewrite.maven:rewrite-maven-plugin:5.46.3:dryRun failed.: ConcurrentModificationException -> [Help 1]
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.openrewrite.maven:rewrite-maven-plugin:5.46.3:dryRun (default-cli) on project stackoverflow-dropwizard-application: Execution default-cli of goal org.openrewrite.maven:rewrite-maven-plugin:5.46.3:dryRun failed.
at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute2 (MojoExecutor.java:339)
at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute (MojoExecutor.java:321)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:217)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:178)
at org.apache.maven.lifecycle.internal.MojoExecutor.access$000 (MojoExecutor.java:77)
at org.apache.maven.lifecycle.internal.MojoExecutor$1.run (MojoExecutor.java:166)
at org.apache.maven.plugin.DefaultMojosExecutionStrategy.execute (DefaultMojosExecutionStrategy.java:39)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:163)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:114)
at org.apache.maven.lifecycle.internal.builder.multithreaded.MultiThreadedBuilder.lambda$createBuildCallable$1 (MultiThreadedBuilder.java:203)
at java.util.concurrent.FutureTask.run (FutureTask.java:264)
at java.util.concurrent.Executors$RunnableAdapter.call (Executors.java:539)
at java.util.concurrent.FutureTask.run (FutureTask.java:264)
at java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1136)
at java.util.concurrent.ThreadPoolExecutor$Worker.run (ThreadPoolExecutor.java:635)
at java.lang.Thread.run (Thread.java:842)
Caused by: org.apache.maven.plugin.PluginExecutionException: Execution default-cli of goal org.openrewrite.maven:rewrite-maven-plugin:5.46.3:dryRun failed.
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo (DefaultBuildPluginManager.java:149)
at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute2 (MojoExecutor.java:333)
at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute (MojoExecutor.java:321)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:217)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:178)
at org.apache.maven.lifecycle.internal.MojoExecutor.access$000 (MojoExecutor.java:77)
at org.apache.maven.lifecycle.internal.MojoExecutor$1.run (MojoExecutor.java:166)
at org.apache.maven.plugin.DefaultMojosExecutionStrategy.execute (DefaultMojosExecutionStrategy.java:39)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:163)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:114)
at org.apache.maven.lifecycle.internal.builder.multithreaded.MultiThreadedBuilder.lambda$createBuildCallable$1 (MultiThreadedBuilder.java:203)
at java.util.concurrent.FutureTask.run (FutureTask.java:264)
at java.util.concurrent.Executors$RunnableAdapter.call (Executors.java:539)
at java.util.concurrent.FutureTask.run (FutureTask.java:264)
at java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1136)
at java.util.concurrent.ThreadPoolExecutor$Worker.run (ThreadPoolExecutor.java:635)
at java.lang.Thread.run (Thread.java:842)
Caused by: java.util.ConcurrentModificationException
at java.util.LinkedHashMap$LinkedHashIterator.nextNode (LinkedHashMap.java:756)
at java.util.LinkedHashMap$LinkedKeyIterator.next (LinkedHashMap.java:778)
at org.apache.maven.project.MavenProject.getCompileClasspathElements (MavenProject.java:331)
at org.openrewrite.maven.MavenMojoProjectParser.processMainSources (MavenMojoProjectParser.java:404)
at org.openrewrite.maven.MavenMojoProjectParser.listSourceFiles (MavenMojoProjectParser.java:181)
at org.openrewrite.maven.MavenMojoProjectParser.lambda$listSourceFiles$0 (MavenMojoProjectParser.java:153)
at java.util.stream.ReferencePipeline$7$1.accept (ReferencePipeline.java:273)
at java.util.ArrayList$ArrayListSpliterator.forEachRemaining (ArrayList.java:1625)
at java.util.stream.AbstractPipeline.copyInto (AbstractPipeline.java:509)
at java.util.stream.AbstractPipeline.wrapAndCopyInto (AbstractPipeline.java:499)
at java.util.stream.ReduceOps$ReduceOp.evaluateSequential (ReduceOps.java:921)
at java.util.stream.AbstractPipeline.evaluate (AbstractPipeline.java:234)
at java.util.stream.ReferencePipeline.collect (ReferencePipeline.java:682)
at org.openrewrite.maven.AbstractRewriteBaseRunMojo.sourcesWithAutoDetectedStyles (AbstractRewriteBaseRunMojo.java:275)
at org.openrewrite.maven.AbstractRewriteBaseRunMojo.loadSourceSet (AbstractRewriteBaseRunMojo.java:237)
at org.openrewrite.maven.AbstractRewriteBaseRunMojo.listResults (AbstractRewriteBaseRunMojo.java:152)
at org.openrewrite.maven.AbstractRewriteDryRunMojo.execute (AbstractRewriteDryRunMojo.java:70)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo (DefaultBuildPluginManager.java:143)
at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute2 (MojoExecutor.java:333)
at org.apache.maven.lifecycle.internal.MojoExecutor.doExecute (MojoExecutor.java:321)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:217)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:178)
at org.apache.maven.lifecycle.internal.MojoExecutor.access$000 (MojoExecutor.java:77)
at org.apache.maven.lifecycle.internal.MojoExecutor$1.run (MojoExecutor.java:166)
at org.apache.maven.plugin.DefaultMojosExecutionStrategy.execute (DefaultMojosExecutionStrategy.java:39)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:163)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:114)
at org.apache.maven.lifecycle.internal.builder.multithreaded.MultiThreadedBuilder.lambda$createBuildCallable$1 (MultiThreadedBuilder.java:203)
at java.util.concurrent.FutureTask.run (FutureTask.java:264)
at java.util.concurrent.Executors$RunnableAdapter.call (Executors.java:539)
at java.util.concurrent.FutureTask.run (FutureTask.java:264)
at java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1136)
at java.util.concurrent.ThreadPoolExecutor$Worker.run (ThreadPoolExecutor.java:635)
at java.lang.Thread.run (Thread.java:842) |
@motlin, it looks like the project is configured with parallel enabled via the maven.config file. https://github.com/liftwizard/klass/blob/main/.mvn/maven.config But maybe we can debug the project to figure out what is triggering the Maven model to change internally when the build is running in parallel. |
@shanman190 Yes, I'm running maven with parallelism, and the rewrite plugin is explicitly marked thread-safe: github.com/search?q=repo%3Aopenrewrite%2Frewrite-maven-plugin%20threadSafe&type=code |
Yeah, and that's because itself it is. The Maven core model is being updated out from under OpenRewrite by something, but we haven't been able to nail down what combination of things is actually making the modification itself (OpenRewrite is just reading the data from the dependency list using an interator when the stacktrace happens). |
Also I should mention that I first saw the exception running a maven build in https://github.com/liftwizard/liftwizard, and just now in a related project https://github.com/liftwizard/klass. Whatever is the issue isn't specific to one project, or the fact that the second project includes maven plugins in the reactor. |
So you believe the concurrency problem is in maven itself? Or there's some combination of maven API usage that causes concurrent modifications inside maven core? |
So Maven core is supposed to be thread safe. What my current idea is there is some other plugin in the build that is adding a dependency from their plugin to the module's build which is not a thread safe thing to do. This then impacts the thread safety of Maven itself and all plugins regardless of them being thread safe themselves. |
What version of OpenRewrite are you using?
I am using
How are you running OpenRewrite?
I am using the Maven plugin, and my project is a multi module project.
The command I ran was
mvnd install org.openrewrite.maven:rewrite-maven-plugin:dryRun --projects '!liftwizard-example' --activate-profiles 'rewrite-maven-plugin-strict,rewrite-maven-plugin-dryRun' -DskipTests
What is the full stack trace of any errors you encountered?
The text was updated successfully, but these errors were encountered: