diff --git a/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng7344EffectivePomPluginTest.java b/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng7344EffectivePomPluginTest.java
new file mode 100644
index 000000000..b3dc2421b
--- /dev/null
+++ b/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng7344EffectivePomPluginTest.java
@@ -0,0 +1,55 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.maven.it;
+
+import java.io.File;
+
+import org.apache.maven.shared.verifier.Verifier;
+import org.apache.maven.shared.verifier.util.ResourceExtractor;
+import org.junit.jupiter.api.Test;
+
+public class MavenITmng7344EffectivePomPluginTest extends AbstractMavenIntegrationTestCase {
+ public MavenITmng7344EffectivePomPluginTest() {
+ super("[4.0.0-alpha-13,)");
+ }
+
+ @Test
+ public void testIt() throws Exception {
+ File testDir = ResourceExtractor.simpleExtractResources(getClass(), "/mng-7344-effective-pom");
+
+ Verifier verifier = newVerifier(new File(testDir, "plugin").getAbsolutePath(), "remote");
+ verifier.addCliArgument("install");
+ verifier.execute();
+ verifier.verifyErrorFreeLog();
+
+ for (String childFolder : new String[] {"dep-x", "bom-parent", "bom-intermediate"}) {
+ verifier = newVerifier(new File(testDir, childFolder).getAbsolutePath());
+ verifier.addCliArgument("install");
+ verifier.execute();
+ verifier.verifyErrorFreeLog();
+ }
+
+ verifier = newVerifier(new File(testDir, "consumer").getAbsolutePath());
+ verifier.setForkJvm(true);
+ verifier.addCliArgument("compile");
+ verifier.execute();
+
+ verifier.verifyTextInLog("[INFO] bom-intermediate-1.0-SNAPSHOT.pom @ 8:3");
+ }
+}
diff --git a/core-it-suite/src/test/java/org/apache/maven/it/TestSuiteOrdering.java b/core-it-suite/src/test/java/org/apache/maven/it/TestSuiteOrdering.java
index 27fe7d9d0..f8c50ad83 100644
--- a/core-it-suite/src/test/java/org/apache/maven/it/TestSuiteOrdering.java
+++ b/core-it-suite/src/test/java/org/apache/maven/it/TestSuiteOrdering.java
@@ -775,6 +775,7 @@ public TestSuiteOrdering() {
suite.addTestSuite(MavenIT0010DependencyClosureResolutionTest.class);
suite.addTestSuite(MavenIT0009GoalConfigurationTest.class);
suite.addTestSuite(MavenIT0008SimplePluginTest.class);
+ suite.addTestSuite(MavenITmng7344EffectivePomPluginTest.class);
/*
* Add tests in reverse alpha order above.
*/
diff --git a/core-it-suite/src/test/resources/mng-7344-effective-pom/bom-intermediate/pom.xml b/core-it-suite/src/test/resources/mng-7344-effective-pom/bom-intermediate/pom.xml
new file mode 100644
index 000000000..c45bfd4f3
--- /dev/null
+++ b/core-it-suite/src/test/resources/mng-7344-effective-pom/bom-intermediate/pom.xml
@@ -0,0 +1,22 @@
+
+
+
+ 4.0.0
+
+ org.apache.maven.its.mng7344
+ bom-intermediate
+ 1.0-SNAPSHOT
+ pom
+
+
+
+
+ org.apache.maven.its.mng7344
+ bom-parent
+ 1.0-SNAPSHOT
+ pom
+ import
+
+
+
+
diff --git a/core-it-suite/src/test/resources/mng-7344-effective-pom/bom-parent/pom.xml b/core-it-suite/src/test/resources/mng-7344-effective-pom/bom-parent/pom.xml
new file mode 100644
index 000000000..88a09bbb8
--- /dev/null
+++ b/core-it-suite/src/test/resources/mng-7344-effective-pom/bom-parent/pom.xml
@@ -0,0 +1,20 @@
+
+
+
+ 4.0.0
+
+ org.apache.maven.its.mng7344
+ bom-parent
+ 1.0-SNAPSHOT
+ pom
+
+
+
+
+ org.apache.maven.its.mng7344
+ dep-x
+ 2
+
+
+
+
diff --git a/core-it-suite/src/test/resources/mng-7344-effective-pom/consumer/pom.xml b/core-it-suite/src/test/resources/mng-7344-effective-pom/consumer/pom.xml
new file mode 100644
index 000000000..fbe9cacba
--- /dev/null
+++ b/core-it-suite/src/test/resources/mng-7344-effective-pom/consumer/pom.xml
@@ -0,0 +1,65 @@
+
+
+
+ 4.0.0
+
+ org.apache.maven.its.mng7344
+ consumer
+ 1.0-SNAPSHOT
+
+
+
+
+ org.apache.maven.its.mng7344
+ bom-intermediate
+ 1.0-SNAPSHOT
+ pom
+ import
+
+
+
+
+
+
+ org.apache.maven.its.mng7344
+ dep-x
+
+
+
+
+
+
+ org.apache.maven.its.mng7344
+ mng-7344-maven-plugin
+ 1.0-SNAPSHOT
+
+
+ effective-pom
+
+ effective-pom
+
+ compile
+
+
+
+
+
+
+
diff --git a/core-it-suite/src/test/resources/mng-7344-effective-pom/dep-x/pom.xml b/core-it-suite/src/test/resources/mng-7344-effective-pom/dep-x/pom.xml
new file mode 100644
index 000000000..ffc681473
--- /dev/null
+++ b/core-it-suite/src/test/resources/mng-7344-effective-pom/dep-x/pom.xml
@@ -0,0 +1,9 @@
+
+
+
+ 4.0.0
+
+ org.apache.maven.its.mng7344
+ dep-x
+ 2
+
diff --git a/core-it-suite/src/test/resources/mng-7344-effective-pom/plugin/pom.xml b/core-it-suite/src/test/resources/mng-7344-effective-pom/plugin/pom.xml
new file mode 100644
index 000000000..5f3afc1dd
--- /dev/null
+++ b/core-it-suite/src/test/resources/mng-7344-effective-pom/plugin/pom.xml
@@ -0,0 +1,76 @@
+
+
+
+ 4.0.0
+
+ org.apache.maven.its.mng7344
+ mng-7344-maven-plugin
+ 1.0-SNAPSHOT
+ maven-plugin
+
+
+ ${mavenVersion}
+
+
+
+ 8
+ 3.6.3
+ 3.9.0
+
+
+
+
+ org.apache.maven
+ maven-plugin-api
+ ${mavenVersion}
+ provided
+
+
+ org.apache.maven
+ maven-core
+ ${mavenVersion}
+ provided
+
+
+ org.apache.maven
+ maven-model
+ ${mavenVersion}
+ provided
+
+
+ org.apache.maven.plugin-tools
+ maven-plugin-annotations
+ ${mavenPluginToolsVersion}
+ provided
+
+
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-plugin-plugin
+ ${mavenPluginToolsVersion}
+
+
+
+
+
diff --git a/core-it-suite/src/test/resources/mng-7344-effective-pom/plugin/src/main/java/testmojo/EffectivePomMojo.java b/core-it-suite/src/test/resources/mng-7344-effective-pom/plugin/src/main/java/testmojo/EffectivePomMojo.java
new file mode 100644
index 000000000..6bf90cc1f
--- /dev/null
+++ b/core-it-suite/src/test/resources/mng-7344-effective-pom/plugin/src/main/java/testmojo/EffectivePomMojo.java
@@ -0,0 +1,82 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package testmojo;
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import java.lang.reflect.Field;
+import java.util.List;
+
+import org.apache.maven.model.Dependency;
+import org.apache.maven.plugin.AbstractMojo;
+import org.apache.maven.plugin.MojoExecutionException;
+import org.apache.maven.plugin.MojoFailureException;
+import org.apache.maven.plugins.annotations.Mojo;
+import org.apache.maven.plugins.annotations.Parameter;
+import org.apache.maven.project.MavenProject;
+
+@Mojo(name = "effective-pom", aggregator = true)
+public class EffectivePomMojo extends AbstractMojo {
+
+ @Parameter(defaultValue = "${reactorProjects}", required = true, readonly = true)
+ private List projects;
+
+ public void execute() throws MojoExecutionException, MojoFailureException {
+ projects.stream()
+ .map(MavenProject::getDependencyManagement)
+ .map(depMgt -> depMgt != null ? depMgt.getDependencies() : null)
+ .filter(dependencies -> dependencies != null)
+ .flatMap(List::stream)
+ .forEach(dependency -> {
+ getLog().info("" + dependency);
+ try {
+ getLog().info(getImportedFrom(dependency));
+ } catch (Exception ex) {
+ getLog().error("Failed to get importedFrom");
+ }
+ });
+ }
+
+ private String getImportedFrom(Dependency dependency) throws Exception {
+ Field delegateField = Class.forName("org.apache.maven.model.BaseObject").getDeclaredField("delegate");
+ delegateField.setAccessible(true);
+ Object delegate = delegateField.get(dependency);
+ delegateField.setAccessible(false);
+ Object importedFrom = delegate.getClass().getMethod("getImportedFrom").invoke(delegate);
+
+ return ("" + importedFrom).replaceAll("^.*[\\\\/]", "");
+ }
+}