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