If the tests are not working by Monday then it's out on its ear ;-)

On Sun 19 Mar 2017 at 18:11, Karl Heinz Marbaise <khmarba...@gmx.de> wrote:

> Hi,
>
> I'm not sure if this for 3.5.0 beta or what ever we call it...at the
> moment the tests are not working...and I need to dive into it why are
> failing..it looks there are missing some dependencies..but I'm note sure
> about it...
>
> But it looks you have already decided what to do...
>
> Kind regards
> Karl Heinz Marbaise
>
> On 19/03/17 18:53, Stephen Connolly wrote:
> > Hervé and I were discussing this on IRC... perhaps we can merge this for
> > 3.5.0-beta-1 and if it causes issues then we can revert for 3.5.0
> >
> > As these are public static final String and char constants, it should not
> > break binary compatibility as javac inlines static final constants... it
> > may break compile compatibility, but that is OK.
> >
> > WDYT? If we have consensus then we'll merge tomorrow before I start the
> > release
> >
> > On 18 March 2017 at 18:12, Robert Scholte <rfscho...@apache.org> wrote:
> >
> >> Are you *really* sure these public static final fields are only used
> here?
> >>
> >>
> >> On Sat, 18 Mar 2017 18:19:05 +0100, <khmarba...@apache.org> wrote:
> >>
> >> Repository: maven
> >>> Updated Branches:
> >>>   refs/heads/MNG-6069 [created] b8efec709
> >>>
> >>>
> >>> [MNG-6069] Migrate to non deprecated parts of Commons CLI
> >>>
> >>>
> >>> Project: http://git-wip-us.apache.org/repos/asf/maven/repo
> >>> Commit: http://git-wip-us.apache.org/repos/asf/maven/commit/b8efec70
> >>> Tree: http://git-wip-us.apache.org/repos/asf/maven/tree/b8efec70
> >>> Diff: http://git-wip-us.apache.org/repos/asf/maven/diff/b8efec70
> >>>
> >>> Branch: refs/heads/MNG-6069
> >>> Commit: b8efec709cce46358da2eaa3d1c288f16ab4c8a8
> >>> Parents: 55eeb32
> >>> Author: Karl Heinz Marbaise <khmarba...@apache.org>
> >>> Authored: Sat Mar 18 18:18:27 2017 +0100
> >>> Committer: Karl Heinz Marbaise <khmarba...@apache.org>
> >>> Committed: Sat Mar 18 18:18:27 2017 +0100
> >>>
> >>> ----------------------------------------------------------------------
> >>>  .../java/org/apache/maven/cli/CLIManager.java   | 118
> >>> ++++++++++---------
> >>>  1 file changed, 60 insertions(+), 58 deletions(-)
> >>> ----------------------------------------------------------------------
> >>>
> >>>
> >>> http://git-wip-us.apache.org/repos/asf/maven/blob/b8efec70/m
> >>> aven-embedder/src/main/java/org/apache/maven/cli/CLIManager.java
> >>> ----------------------------------------------------------------------
> >>> diff --git
> a/maven-embedder/src/main/java/org/apache/maven/cli/CLIManager.java
> >>> b/maven-embedder/src/main/java/org/apache/maven/cli/CLIManager.java
> >>> index a9038bf..20376d9 100644
> >>> --- a/maven-embedder/src/main/java/org/apache/maven/cli/CLIManager.java
> >>> +++ b/maven-embedder/src/main/java/org/apache/maven/cli/CLIManager.java
> >>> @@ -24,9 +24,9 @@ import java.io.PrintWriter;
> >>> import org.apache.commons.cli.CommandLine;
> >>>  import org.apache.commons.cli.CommandLineParser;
> >>> -import org.apache.commons.cli.GnuParser;
> >>> +import org.apache.commons.cli.DefaultParser;
> >>>  import org.apache.commons.cli.HelpFormatter;
> >>> -import org.apache.commons.cli.OptionBuilder;
> >>> +import org.apache.commons.cli.Option;
> >>>  import org.apache.commons.cli.Options;
> >>>  import org.apache.commons.cli.ParseException;
> >>> @@ -35,43 +35,43 @@ import org.apache.commons.cli.ParseException;
> >>>   */
> >>>  public class CLIManager
> >>>  {
> >>> -    public static final char ALTERNATE_POM_FILE = 'f';
> >>> +    public static final String ALTERNATE_POM_FILE = "f";
> >>> -    public static final char BATCH_MODE = 'B';
> >>> +    public static final String BATCH_MODE = "B";
> >>> -    public static final char SET_SYSTEM_PROPERTY = 'D';
> >>> +    public static final String SET_SYSTEM_PROPERTY = "D";
> >>> -    public static final char OFFLINE = 'o';
> >>> +    public static final String OFFLINE = "o";
> >>> -    public static final char QUIET = 'q';
> >>> +    public static final String QUIET = "q";
> >>> -    public static final char DEBUG = 'X';
> >>> +    public static final String DEBUG = "X";
> >>> -    public static final char ERRORS = 'e';
> >>> +    public static final String ERRORS = "e";
> >>> -    public static final char HELP = 'h';
> >>> +    public static final String HELP = "h";
> >>> -    public static final char VERSION = 'v';
> >>> +    public static final String VERSION = "v";
> >>> -    public static final char SHOW_VERSION = 'V';
> >>> +    public static final String SHOW_VERSION = "V";
> >>> -    public static final char NON_RECURSIVE = 'N';
> >>> +    public static final String NON_RECURSIVE = "N";
> >>> -    public static final char UPDATE_SNAPSHOTS = 'U';
> >>> +    public static final String UPDATE_SNAPSHOTS = "U";
> >>> -    public static final char ACTIVATE_PROFILES = 'P';
> >>> +    public static final String ACTIVATE_PROFILES = "P";
> >>>     public static final String SUPRESS_SNAPSHOT_UPDATES = "nsu";
> >>> -    public static final char CHECKSUM_FAILURE_POLICY = 'C';
> >>> +    public static final String CHECKSUM_FAILURE_POLICY = "C";
> >>> -    public static final char CHECKSUM_WARNING_POLICY = 'c';
> >>> +    public static final String CHECKSUM_WARNING_POLICY = "c";
> >>> -    public static final char ALTERNATE_USER_SETTINGS = 's';
> >>> +    public static final String ALTERNATE_USER_SETTINGS = "s";
> >>>     public static final String ALTERNATE_GLOBAL_SETTINGS = "gs";
> >>> -    public static final char ALTERNATE_USER_TOOLCHAINS = 't';
> >>> +    public static final String ALTERNATE_USER_TOOLCHAINS = "t";
> >>>     public static final String ALTERNATE_GLOBAL_TOOLCHAINS = "gt";
> >>> @@ -103,50 +103,52 @@ public class CLIManager
> >>>     protected Options options;
> >>> -    @SuppressWarnings( { "static-access", "checkstyle:linelength" } )
> >>> +    // CHECKSTYLE_OFF: LineLength
> >>>      public CLIManager()
> >>>      {
> >>>          options = new Options();
> >>> -        options.addOption( OptionBuilder.withLongOpt( "help"
> >>> ).withDescription( "Display help information" ).create( HELP ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "file"
> >>> ).hasArg().withDescription( "Force the use of an alternate POM file (or
> >>> directory with pom.xml)" ).create( ALTERNATE_POM_FILE ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "define"
> >>> ).hasArg().withDescription( "Define a system property" ).create(
> >>> SET_SYSTEM_PROPERTY ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "offline"
> >>> ).withDescription( "Work offline" ).create( OFFLINE ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "version"
> >>> ).withDescription( "Display version information" ).create( VERSION ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "quiet"
> >>> ).withDescription( "Quiet output - only show errors" ).create( QUIET )
> );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "debug"
> >>> ).withDescription( "Produce execution debug output" ).create( DEBUG )
> );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "errors"
> >>> ).withDescription( "Produce execution error messages" ).create( ERRORS
> ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "non-recursive"
> >>> ).withDescription( "Do not recurse into sub-projects" ).create(
> >>> NON_RECURSIVE ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> "update-snapshots"
> >>> ).withDescription( "Forces a check for missing releases and updated
> >>> snapshots on remote repositories" ).create( UPDATE_SNAPSHOTS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "activate-profiles" ).withDescription( "Comma-delimited list of
> profiles to
> >>> activate" ).hasArg().create( ACTIVATE_PROFILES ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "batch-mode"
> >>> ).withDescription( "Run in non-interactive (batch) mode (disables
> output
> >>> color)" ).create( BATCH_MODE ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "no-snapshot-updates" ).withDescription( "Suppress SNAPSHOT updates"
> >>> ).create( SUPRESS_SNAPSHOT_UPDATES ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> "strict-checksums"
> >>> ).withDescription( "Fail the build if checksums don't match" ).create(
> >>> CHECKSUM_FAILURE_POLICY ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "lax-checksums"
> >>> ).withDescription( "Warn if checksums don't match" ).create(
> >>> CHECKSUM_WARNING_POLICY ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "settings"
> >>> ).withDescription( "Alternate path for the user settings file"
> >>> ).hasArg().create( ALTERNATE_USER_SETTINGS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> "global-settings"
> >>> ).withDescription( "Alternate path for the global settings file"
> >>> ).hasArg().create( ALTERNATE_GLOBAL_SETTINGS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "toolchains"
> >>> ).withDescription( "Alternate path for the user toolchains file"
> >>> ).hasArg().create( ALTERNATE_USER_TOOLCHAINS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "global-toolchains" ).withDescription( "Alternate path for the global
> >>> toolchains file" ).hasArg().create( ALTERNATE_GLOBAL_TOOLCHAINS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "fail-fast"
> >>> ).withDescription( "Stop at first failure in reactorized builds"
> ).create(
> >>> FAIL_FAST ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "fail-at-end"
> >>> ).withDescription( "Only fail the build afterwards; allow all
> non-impacted
> >>> builds to continue" ).create( FAIL_AT_END ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "fail-never"
> >>> ).withDescription( "NEVER fail the build, regardless of project result"
> >>> ).create( FAIL_NEVER ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "resume-from"
> >>> ).hasArg().withDescription( "Resume reactor from specified project"
> >>> ).create( RESUME_FROM ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "projects"
> >>> ).withDescription( "Comma-delimited list of specified reactor projects
> to
> >>> build instead of all projects. A project can be specified by
> >>> [groupId]:artifactId or by its relative path" ).hasArg().create(
> >>> PROJECT_LIST ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "also-make"
> >>> ).withDescription( "If project list is specified, also build projects
> >>> required by the list" ).create( ALSO_MAKE ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "also-make-dependents" ).withDescription( "If project list is
> specified,
> >>> also build projects that depend on projects on the list" ).create(
> >>> ALSO_MAKE_DEPENDENTS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "log-file"
> >>> ).hasArg().withDescription( "Log file where all build output will go
> >>> (disables output color)" ).create( LOG_FILE ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "show-version"
> >>> ).withDescription( "Display version information WITHOUT stopping build"
> >>> ).create( SHOW_VERSION ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "encrypt-master-password" ).hasOptionalArg().withDescription( "Encrypt
> >>> master security password" ).create( ENCRYPT_MASTER_PASSWORD ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> "encrypt-password"
> >>> ).hasOptionalArg().withDescription( "Encrypt server password" ).create(
> >>> ENCRYPT_PASSWORD ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "threads"
> >>> ).hasArg().withDescription( "Thread count, for instance 2.0C where C is
> >>> core multiplied" ).create( THREADS ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "legacy-local-repository" ).withDescription( "Use Maven 2 Legacy Local
> >>> Repository behaviour, ie no use of _remote.repositories. Can also be
> >>> activated by using -Dmaven.legacyLocalRepo=true" ).create(
> >>> LEGACY_LOCAL_REPOSITORY ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "builder"
> >>> ).hasArg().withDescription( "The id of the build strategy to use"
> ).create(
> >>> BUILDER ) );
> >>> +        options.addOption( Option.builder( HELP ).longOpt( "help"
> >>> ).desc( "Display help information" ).build() );
> >>> +        options.addOption( Option.builder( ALTERNATE_POM_FILE
> ).longOpt(
> >>> "file" ).hasArg().desc( "Force the use of an alternate POM file (or
> >>> directory with pom.xml)" ).build() );
> >>> +        options.addOption( Option.builder( SET_SYSTEM_PROPERTY
> >>> ).longOpt( "define" ).hasArgs().valueSeparator().desc( "Define a system
> >>> property" ).build() );
> >>> +        options.addOption( Option.builder( OFFLINE ).longOpt(
> "offline"
> >>> ).desc( "Work offline" ).build() );
> >>> +        options.addOption( Option.builder( VERSION ).longOpt(
> "version"
> >>> ).desc( "Display version information" ).build() );
> >>> +        options.addOption( Option.builder( QUIET ).longOpt( "quiet"
> >>> ).desc( "Quiet output - only show errors" ).build() );
> >>> +        options.addOption( Option.builder( DEBUG ).longOpt( "debug"
> >>> ).desc( "Produce execution debug output" ).build() );
> >>> +        options.addOption( Option.builder( ERRORS ).longOpt( "errors"
> >>> ).desc( "Produce execution error messages" ).build() );
> >>> +        options.addOption( Option.builder( NON_RECURSIVE ).longOpt(
> >>> "non-recursive" ).desc( "Do not recurse into sub-projects" ).build() );
> >>> +        options.addOption( Option.builder( UPDATE_SNAPSHOTS ).longOpt(
> >>> "update-snapshots" ).desc( "Forces a check for missing releases and
> updated
> >>> snapshots on remote repositories" ).build() );
> >>> +        options.addOption( Option.builder( ACTIVATE_PROFILES
> ).longOpt(
> >>> "activate-profiles" ).desc( "Comma-delimited list of profiles to
> activate"
> >>> ).hasArg().build() );
> >>> +        options.addOption( Option.builder( BATCH_MODE ).longOpt(
> >>> "batch-mode" ).desc( "Run in non-interactive (batch) mode (disables
> output
> >>> color)" ).build() );
> >>> +        options.addOption( Option.builder( SUPRESS_SNAPSHOT_UPDATES
> >>> ).longOpt( "no-snapshot-updates" ).desc( "Suppress SNAPSHOT updates"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( CHECKSUM_FAILURE_POLICY
> >>> ).longOpt( "strict-checksums" ).desc( "Fail the build if checksums
> don't
> >>> match" ).build() );
> >>> +        options.addOption( Option.builder( CHECKSUM_WARNING_POLICY
> >>> ).longOpt( "lax-checksums" ).desc( "Warn if checksums don't match"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( ALTERNATE_USER_SETTINGS
> >>> ).longOpt( "settings" ).hasArg().desc( "Alternate path for the user
> >>> settings file" ).build() );
> >>> +        options.addOption( Option.builder( ALTERNATE_GLOBAL_SETTINGS
> >>> ).longOpt( "global-settings" ).hasArg().desc( "Alternate path for the
> >>> global settings file" ).build() );
> >>> +        options.addOption( Option.builder( ALTERNATE_USER_TOOLCHAINS
> >>> ).longOpt( "toolchains" ).hasArg().desc( "Alternate path for the user
> >>> toolchains file" ).hasArg().build() );
> >>> +        options.addOption( Option.builder( ALTERNATE_GLOBAL_TOOLCHAINS
> >>> ).longOpt( "global-toolchains" ).desc( "Alternate path for the global
> >>> toolchains file" ).hasArg().build() );
> >>> +        options.addOption( Option.builder( FAIL_FAST ).longOpt(
> >>> "fail-fast" ).desc( "Stop at first failure in reactorized builds"
> ).build()
> >>> );
> >>> +        options.addOption( Option.builder( FAIL_AT_END ).longOpt(
> >>> "fail-at-end" ).desc( "Only fail the build afterwards; allow all
> >>> non-impacted builds to continue" ).build() );
> >>> +        options.addOption( Option.builder( FAIL_NEVER ).longOpt(
> >>> "fail-never" ).desc( "NEVER fail the build, regardless of project
> result"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( RESUME_FROM ).longOpt(
> >>> "resume-from" ).hasArg().desc( "Resume reactor from specified project"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( PROJECT_LIST ).longOpt(
> >>> "projects" ).desc( "Comma-delimited list of specified reactor projects
> to
> >>> build instead of all projects. A project can be specified by
> >>> [groupId]:artifactId or by its relative path." ).hasArg().build() );
> >>> +        options.addOption( Option.builder( ALSO_MAKE ).longOpt(
> >>> "also-make" ).desc( "If project list is specified, also build projects
> >>> required by the list" ).build() );
> >>> +        options.addOption( Option.builder( ALSO_MAKE_DEPENDENTS
> >>> ).longOpt( "also-make-dependents" ).desc( "If project list is
> specified,
> >>> also build projects that depend on projects on the list" ).build() );
> >>> +        options.addOption( Option.builder( LOG_FILE ).longOpt(
> >>> "log-file" ).hasArg().desc( "Log file where all build output will go"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( SHOW_VERSION ).longOpt(
> >>> "show-version" ).desc( "Display version information WITHOUT stopping
> build"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( ENCRYPT_MASTER_PASSWORD
> >>> ).longOpt( "encrypt-master-password" ).optionalArg( true ).desc(
> "Encrypt
> >>> master security password" ).build() );
> >>> +        options.addOption( Option.builder( ENCRYPT_PASSWORD ).longOpt(
> >>> "encrypt-password" ).optionalArg( true ).desc( "Encrypt server
> password"
> >>> ).build() );
> >>> +        options.addOption( Option.builder( THREADS ).longOpt(
> "threads"
> >>> ).hasArg().desc( "Thread count, for instance 2.0C where C is core
> >>> multiplied" ).build() );
> >>> +        options.addOption( Option.builder( LEGACY_LOCAL_REPOSITORY
> >>> ).longOpt( "legacy-local-repository" ).desc( "Use Maven 2 Legacy Local
> >>> Repository behaviour, ie no use of _remote.repositories. Can also be
> >>> activated by using -Dmaven.legacyLocalRepo=true" ).build() );
> >>> +        options.addOption( Option.builder( BUILDER ).longOpt(
> "builder"
> >>> ).hasArg().desc( "The id of the build strategy to use" ).build() );
> >>>         // Adding this back in for compatibility with the verifier that
> >>> hard codes this option.
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "no-plugin-registry" ).withDescription( "Ineffective, only kept for
> >>> backward compatibility" ).create( "npr" ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "check-plugin-updates" ).withDescription( "Ineffective, only kept for
> >>> backward compatibility" ).create( "cpu" ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt( "update-plugins"
> >>> ).withDescription( "Ineffective, only kept for backward compatibility"
> >>> ).create( "up" ) );
> >>> -        options.addOption( OptionBuilder.withLongOpt(
> >>> "no-plugin-updates" ).withDescription( "Ineffective, only kept for
> backward
> >>> compatibility" ).create( "npu" ) );
> >>> +        options.addOption( Option.builder( "npr" ).longOpt(
> >>> "no-plugin-registry" ).desc( "Ineffective, only kept for backward
> >>> compatibility" ).build() );
> >>> +        options.addOption( Option.builder( "cpu" ).longOpt(
> >>> "check-plugin-updates" ).desc( "Ineffective, only kept for backward
> >>> compatibility" ).build() );
> >>> +        options.addOption( Option.builder( "up" ).longOpt(
> >>> "update-plugins" ).desc( "Ineffective, only kept for backward
> >>> compatibility" ).build() );
> >>> +        options.addOption( Option.builder( "npu" ).longOpt(
> >>> "no-plugin-updates" ).desc( "Ineffective, only kept for backward
> >>> compatibility" ).build() );
> >>> +
> >>>      }
> >>> +    // CHECKSTYLE_ON: LineLength
> >>>     public CommandLine parse( String[] args )
> >>>          throws ParseException
> >>> @@ -154,7 +156,7 @@ public class CLIManager
> >>>          // We need to eat any quotes surrounding arguments...
> >>>          String[] cleanArgs = CleanArgument.cleanArgs( args );
> >>> -        CommandLineParser parser = new GnuParser();
> >>> +        CommandLineParser parser = new DefaultParser();
> >>>         return parser.parse( options, cleanArgs );
> >>>      }
> >>>
> >>
> >> ---------------------------------------------------------------------
> >> To unsubscribe, e-mail: dev-unsubscr...@maven.apache.org
> >> For additional commands, e-mail: dev-h...@maven.apache.org
>
> ---------------------------------------------------------------------
> To unsubscribe, e-mail: dev-unsubscr...@maven.apache.org
> For additional commands, e-mail: dev-h...@maven.apache.org
>
> --
Sent from my phone

Reply via email to