You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@maven.apache.org by "ASF GitHub Bot (Jira)" <ji...@apache.org> on 2023/05/09 07:40:00 UTC

[jira] [Commented] (MPMD-371) Using two ruleset files with same name in different directories

    [ https://issues.apache.org/jira/browse/MPMD-371?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17720834#comment-17720834 ] 

ASF GitHub Bot commented on MPMD-371:
-------------------------------------

harbulot opened a new pull request, #127:
URL: https://github.com/apache/maven-pmd-plugin/pull/127

   ### Problem
   
   In version 3.20.0 (without this patch), two PMD rulesets that have the same filename will overwrite each other when staged into the `${project.build.directory}/pmd/rulesets/` directory.
   
   In the following example, the two distinct `pmd-ruleset.xml` files will both be copied as `${project.build.directory}/pmd/rulesets/pmd-ruleset.xml`, so the last copied will overwrite the first: only one of those files will be taken into account.
   
   ```xml
   <plugin>
       <groupId>org.apache.maven.plugins</groupId>
       <artifactId>maven-pmd-plugin</artifactId>
       <version>${pmd-maven-plugin.version}</version>
       <configuration>
           <rulesets>
               <ruleset>${project.basedir}/pmd-ruleset.xml</ruleset>
               <ruleset>${project-root.basedir}/pmd-ruleset.xml</ruleset>
           </rulesets>
       </configuration>
   </plugin>
   ```
   
   ### Proposed solution
   
   This patch prefixes the target filename with a counter, based on the position in the ruleset element.
   
   For example:
   
   ```xml
   <rulesets>
       <ruleset>${project.basedir}/pmd-ruleset.xml</ruleset>
       <ruleset>${project.basedir}/otherfolder/other-pmd-ruleset.xml</ruleset>
       <ruleset>${project.basedir}/otherfolder/pmd-ruleset.xml</ruleset>
   </rulesets>
   ```
   
   This would create 3 files in `${project.build.directory}/pmd/rulesets/`:
   
   * `001-pmd-ruleset.xml` (copy of `${project.basedir}/pmd-ruleset.xml`)
   * `002-other-pmd-ruleset.xml` (copy of `${project.basedir}/otherfolder/other-pmd-ruleset.xml`)
   * `003-pmd-ruleset.xml` (copy of `${project.basedir}/otherfolder/pmd-ruleset.xml`, now **not** overwriting the first one)
   
   
   This only required changes a few lines in `PmdReport#getLocationTemp(...)` and `PmdReport.resolveRulesets(...)`.
   
   The rest of the changes is just about adapting the expected locations in those tests . (The expected filename is dependent on the order specified in the POM's `<rulesets />` element.)
   
   The number format is `%03d`, so we assume we'll have fewer than 1000 ruleset files. (This may help if ruleset ordering ever mattered. An alternative would be to remove zero-padding.)
   
   
   ---
   
   Following this checklist to help us incorporate your
   contribution quickly and easily:
   
    - [X] Make sure there is a [JIRA issue](https://issues.apache.org/jira/browse/MPMD) filed
          for the change (usually before you start working on it).  Trivial changes like typos do not
          require a JIRA issue.  Your pull request should address just this issue, without
          pulling in other changes.
    - [X] Each commit in the pull request should have a meaningful subject line and body.
    - [X] Format the pull request title like `[MPMD-XXX] - Subject of the JIRA Ticket`,
          where you replace `MPMD-XXX` with the appropriate JIRA issue. Best practice
          is to use the JIRA issue title in the pull request title and in the first line of the
          commit message.
    - [X] Write a pull request description that is detailed enough to understand what the pull request does, how, and why.
    - [X] Run `mvn clean verify` to make sure basic checks pass. A more thorough check will
          be performed on your pull request automatically.
    - [X] You have run the integration tests successfully (`mvn -Prun-its clean verify`).
   
   If your pull request is about ~20 lines of code you don't need to sign an
   [Individual Contributor License Agreement](https://www.apache.org/licenses/icla.pdf) if you are unsure
   please ask on the developers list.
   
   To make clear that you license your contribution under
   the [Apache License Version 2.0, January 2004](http://www.apache.org/licenses/LICENSE-2.0)
   you have to acknowledge this by using the following check-box.
   
    - [X] I hereby declare this contribution to be licenced under the [Apache License Version 2.0, January 2004](http://www.apache.org/licenses/LICENSE-2.0)
   




> Using two ruleset files with same name in different directories
> ---------------------------------------------------------------
>
>                 Key: MPMD-371
>                 URL: https://issues.apache.org/jira/browse/MPMD-371
>             Project: Maven PMD Plugin
>          Issue Type: Bug
>          Components: PMD
>    Affects Versions: 3.20.0
>            Reporter: Bruno Harbulot
>            Priority: Major
>
> It is not possible to rely on two ruleset files that share the same filename (but are located in different directories).
> Here is an sample configuration for a multi-module project where there is a common {{pmd-ruleset.xml}} file in the parent project and a {{pmd-ruleset.xml}} file in each sub-module. (This is not limited to multi-module projects, it could be any configuration where the same filename is used in different directories.)
>  
> {code:java}
> <plugin>
>     <groupId>org.apache.maven.plugins</groupId>
>     <artifactId>maven-pmd-plugin</artifactId>
>     <version>${pmd-maven-plugin.version}</version>
>     <configuration>
>         <rulesets>
>             <ruleset>${project.basedir}/pmd-ruleset.xml</ruleset>
>             <ruleset>${project-root.basedir}/pmd-ruleset.xml</ruleset>
>         </rulesets>
>     </configuration>
> </plugin>{code}
>  
> The files specified in the {{<ruleset />}} elements are copied into {{{}${project.build.directory}/pmd/rulesets{}}}, but only the actual filename is taken into account during the copy, so the second copy overwrites the first.
> This seems to be due to the implementation of {{PmdReport.resolveRulesets(...)}} and {{PmdReport.getLocationTemp(...)}}



--
This message was sent by Atlassian Jira
(v8.20.10#820010)