MNG-6209 better executeMojo thread context classloader Signed-off-by: Igor Fedorenko <ifedore...@apache.org>
Project: http://git-wip-us.apache.org/repos/asf/maven/repo Commit: http://git-wip-us.apache.org/repos/asf/maven/commit/ec629f7d Tree: http://git-wip-us.apache.org/repos/asf/maven/tree/ec629f7d Diff: http://git-wip-us.apache.org/repos/asf/maven/diff/ec629f7d Branch: refs/heads/MNG-6123-detect-self-references Commit: ec629f7d511eb910b4e80112a9fbe85ed8786f10 Parents: 567af0d Author: Igor Fedorenko <ifedore...@apache.org> Authored: Tue Apr 11 07:59:34 2017 -0700 Committer: Igor Fedorenko <ifedore...@apache.org> Committed: Thu Apr 13 14:12:23 2017 -0700 ---------------------------------------------------------------------- .../java/org/apache/maven/plugin/DefaultBuildPluginManager.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/maven/blob/ec629f7d/maven-core/src/main/java/org/apache/maven/plugin/DefaultBuildPluginManager.java ---------------------------------------------------------------------- diff --git a/maven-core/src/main/java/org/apache/maven/plugin/DefaultBuildPluginManager.java b/maven-core/src/main/java/org/apache/maven/plugin/DefaultBuildPluginManager.java index b4f7a4d..3af1125 100644 --- a/maven-core/src/main/java/org/apache/maven/plugin/DefaultBuildPluginManager.java +++ b/maven-core/src/main/java/org/apache/maven/plugin/DefaultBuildPluginManager.java @@ -106,8 +106,11 @@ public class DefaultBuildPluginManager throw new PluginExecutionException( mojoExecution, project, e ); } + // use project realm as thread context classloader to enable components from all extensions=true plugins + ClassRealm tccl = mojoExecution.getPlugin().isExtensions() ? project.getClassRealm() : pluginRealm; + ClassLoader oldClassLoader = Thread.currentThread().getContextClassLoader(); - Thread.currentThread().setContextClassLoader( pluginRealm ); + Thread.currentThread().setContextClassLoader( tccl ); MavenSession oldSession = legacySupport.getSession();