Uploaded image for project: 'Maven Archetype'
  1. Maven Archetype
  2. ARCHETYPE-613

Different gererating result with user defined parameters

Attach filesAttach ScreenshotAdd voteVotersWatch issueWatchersCreate sub-taskLinkCloneUpdate Comment AuthorReplace String in CommentUpdate Comment VisibilityDelete Comments
    XMLWordPrintableJSON

Details

    • Bug
    • Status: Open
    • Major
    • Resolution: Unresolved
    • 3.2.0
    • None
    • Plugin
    • None
    • maven 3.6.3(right), maven3.6.1(wrong), IDEA2020.1(wrong)

    Description

      Happend in two different maven version 3.6.1 and 3.6.3,

      I defined my archetype-metadata.xml as following:

      //代码占位符
      <requiredProperties>
          <requiredProperty key="groupId"/>
          <requiredProperty key="artifactId"/>
          <requiredProperty key="version">
              <defaultValue>1.0.0-SNAPSHOT</defaultValue>
          </requiredProperty>
          <requiredProperty key="package"/>
          <requiredProperty key="projectName"/>
          <requiredProperty key="xxxx1"/> //user defined parameter
          <requiredProperty key="xxxx2"> // user defined parameter
         <defaultValue>${package.getClass().forName("org.apache.velocity.util.StringUtils").nullTrim("")}</defaultValue> //default is null;
          </requiredProperty>
          

       and following are some others parameter tansformed by abover parameters

      //代码占位符
      <requiredProperty key="xxxx3" >
          <defaultValue>${xxxx1.toUpperCase()}</defaultValue>
      </requiredProperty>
      <requiredProperty key="xxxx4" >
          <defaultValue>${xxxx1.toLowerCase().substring(0,1).toUpperCase()}${xxxx1.toLowerCase().substring(1)}</defaultValue>
      </requiredProperty>
      
      <requiredProperty key="xxxx5" >
          <defaultValue>${package.getClass().forName("org.apache.velocity.util.StringUtils").nullTrim("$xxxx2").toUpperCase()}</defaultValue>
      </requiredProperty>
      <requiredProperty key="xxxx6" >
          <defaultValue>${package.getClass().forName("org.apache.velocity.util.StringUtils").firstLetterCaps("${xxxx2}_").replaceAll("_","")}</defaultValue>
      </requiredProperty>
      <requiredProperty key="xxxx7" >
          <defaultValue>${xxxx4}${xxxx6}</defaultValue>
      </requiredProperty>
      ....
      
      

      when I use command "mvn archetype : generate ...." in maven 3.6.3, i got the right generated project ,and all the parameters are as my expected including parameters which need to be evaluated. But in maven 3.6.1(In fact , I'm not sure whether the version cause the difference"), it's different, some parameters are not evaluatedd correctly like following:

      //代码占位符
      ...
      Parameter: xxxx3, Value: ${xxxx1.toUpperCase()}
      [INFO] Parameter: xxxxx6, Value: _${xxxx}_
      [INFO] Parameter: xxxxx,  Value: _xxxx_
      ...

      as you see, some parameters are evaluated, but some are not.  In fact , I found this happened also in 'mvn command' and 'maven archetype generating process in IDEA'. And I found following source code in maven-archetype plugin:

      //代码占位符
      private Context prepareVelocityContext(ArchetypeGenerationRequest request) {
          Context context = new VelocityContext();
          context.put(Constants.GROUP_ID, request.getGroupId());
          context.put(Constants.ARTIFACT_ID, request.getArtifactId());
          context.put(Constants.VERSION, request.getVersion());
          context.put(Constants.PACKAGE, request.getPackage());
          final String packageInPathFormat = getPackageInPathFormat(request.getPackage());
          context.put(Constants.PACKAGE_IN_PATH_FORMAT, packageInPathFormat);
      
          if (getLogger().isInfoEnabled()) {
              getLogger().info("----------------------------------------------------------------------------");
      
              getLogger().info(
                      "Using following parameters for creating project from Archetype: " + request
                              .getArchetypeArtifactId()
                              + ":" + request.getArchetypeVersion());
      
              getLogger().info("----------------------------------------------------------------------------");
              getLogger().info("Parameter: " + Constants.GROUP_ID + ", Value: " + request.getGroupId());
              getLogger().info("Parameter: " + Constants.ARTIFACT_ID + ", Value: " + request.getArtifactId());
              getLogger().info("Parameter: " + Constants.VERSION + ", Value: " + request.getVersion());
              getLogger().info("Parameter: " + Constants.PACKAGE + ", Value: " + request.getPackage());
              getLogger().info("Parameter: " + Constants.PACKAGE_IN_PATH_FORMAT + ", Value: " + packageInPathFormat);
          }
      
          for (Iterator<?> iterator = request.getProperties().keySet().iterator(); iterator.hasNext(); ) { // here,the result of request.getProperties() is a hashtable
              String key = (String) iterator.next();
      
              String value = request.getProperties().getProperty(key);
      
              if (maybeVelocityExpression(value)) {
                  value = evaluateExpression(context, key, value);
              }
      
              context.put(key, value);
      
              if (getLogger().isInfoEnabled()) {
                  getLogger().info("Parameter: " + key + ", Value: " + value);
              }
          }
          return context;
      }
      

      As above comment, the result of request.getProperties() is a HashTable, the fact is that the parameter order is not what we input but hash value, so it cause that some parameters are not evaluated because some parameters are relied on others.

      But the question is "how difference happens?" . In fact ,once the parameter are determined, the result will be determined, why it will be different in some case?

      IDEA use the java command to start the process of generating like:

      //代码占位符
      java -Dxxx=xxx org.apache.maven.plugins:maven-archetype-plugin:RELEASE:generate
      

      also, some parameters are not evaluated correctly.

      Attachments

        Activity

          This comment will be Viewable by All Users Viewable by All Users
          Cancel

          People

            Unassigned Unassigned
            jxsrlsl1234 Liu Shilong

            Dates

              Created:
              Updated:

              Slack

                Issue deployment