diff --git a/pom.xml b/pom.xml index aa592b2b..5d714947 100644 --- a/pom.xml +++ b/pom.xml @@ -78,10 +78,10 @@ under the License. 1.4.1 9.3 1.7.36 - 1.11.1 - 1.11.1 - 3.12.1 - 3.3.0 + 2.0.0-M12 + 2.0.0-M19 + 3.20.0 + 3.4.0 2024-06-02T14:45:45Z @@ -132,12 +132,12 @@ under the License. org.apache.maven.reporting maven-reporting-api - 3.1.1 + 4.0.0-M12 org.apache.maven.reporting maven-reporting-impl - 3.2.0 + 4.0.0-M15 diff --git a/src/it/MCHECKSTYLE-222-resources/verify.groovy b/src/it/MCHECKSTYLE-222-resources/verify.groovy index db588b99..0d9ff04e 100644 --- a/src/it/MCHECKSTYLE-222-resources/verify.groovy +++ b/src/it/MCHECKSTYLE-222-resources/verify.groovy @@ -17,6 +17,6 @@ * under the License. */ -assert new File(basedir, 'target/site/checkstyle.html').exists(); +assert new File(basedir, 'target/reports/checkstyle.html').exists(); return true; diff --git a/src/it/MCHECKSTYLE-222-testResources/verify.groovy b/src/it/MCHECKSTYLE-222-testResources/verify.groovy index db588b99..0d9ff04e 100644 --- a/src/it/MCHECKSTYLE-222-testResources/verify.groovy +++ b/src/it/MCHECKSTYLE-222-testResources/verify.groovy @@ -17,6 +17,6 @@ * under the License. */ -assert new File(basedir, 'target/site/checkstyle.html').exists(); +assert new File(basedir, 'target/reports/checkstyle.html').exists(); return true; diff --git a/src/it/MCHECKSTYLE-338/verify.groovy b/src/it/MCHECKSTYLE-338/verify.groovy index 71b05da1..6c606b9c 100644 --- a/src/it/MCHECKSTYLE-338/verify.groovy +++ b/src/it/MCHECKSTYLE-338/verify.groovy @@ -25,7 +25,7 @@ assert buildLog.text.contains( 'EmptyLogging: EmptyLoggingCheck on file TestFals assert !buildLog.text.contains( 'EmptyLogging: EmptyLoggingCheck on file TestTrue.java' ) // verify that the "checkstyle" goal does the same -site = new File( basedir, 'omitignoredmodules-false/target/site/checkstyle.html' ) +site = new File( basedir, 'omitignoredmodules-false/target/reports/checkstyle.html' ) assert site.text.contains( 'EmptyLoggingCheck on file TestFalse.java' ) -site = new File( basedir, 'omitignoredmodules-true/target/site/checkstyle.html' ) +site = new File( basedir, 'omitignoredmodules-true/target/reports/checkstyle.html' ) assert !site.text.contains( 'EmptyLoggingCheck on file TestTrue.java' ) diff --git a/src/it/MCHECKSTYLE-412/src/main/java/org/MyClass.java b/src/it/MCHECKSTYLE-412/src/main/java/org/MyClass.java deleted file mode 100644 index 1645c138..00000000 --- a/src/it/MCHECKSTYLE-412/src/main/java/org/MyClass.java +++ /dev/null @@ -1,26 +0,0 @@ -package org; - -/* - * 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. - */ - -/** - * My class. - */ -public class MyClass { -} diff --git a/src/it/MCHECKSTYLE-99-custom-xref-test-location/verify.groovy b/src/it/MCHECKSTYLE-99-custom-xref-test-location/verify.groovy index c0e8435c..e15f882e 100644 --- a/src/it/MCHECKSTYLE-99-custom-xref-test-location/verify.groovy +++ b/src/it/MCHECKSTYLE-99-custom-xref-test-location/verify.groovy @@ -18,9 +18,9 @@ * under the License. */ -site = new File( basedir, 'target/site/checkstyle.html' ) -assert site.exists(); -assert site.text.contains( '' ) -assert site.text.contains( '' ) +report = new File( basedir, 'target/reports/checkstyle.html' ) +assert report.exists(); +assert report.text.contains( '' ) +assert report.text.contains( '' ) return true; diff --git a/src/it/MCHECKSTYLE-99/verify.groovy b/src/it/MCHECKSTYLE-99/verify.groovy index 15675520..fc04c778 100644 --- a/src/it/MCHECKSTYLE-99/verify.groovy +++ b/src/it/MCHECKSTYLE-99/verify.groovy @@ -18,9 +18,9 @@ * under the License. */ -site = new File( basedir, 'target/site/checkstyle.html' ) -assert site.exists(); -assert site.text.contains( '' ) -assert site.text.contains( '' ) +report = new File( basedir, 'target/reports/checkstyle.html' ) +assert report.exists(); +assert report.text.contains( '' ) +assert report.text.contains( '' ) return true; diff --git a/src/it/checkstyle-goal/verify.groovy b/src/it/checkstyle-goal/verify.groovy index 9cdc38c0..22a61c4e 100644 --- a/src/it/checkstyle-goal/verify.groovy +++ b/src/it/checkstyle-goal/verify.groovy @@ -24,7 +24,7 @@ assert new File( basedir, 'target/checkstyle-checker.xml' ).exists(); assert new File( basedir, 'target/checkstyle-header.txt' ).exists(); assert new File( basedir, 'target/checkstyle-result.xml' ).exists(); -def html = new File( basedir, 'target/site/checkstyle.html' ).text; +def html = new File( basedir, 'target/reports/checkstyle.html' ).text; assert html.contains( '' ); return true; diff --git a/src/main/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleReport.java b/src/main/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleReport.java index e86b6d9f..0193c549 100644 --- a/src/main/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleReport.java +++ b/src/main/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleReport.java @@ -26,6 +26,7 @@ import java.io.OutputStream; import java.nio.file.Path; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import java.util.Locale; import java.util.Map; @@ -42,6 +43,7 @@ import org.apache.maven.model.Plugin; import org.apache.maven.model.PluginManagement; import org.apache.maven.model.ReportPlugin; +import org.apache.maven.model.Reporting; import org.apache.maven.model.Resource; import org.apache.maven.plugin.descriptor.PluginDescriptor; import org.apache.maven.plugins.annotations.Component; @@ -50,6 +52,7 @@ import org.apache.maven.plugins.checkstyle.exec.CheckstyleExecutorException; import org.apache.maven.plugins.checkstyle.exec.CheckstyleExecutorRequest; import org.apache.maven.plugins.checkstyle.exec.CheckstyleResults; +import org.apache.maven.project.MavenProject; import org.apache.maven.reporting.AbstractMavenReport; import org.apache.maven.reporting.MavenReportException; import org.codehaus.plexus.configuration.PlexusConfiguration; @@ -345,8 +348,8 @@ public abstract class AbstractCheckstyleReport extends AbstractMavenReport { private PluginDescriptor plugin; /** - * Link the violation line numbers to the source xref. Will link - * automatically if Maven JXR plugin is being used. + * Link the violation line numbers to the (Test) Source XRef. Links will be created automatically if the JXR plugin is + * being used. * * @since 2.1 */ @@ -354,15 +357,19 @@ public abstract class AbstractCheckstyleReport extends AbstractMavenReport { private boolean linkXRef; /** - * Location of the Xrefs to link to. + * Location where Source XRef is generated for this project. + *
+ * Default: {@link #getReportOutputDirectory()} + {@code /xref} */ - @Parameter(defaultValue = "${project.reporting.outputDirectory}/xref") + @Parameter private File xrefLocation; /** - * Location of the XrefTests to link to. + * Location where Test Source XRef is generated for this project. + *
+ * Default: {@link #getReportOutputDirectory()} + {@code /xref-test} */ - @Parameter(defaultValue = "${project.reporting.outputDirectory}/xref-test") + @Parameter private File xrefTestLocation; /** @@ -474,6 +481,53 @@ protected String getI18nString(Locale locale, String key) { return i18n.getString("checkstyle-report", locale, "report.checkstyle." + key); } + protected MavenProject getProject() { + return project; + } + + protected List getReactorProjects() { + return reactorProjects; + } + + protected String constructXrefLocation(boolean test, boolean haveResults) { + String location = null; + if (linkXRef) { + File xrefLocation = getXrefLocation(test); + + String relativePath = PathTool.getRelativePath( + getReportOutputDirectory().getAbsolutePath(), xrefLocation.getAbsolutePath()); + if (relativePath == null || relativePath.isEmpty()) { + relativePath = "."; + } + relativePath = relativePath + "/" + xrefLocation.getName(); + if (xrefLocation.exists()) { + // XRef was already generated by manual execution of a lifecycle binding + location = relativePath; + } else { + // Not yet generated - check if the report is on its way + Reporting reporting = project.getModel().getReporting(); + List reportPlugins = + reporting != null ? reporting.getPlugins() : Collections.emptyList(); + for (ReportPlugin plugin : reportPlugins) { + String artifactId = plugin.getArtifactId(); + if ("maven-jxr-plugin".equals(artifactId) || "jxr-maven-plugin".equals(artifactId)) { + location = relativePath; + } + } + } + + if (location == null && haveResults) { + getLog().warn("Unable to locate" + (test ? " Test" : "") + " Source XRef to link to - DISABLED"); + } + } + return location; + } + + protected File getXrefLocation(boolean test) { + File location = test ? xrefTestLocation : xrefLocation; + return location != null ? location : new File(getReportOutputDirectory(), test ? "xref-test" : "xref"); + } + /** {@inheritDoc} */ public void executeReport(Locale locale) throws MavenReportException { checkDeprecatedParameterUsage(sourceDirectory, "sourceDirectory", "sourceDirectories"); @@ -519,6 +573,7 @@ public void executeReport(Locale locale) throws MavenReportException { CheckstyleResults results = checkstyleExecutor.executeCheckstyle(request); + boolean haveResults = results.getFileCount() > 0; CheckstyleReportRenderer r = new CheckstyleReportRenderer( getSink(), i18n, @@ -526,23 +581,13 @@ public void executeReport(Locale locale) throws MavenReportException { project, siteTool, effectiveConfigLocation, + constructXrefLocation(false, haveResults), + constructXrefLocation(true, haveResults), + linkXRef ? getTestSourceDirectories() : Collections.emptyList(), enableRulesSummary, enableSeveritySummary, enableFilesSummary, results); - if (linkXRef) { - initializeXrefLocation(r); - if (r.getXrefLocation() == null && results.getFileCount() > 0) { - getLog().warn("Unable to locate Source XRef to link to - DISABLED"); - } - - initializeXrefTestLocation(r); - if (r.getXrefTestLocation() == null && results.getFileCount() > 0) { - getLog().warn("Unable to locate Test Source XRef to link to - DISABLED"); - } - - r.setTestSourceDirectories(getTestSourceDirectories()); - } if (treeWalkerNames != null) { r.setTreeWalkerNames(treeWalkerNames); } @@ -673,24 +718,6 @@ protected DefaultLogger getConsoleListener() throws MavenReportException { return consoleListener; } - private void initializeXrefLocation(CheckstyleReportRenderer renderer) { - String relativePath = determineRelativePath(xrefLocation); - if (xrefLocation.exists() || checkMavenJxrPluginIsConfigured()) { - // XRef was already generated by manual execution of a lifecycle binding - // the report is on its way - renderer.setXrefLocation(relativePath); - } - } - - private void initializeXrefTestLocation(CheckstyleReportRenderer renderer) { - String relativePath = determineRelativePath(xrefTestLocation); - if (xrefTestLocation.exists() || checkMavenJxrPluginIsConfigured()) { - // XRef was already generated by manual execution of a lifecycle binding - // the report is on its way - renderer.setXrefTestLocation(relativePath); - } - } - private String determineRelativePath(File location) { String relativePath = PathTool.getRelativePath(getReportOutputDirectory().getAbsolutePath(), location.getAbsolutePath()); @@ -701,17 +728,6 @@ private String determineRelativePath(File location) { return relativePath + "/" + location.getName(); } - private boolean checkMavenJxrPluginIsConfigured() { - for (ReportPlugin report : (Iterable) getProject().getReportPlugins()) { - String artifactId = report.getArtifactId(); - if ("maven-jxr-plugin".equals(artifactId) || "jxr-maven-plugin".equals(artifactId)) { - return true; - } - } - - return false; - } - protected List getSourceDirectories() { if (sourceDirectories == null) { sourceDirectories = filterBuildTarget(project.getCompileSourceRoots()); diff --git a/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleAggregateReport.java b/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleAggregateReport.java index 0419d283..232e2486 100644 --- a/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleAggregateReport.java +++ b/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleAggregateReport.java @@ -18,13 +18,9 @@ */ package org.apache.maven.plugins.checkstyle; -import java.util.List; - import org.apache.maven.plugins.annotations.Mojo; -import org.apache.maven.plugins.annotations.Parameter; import org.apache.maven.plugins.annotations.ResolutionScope; import org.apache.maven.plugins.checkstyle.exec.CheckstyleExecutorRequest; -import org.apache.maven.project.MavenProject; import org.apache.maven.reporting.MavenReportException; /** @@ -40,19 +36,6 @@ requiresDependencyResolution = ResolutionScope.COMPILE, threadSafe = true) public class CheckstyleAggregateReport extends AbstractCheckstyleReport { - /** - * The projects in the reactor for aggregation report. - * - * @since 2.8 - */ - @Parameter(property = "reactorProjects", readonly = true) - private List reactorProjects; - - /** {@inheritDoc} */ - protected MavenProject getProject() { - return project; - } - /** * {@inheritDoc} */ diff --git a/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReport.java b/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReport.java index 15f16e04..ed575f4c 100644 --- a/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReport.java +++ b/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReport.java @@ -25,7 +25,6 @@ import org.apache.maven.plugins.annotations.Mojo; import org.apache.maven.plugins.annotations.ResolutionScope; import org.apache.maven.plugins.checkstyle.exec.CheckstyleExecutorRequest; -import org.apache.maven.project.MavenProject; import org.apache.maven.reporting.MavenReportException; /** @@ -39,12 +38,6 @@ */ @Mojo(name = "checkstyle", requiresDependencyResolution = ResolutionScope.COMPILE, threadSafe = true) public class CheckstyleReport extends AbstractCheckstyleReport { - - /** {@inheritDoc} */ - protected MavenProject getProject() { - return project; - } - /** * {@inheritDoc} */ diff --git a/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReportRenderer.java b/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReportRenderer.java index 3db3497f..8b47d6f7 100644 --- a/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReportRenderer.java +++ b/src/main/java/org/apache/maven/plugins/checkstyle/CheckstyleReportRenderer.java @@ -69,7 +69,7 @@ public class CheckstyleReportRenderer extends AbstractMavenReportRenderer { private String xrefTestLocation; - private List testSourceDirectories = new ArrayList<>(); + private List testSourceDirectories; private List treeWalkerNames = Collections.singletonList("TreeWalker"); @@ -84,6 +84,9 @@ public CheckstyleReportRenderer( MavenProject project, SiteTool siteTool, String ruleset, + String xrefLocation, + String xrefTestLocation, + List testSourceDirectories, boolean enableRulesSummary, boolean enableSeveritySummary, boolean enableFilesSummary, @@ -94,6 +97,9 @@ public CheckstyleReportRenderer( this.project = project; this.siteTool = siteTool; this.ruleset = ruleset; + this.xrefLocation = xrefLocation; + this.xrefTestLocation = xrefTestLocation; + this.testSourceDirectories = testSourceDirectories; this.enableRulesSummary = enableRulesSummary; this.enableSeveritySummary = enableSeveritySummary; this.enableFilesSummary = enableFilesSummary; @@ -542,9 +548,9 @@ private void renderFileEvents(List eventList, String filename) { private String getEffectiveXrefLocation(List eventList) { String absoluteFilename = eventList.get(0).getFileName(); if (isTestSource(absoluteFilename)) { - return getXrefTestLocation(); + return xrefTestLocation; } else { - return getXrefLocation(); + return xrefLocation; } } @@ -558,26 +564,6 @@ private boolean isTestSource(final String absoluteFilename) { return false; } - public String getXrefLocation() { - return xrefLocation; - } - - public void setXrefLocation(String xrefLocation) { - this.xrefLocation = xrefLocation; - } - - public String getXrefTestLocation() { - return xrefTestLocation; - } - - public void setXrefTestLocation(String xrefTestLocation) { - this.xrefTestLocation = xrefTestLocation; - } - - public void setTestSourceDirectories(List testSourceDirectories) { - this.testSourceDirectories = testSourceDirectories; - } - public void setTreeWalkerNames(List treeWalkerNames) { this.treeWalkerNames = treeWalkerNames; } diff --git a/src/test/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleTestCase.java b/src/test/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleTestCase.java index 9db52c9b..7aaa6fdc 100644 --- a/src/test/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleTestCase.java +++ b/src/test/java/org/apache/maven/plugins/checkstyle/AbstractCheckstyleTestCase.java @@ -21,9 +21,14 @@ import java.io.File; import java.io.IOException; import java.nio.file.Files; -import java.util.Locale; +import java.util.Collections; +import java.util.List; +import org.apache.maven.model.Plugin; import org.apache.maven.plugin.LegacySupport; +import org.apache.maven.plugin.MojoExecution; +import org.apache.maven.plugin.descriptor.MojoDescriptor; +import org.apache.maven.plugin.descriptor.PluginDescriptor; import org.apache.maven.plugin.testing.AbstractMojoTestCase; import org.apache.maven.plugin.testing.ArtifactStubFactory; import org.apache.maven.plugin.testing.stubs.MavenProjectStub; @@ -39,8 +44,6 @@ * Abstract class to test reports generation. */ public abstract class AbstractCheckstyleTestCase extends AbstractMojoTestCase { - private Locale oldLocale; - private ArtifactStubFactory artifactStubFactory; /** @@ -53,21 +56,10 @@ protected void setUp() throws Exception { // required for mojo lookups to work super.setUp(); - oldLocale = Locale.getDefault(); - Locale.setDefault(Locale.ENGLISH); - artifactStubFactory = new DependencyArtifactStubFactory(getTestFile("target"), true, false); artifactStubFactory.getWorkingDir().mkdirs(); } - @Override - protected void tearDown() throws Exception { - super.tearDown(); - - Locale.setDefault(oldLocale); - oldLocale = null; - } - /** * Get the current Maven project * @@ -121,8 +113,17 @@ protected CheckstyleReport createReportMojo(String goal, File pluginXmlFile) thr repoSession.setLocalRepositoryManager(new SimpleLocalRepositoryManagerFactory() .newInstance(repoSession, new LocalRepository(artifactStubFactory.getWorkingDir()))); + List reactorProjects = + mojo.getReactorProjects() != null ? mojo.getReactorProjects() : Collections.emptyList(); + + setVariableValueToObject(mojo, "mojoExecution", getMockMojoExecution()); setVariableValueToObject(mojo, "session", legacySupport.getSession()); - setVariableValueToObject(mojo, "remoteRepositories", mojo.getProject().getRemoteArtifactRepositories()); + setVariableValueToObject(mojo, "repoSession", legacySupport.getRepositorySession()); + setVariableValueToObject(mojo, "reactorProjects", reactorProjects); + setVariableValueToObject( + mojo, "remoteProjectRepositories", mojo.getProject().getRemoteProjectRepositories()); + setVariableValueToObject( + mojo, "siteDirectory", new File(mojo.getProject().getBasedir(), "src/site")); return mojo; } @@ -148,4 +149,22 @@ protected File generateReport(CheckstyleReport mojo, File pluginXmlFile) throws protected String readFile(File checkstyleTestDir, String fileName) throws IOException { return new String(Files.readAllBytes(checkstyleTestDir.toPath().resolve(fileName))); } + + private MojoExecution getMockMojoExecution() { + MojoDescriptor md = new MojoDescriptor(); + md.setGoal(getGoal()); + + MojoExecution me = new MojoExecution(md); + + PluginDescriptor pd = new PluginDescriptor(); + Plugin p = new Plugin(); + p.setGroupId("org.apache.maven.plugins"); + p.setArtifactId("maven-checkstyle-plugin"); + pd.setPlugin(p); + md.setPluginDescriptor(pd); + + return me; + } + + protected abstract String getGoal(); } diff --git a/src/test/java/org/apache/maven/plugins/checkstyle/CheckstyleReportTest.java b/src/test/java/org/apache/maven/plugins/checkstyle/CheckstyleReportTest.java index 13263304..038839b1 100644 --- a/src/test/java/org/apache/maven/plugins/checkstyle/CheckstyleReportTest.java +++ b/src/test/java/org/apache/maven/plugins/checkstyle/CheckstyleReportTest.java @@ -22,10 +22,10 @@ import java.io.File; import java.io.FileReader; import java.io.IOException; -import java.util.Locale; import java.util.ResourceBundle; import org.apache.maven.artifact.DependencyResolutionRequiredException; +import org.apache.maven.doxia.tools.SiteTool; import org.apache.maven.plugin.descriptor.PluginDescriptor; import org.codehaus.plexus.util.FileUtils; @@ -35,11 +35,8 @@ */ public class CheckstyleReportTest extends AbstractCheckstyleTestCase { public void testNoSource() throws Exception { - // clean up after earlier runs - File report = new File("target/test-harness/checkstyle/no-source/checkstyle.html"); - report.delete(); - File generatedReport = generateReport("checkstyle", "no-source-plugin-config.xml"); - assertFalse(report + " exists", generatedReport.exists()); + File generatedReport = generateReport(getGoal(), "no-source-plugin-config.xml"); + assertFalse(FileUtils.fileExists(generatedReport.getAbsolutePath())); } public void testMinConfiguration() throws Exception { @@ -117,9 +114,9 @@ private String readFile(File file) throws IOException { private void generateReport(String pluginXml) throws Exception { File pluginXmlFile = new File(getBasedir(), "src/test/resources/plugin-configs/" + pluginXml); ResourceBundle bundle = - ResourceBundle.getBundle("checkstyle-report", Locale.getDefault(), this.getClassLoader()); + ResourceBundle.getBundle("checkstyle-report", SiteTool.DEFAULT_LOCALE, this.getClassLoader()); - CheckstyleReport mojo = createReportMojo("checkstyle", pluginXmlFile); + CheckstyleReport mojo = createReportMojo(getGoal(), pluginXmlFile); PluginDescriptor descriptorStub = new PluginDescriptor(); descriptorStub.setGroupId("org.apache.maven.plugins"); @@ -173,6 +170,11 @@ private void generateReport(String pluginXml) throws Exception { } private static String getHtmlHeader(String s) { - return ">" + s + ""; + return ">" + s + ""; + } + + @Override + protected String getGoal() { + return "checkstyle"; } } diff --git a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/CheckstyleProjectStub.java b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/CheckstyleProjectStub.java index 82e3d040..f85404bd 100644 --- a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/CheckstyleProjectStub.java +++ b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/CheckstyleProjectStub.java @@ -18,16 +18,34 @@ */ package org.apache.maven.plugins.checkstyle.stubs; +import java.io.File; import java.util.Collections; import java.util.List; +import org.apache.maven.RepositoryUtils; import org.apache.maven.artifact.repository.ArtifactRepository; import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy; import org.apache.maven.artifact.repository.MavenArtifactRepository; import org.apache.maven.artifact.repository.layout.DefaultRepositoryLayout; import org.apache.maven.plugin.testing.stubs.MavenProjectStub; +import org.eclipse.aether.repository.RemoteRepository; public abstract class CheckstyleProjectStub extends MavenProjectStub { + /** + * @return the POM file name + */ + protected abstract String getPOM(); + + @Override + public File getBasedir() { + return new File(super.getBasedir() + "/src/test/resources/plugin-configs/"); + } + + @Override + public File getFile() { + return new File(getBasedir(), getPOM()); + } + @Override public List getRemoteArtifactRepositories() { ArtifactRepository repository = new MavenArtifactRepository( @@ -39,4 +57,9 @@ public List getRemoteArtifactRepositories() { return Collections.singletonList(repository); } + + @Override + public List getRemoteProjectRepositories() { + return RepositoryUtils.toRepos(getRemoteArtifactRepositories()); + } } diff --git a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MinMavenProjectStub.java b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MinMavenProjectStub.java index a9bb6caf..1dcaa0cb 100644 --- a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MinMavenProjectStub.java +++ b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MinMavenProjectStub.java @@ -18,7 +18,6 @@ */ package org.apache.maven.plugins.checkstyle.stubs; -import java.io.File; import java.util.ArrayList; import java.util.Collections; import java.util.List; @@ -41,19 +40,19 @@ public List getCompileClasspathElements() throws DependencyResolutionReq /** {@inheritDoc} */ public List getTestClasspathElements() throws DependencyResolutionRequiredException { List list = new ArrayList<>(getCompileClasspathElements()); - list.add("target/test-classes"); + list.add(getBasedir() + "/target/test-classes"); return list; } /** {@inheritDoc} */ public List getCompileSourceRoots() { - return Collections.singletonList("target/classes"); + return Collections.singletonList(getBasedir() + "/target/classes"); } /** {@inheritDoc} */ public List getTestCompileSourceRoots() { List list = new ArrayList<>(getCompileSourceRoots()); - list.add("target/test-classes"); + list.add(getBasedir() + "/target/test-classes"); return list; } @@ -84,15 +83,13 @@ public String getInceptionYear() { public Build getBuild() { Build build = new Build(); - build.setDirectory("target/test-harness/checkstyle/min"); + build.setDirectory(getBasedir() + "/target/test-harness/checkstyle/min"); return build; } - /** {@inheritDoc} */ - public File getFile() { - File file = new File(getBasedir(), "pom.xml"); - - return file; + @Override + protected String getPOM() { + return "min-plugin-config.xml"; } } diff --git a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/ModuleMavenProjectStub.java b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/ModuleMavenProjectStub.java index 4279abf9..4bc3136f 100644 --- a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/ModuleMavenProjectStub.java +++ b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/ModuleMavenProjectStub.java @@ -18,7 +18,6 @@ */ package org.apache.maven.plugins.checkstyle.stubs; -import java.io.File; import java.util.ArrayList; import java.util.Collections; import java.util.List; @@ -42,19 +41,19 @@ public List getCompileClasspathElements() throws DependencyResolutionReq /** {@inheritDoc} */ public List getTestClasspathElements() throws DependencyResolutionRequiredException { List list = new ArrayList<>(getCompileClasspathElements()); - list.add("target/test-classes"); + list.add(getBasedir() + "/target/test-classes"); return list; } /** {@inheritDoc} */ public List getCompileSourceRoots() { - return Collections.singletonList("target/classes"); + return Collections.singletonList(getBasedir() + "/target/classes"); } /** {@inheritDoc} */ public List getTestCompileSourceRoots() { List list = new ArrayList<>(getCompileSourceRoots()); - list.add("target/test-classes"); + list.add(getBasedir() + "/target/test-classes"); return list; } @@ -85,17 +84,15 @@ public String getInceptionYear() { public Build getBuild() { Build build = new Build(); - build.setDirectory("target/test-harness/checkstyle/multi"); - build.setSourceDirectory("src/test/test-sources"); - build.setTestSourceDirectory("src/test/java"); + build.setDirectory(getBasedir() + "/target/test-harness/checkstyle/multi"); + build.setSourceDirectory(getBasedir() + "/src/test/test-sources"); + build.setTestSourceDirectory(getBasedir() + "/src/test/java"); return build; } - /** {@inheritDoc} */ - public File getFile() { - File file = new File(getBasedir(), "pom.xml"); - - return file; + @Override + protected String getPOM() { + return "multi-plugin-config.xml"; } } diff --git a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MultiMavenProjectStub.java b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MultiMavenProjectStub.java index a0c5f946..20790ee4 100644 --- a/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MultiMavenProjectStub.java +++ b/src/test/java/org/apache/maven/plugins/checkstyle/stubs/MultiMavenProjectStub.java @@ -18,7 +18,6 @@ */ package org.apache.maven.plugins.checkstyle.stubs; -import java.io.File; import java.util.Collections; import java.util.List; @@ -89,15 +88,13 @@ public String getInceptionYear() { public Build getBuild() { Build build = new Build(); - build.setDirectory("target/test-harness/checkstyle/multi"); + build.setDirectory(getBasedir() + "/target/test-harness/checkstyle/multi"); return build; } - /** {@inheritDoc} */ - public File getFile() { - File file = new File(getBasedir(), "pom.xml"); - - return file; + @Override + protected String getPOM() { + return "multi-plugin-config.xml"; } } diff --git a/src/test/resources/plugin-configs/custom-plugin-config.xml b/src/test/resources/plugin-configs/custom-plugin-config.xml index 830a9286..4d3703b0 100644 --- a/src/test/resources/plugin-configs/custom-plugin-config.xml +++ b/src/test/resources/plugin-configs/custom-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/custom - ${localRepository} true true true diff --git a/src/test/resources/plugin-configs/dep-resolution-exception-plugin-config.xml b/src/test/resources/plugin-configs/dep-resolution-exception-plugin-config.xml index 7d1c8cb0..aba1d2e4 100644 --- a/src/test/resources/plugin-configs/dep-resolution-exception-plugin-config.xml +++ b/src/test/resources/plugin-configs/dep-resolution-exception-plugin-config.xml @@ -24,7 +24,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/dep-resolution - ${localRepository} true true true diff --git a/src/test/resources/plugin-configs/min-plugin-config.xml b/src/test/resources/plugin-configs/min-plugin-config.xml index 1cb1e8e9..b897fff6 100644 --- a/src/test/resources/plugin-configs/min-plugin-config.xml +++ b/src/test/resources/plugin-configs/min-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/min - ${localRepository} true true true diff --git a/src/test/resources/plugin-configs/no-files-plugin-config.xml b/src/test/resources/plugin-configs/no-files-plugin-config.xml index 49061c73..d09c3a9c 100644 --- a/src/test/resources/plugin-configs/no-files-plugin-config.xml +++ b/src/test/resources/plugin-configs/no-files-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/no-files - ${localRepository} true true false diff --git a/src/test/resources/plugin-configs/no-rules-plugin-config.xml b/src/test/resources/plugin-configs/no-rules-plugin-config.xml index a3795edd..60b4cd84 100644 --- a/src/test/resources/plugin-configs/no-rules-plugin-config.xml +++ b/src/test/resources/plugin-configs/no-rules-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/no-rules - ${localRepository} false true true diff --git a/src/test/resources/plugin-configs/no-severity-plugin-config.xml b/src/test/resources/plugin-configs/no-severity-plugin-config.xml index fb785b11..f65b18ab 100644 --- a/src/test/resources/plugin-configs/no-severity-plugin-config.xml +++ b/src/test/resources/plugin-configs/no-severity-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/no-severity - ${localRepository} true false true diff --git a/src/test/resources/plugin-configs/test-source-directory-plugin-config.xml b/src/test/resources/plugin-configs/test-source-directory-plugin-config.xml index 9ca9d037..79cf03a1 100644 --- a/src/test/resources/plugin-configs/test-source-directory-plugin-config.xml +++ b/src/test/resources/plugin-configs/test-source-directory-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/no-source - ${localRepository} true true true diff --git a/src/test/resources/plugin-configs/useFile-plugin-config.xml b/src/test/resources/plugin-configs/useFile-plugin-config.xml index f78464d3..acb5ba34 100644 --- a/src/test/resources/plugin-configs/useFile-plugin-config.xml +++ b/src/test/resources/plugin-configs/useFile-plugin-config.xml @@ -28,7 +28,6 @@ under the License. maven-checkstyle-plugin ${basedir}/target/test-harness/checkstyle/useFile - ${localRepository} true true true